The establishment of SSH
session consists of 2
parts: build up the encryption channel and authenticate user. To understand the whole flow better, I usetcpdump/Wireshark
to capture and analyze the packets. Server is OpenBSD 6.1
and client is ArchLinux
. The tcpdump
command is like this:
sudo tcpdump -A -s 0 'net 192.168.38.176' -i enp7s0f0 -w capture.pcap
(1) Connect server first time:
data:image/s3,"s3://crabby-images/127cc/127cc91042664c6f562563a5ad64fb2dd2bc693e" alt="1"
The captured packets:
data:image/s3,"s3://crabby-images/78544/78544c5bc24afc544fe774daa0baf7d91aa5141a" alt="C1"
We can see the client/server negotiated SSH
version firstĀ (In fact, client and server sentĀ SSH
version simultaneously, so please don’t misunderstand client sent first, then server responded. Use “nc 192.168.38.176 22
” command to check.)
, then exchanged public key to generate secret key. The server issued “New Keys
” message, and waited for client to answer.
(2) Accept server’s public key but not input password:
data:image/s3,"s3://crabby-images/e0db6/e0db6c2f21bffdbca771f9af550244252cee44da" alt="2"
The captured packets:
data:image/s3,"s3://crabby-images/55756/557565764d228eefb644c0266bc6e65747cdd42b" alt="C2"
The first packet should be client acknowledged server’s “New Keys
” message, then there are some interactions. Now the encryption channel is set up.
(3) Enter password and authenticate user:
data:image/s3,"s3://crabby-images/b4578/b45781c6ff5b7b71c98a6d638adfb917e575cd79" alt="3"
The captured packets:
data:image/s3,"s3://crabby-images/9f819/9f819accc0e27ea952334c439c5b8f67f98694a1" alt="C3"
These packets are all encrypted data. If user’s password is correct, the whole SSH
session will be ready, and you can administrator server now.
Reference:
Understanding the SSH Encryption and Connection Process.