Eu tenho uma pergunta simples sobre o protocolo OpenVPN. Vamos supor que temos dois usuários diferentes, com chaves diferentes para o mesmo servidor e ambas as chaves 1024bits. Se esses dois usuários fizerem exatamente a mesma solicitação e alguém estiver farejando os dados no servidor, essa pessoa (o farejador) verá os mesmos dados para usuários ou dados diferentes? A questão é saber se a chave privada do usuário interfere na criptografia APÓS a autenticação ou se é usada apenas no tempo de autenticação. Obrigado.
8
Respostas:
Dados diferentes.
As chaves públicas / privadas são usadas apenas durante a autenticação / negociação de chaves.
O OpenVPN pode operar em um dos dois modos , uma chave pré-compartilhada ou usando TLS com certificados. A chave pré-compartilhada é estática, constante, mas você está perguntando sobre o modo de certificado.
Não vou entrar em muitos detalhes e você mesmo pode procurar o TLS, mas basicamente o TLS usa os certificados (e chaves privadas) para autenticação e durante a fase de negociação de chaves. Ele gera uma chave de criptografia simétrica (por exemplo, BlowFish, AES etc.) e usa criptografia de chave pública para compartilhar essa chave com segurança.
As mensagens reais são então criptografadas com criptografia simétrica. Cada sessão tem sua própria chave de criptografia independente (por isso, se você desconectar e reconectar, na verdade, acabará com uma chave diferente). Da mesma forma, cada usuário terá sessões diferentes e, portanto, chaves diferentes.
Há duas razões para fazer isso. A criptografia simétrica é consideravelmente mais rápida que a criptografia assimétrica; portanto, é preferível para alto rendimento (a dificuldade é o compartilhamento de chaves, resolvido pela fase de negociação). Além disso, ao gerar uma nova chave toda vez, é mais difícil para as chaves comprometidas revelar os dados de outras sessões ( FS ).
fonte
Cada cliente criptografará seus dados com a chave negociada entre cliente e servidor, para que os dados recebidos no gateway VPN sejam diferentes para os dois usuários.
fonte