AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / computer / Perguntas / 1526712
Accepted
paul23
paul23
Asked: 2020-02-20 08:50:57 +0800 CST2020-02-20 08:50:57 +0800 CST 2020-02-20 08:50:57 +0800 CST

Por que o SSH é mais seguro que o HTTPS em conexões diretas com um repositório Git com credenciais

  • 772

Bem, considere que as credenciais são armazenadas de maneira não segura em algum lugar do sistema de arquivos (opções padrão no Ubuntu). Existem alguns sites que dizem que usar SSH é mais seguro e deve ser usado como

"Com HTTPS, as credenciais são armazenadas em um arquivo não criptografado"

No entanto, isso faz muito pouco sentido para mim: com SSH você também tem um arquivo simples que armazena a chave (privada), então qualquer pessoa que pegar esse arquivo pode se conectar facilmente ao repositório git.

E não é como se nenhum dos arquivos fosse mais difícil de acessar: ambos são apenas armazenados no sistema de arquivos local principalmente não criptografados (no Linux).

Então, o que torna o SSH mais seguro que o HTTPS?

ssh git
  • 1 1 respostas
  • 7234 Views

1 respostas

  • Voted
  1. Best Answer
    cjs
    2020-02-20T17:26:07+08:002020-02-20T17:26:07+08:00

    Não está claro para mim se você foi informado de que o SSH é mais seguro que o HTTPS em seu caso específico (onde não temos todos os detalhes), o que pode estar absolutamente correto ou se você recebeu isso como um conselho geral. A análise de SSH vs. HTTPS pode ser surpreendentemente complexa para aqueles que não são bem versados ​​em análise de sistemas de segurança, e é por isso que tendemos a fazer declarações amplas como "SSH é mais seguro que HTTPS": geralmente será verdade, mesmo que seja não é verdade em todos os casos. De qualquer forma, aqui estão alguns pensamentos sobre o assunto.

    Como você mencionou o armazenamento de credenciais em um arquivo, esta resposta pressupõe que você esteja usando autenticação de chave pública/privada para HTTPS e SSH. A autenticação por senha é significativamente menos segura em ambos os casos.

    Armazenamento local de credenciais

    Primeiro, você está trabalhando com a suposição de que a credencial do usuário armazenada no disco não está protegida por uma senha. Isso pode ou não ser verdade, mas se fosse protegido por uma senha, isso aumentaria muito a segurança.

    No caso do SSH, é mais provável que a credencial seja protegida por uma senha porque os principais agentes são mais fáceis de usar e usados ​​com mais frequência com o SSH. Com o SSH, um agente chave está quase invariavelmente disponível porque ssh-agentou similar faz parte de quase todos os conjuntos padrão de ferramentas de cliente SSH. Isso também facilita o treinamento para usar o agente, pois o treinamento para o uso de uma ferramenta de uma maneira específica funciona praticamente em qualquer lugar.

    Os principais agentes para sistemas HTTPS são muito mais diversos, provavelmente menos comumente instalados e, mesmo se disponíveis em um determinado sistema, é menos provável que alguém saiba que um determinado está disponível e saiba como usá-lo.

    Agentes Remotos

    Em segundo lugar, o SSH oferece suporte a conexões de agentes remotos, permitindo remover o material de chave do sistema no qual você está fazendo o git fetch que, em muitos casos, pode levar a uma segurança muito melhor. Isso é melhor descrito por um exemplo do meu fluxo de trabalho mais comum.

    Meu laptop é uma máquina "pessoal" no sentido de que sou o único que tem acesso a ele. (Tem criptografia de disco total e contas de usuário apenas para mim.) Quando eu faço login, inicio um local ssh-agente carrego minha chave (também protegida por senha) nele, com ssh-askpass confirmação habilitada via ssh-add -c.

    Quando faço SSH no host no qual estou desenvolvendo, geralmente compartilhado com outras pessoas, uso ssh -Apara habilitar o encaminhamento do agente. Eu então git fetch, que inicia uma sessão SSH do host de desenvolvimento para o servidor para o controle remoto do Git.

    Esse SSH, quando solicitado pelo controle remoto para autenticação, recebe a solicitação e a encaminha de volta ao agente no meu laptop. Recebo um alerta em minha tela de que meu agente local recebeu uma solicitação de autenticação, o que já esperava, pois acabei de iniciar uma ação que causaria isso e, portanto, aprovo a autenticação. O processo SSH no host de desenvolvimento recebe de volta as informações de que precisa para autenticar (válido apenas para aquela sessão específica), autentica com sucesso no servidor remoto e git fetchcontinua.

    Observe que isso é consideravelmente mais seguro porque a) a chave nunca esteve no servidor de desenvolvimento e, portanto, muito, muito menos acessível aos invasores (eles precisariam acessar meu laptop particular) e b) recebo notificações sobre solicitações para meu chave a ser usada, permitindo-me detectar tentativas inesperadas de usar a chave. (Qualquer usuário com root no servidor de desenvolvimento também pode encaminhar solicitações de autenticação para meu laptop.) E não precisei digitar uma frase secreta todas as vezes, portanto, ter um arquivo de chave protegido por senha é muito menos complicado.

    • 24

relate perguntas

  • adicionar git. comando não funciona

  • Exigir autenticação LDAP *e* autenticação ssh

  • Carregar chave “ec256.pem”: formato inválido é lançado ao tentar gerar chave pública a partir de chave privada

  • Recuperar arquivo excluído do git após o commit

  • Por que chown 600 id_rsa corrige problemas de permissões?

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Como posso reduzir o consumo do processo `vmmem`?

    • 11 respostas
  • Marko Smith

    Baixar vídeo do Microsoft Stream

    • 4 respostas
  • Marko Smith

    O Google Chrome DevTools falhou ao analisar o SourceMap: chrome-extension

    • 6 respostas
  • Marko Smith

    O visualizador de fotos do Windows não pode ser executado porque não há memória suficiente?

    • 5 respostas
  • Marko Smith

    Como faço para ativar o WindowsXP agora que o suporte acabou?

    • 6 respostas
  • Marko Smith

    Área de trabalho remota congelando intermitentemente

    • 7 respostas
  • Marko Smith

    O que significa ter uma máscara de sub-rede /32?

    • 6 respostas
  • Marko Smith

    Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows?

    • 1 respostas
  • Marko Smith

    O VirtualBox falha ao iniciar com VERR_NEM_VM_CREATE_FAILED

    • 8 respostas
  • Marko Smith

    Os aplicativos não aparecem nas configurações de privacidade da câmera e do microfone no MacBook

    • 5 respostas
  • Martin Hope
    CiaranWelsh Como posso reduzir o consumo do processo `vmmem`? 2020-06-10 02:06:58 +0800 CST
  • Martin Hope
    Jim Pesquisa do Windows 10 não está carregando, mostrando janela em branco 2020-02-06 03:28:26 +0800 CST
  • Martin Hope
    v15 Por que uma conexão de Internet gigabit/s via cabo (coaxial) não oferece velocidades simétricas como fibra? 2020-01-25 08:53:31 +0800 CST
  • Martin Hope
    fixer1234 O "HTTPS Everywhere" ainda é relevante? 2019-10-27 18:06:25 +0800 CST
  • Martin Hope
    andre_ss6 Área de trabalho remota congelando intermitentemente 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney Por que colocar um ponto após o URL remove as informações de login? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    jonsca Todos os meus complementos do Firefox foram desativados repentinamente, como posso reativá-los? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK É possível criar um código QR usando texto? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 Altere o nome da ramificação padrão do git init 2019-04-01 06:16:56 +0800 CST

Hot tag

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve