Aller au contenu

Créer des clés SSH dans Windows et WSL

Créer les clés dans l'invite de commande:

C:\Users\enzo2> ssh-keygen

Crée un dossier .ssh contenant les clés publique/privée

On copie la clé publique sur le serveur:

C:\Users\bruno\Desktop> type C:\Users\bruno\.ssh\id_rsa.pub | ssh -p42666 bruno@192.168.1.7 'cat >> .ssh/authorized_keys'
** ne marche pas **

Copier les clés dans wsl:

cp -r /mnt/c/Users/bruno/.ssh ~/.ssh

ou créer des liens symboliques:

> ln -s /mnt/c/Users/bruno/.ssh/id_rsa ~/.ssh/id_rsa
> ln -s /mnt/c/Users/bruno/.ssh/id_rsa.pub ~/.ssh/id_rsa.pub
> ln -s /mnt/c/Users/bruno/.ssh ~/.ssh

Dans wsl, fixer les permissions:

$ cd ~/.ssh
$ chmod 600 id_rsa
$ chmod 644 id_rsa.pub
$ chmod 644 known_hosts

$ cd ~
$ chmod 700 .ssh

On se connecte au serveur avec le mdp:

$ ssh -p42666 bruno@192.168.1.7
bruno@192.168.1.7's password:
bruno@DS916:~ $
bruno@DS916:~ $ exit

On copie la clé publique sur le serveur:

$ cd ~/.ssh
$ cat id_rsa.pub | ssh -p42666 bruno@192.168.1.7 'cat>> ~/.ssh/authorized_keys'
$ cat id_rsa.pub | ssh funnymac@ftp.cluster011.ovh.net 'cat>> ~/.ssh/authorized_keys'

On se connecte enfin au serveur avec la clé:

$ ssh -p42666 bruno@192.168.1.7
Enter passphrase for key '/home/enzo2/.ssh/id_rsa'
bruno@DS916:~ $

On installe keychain:

$ sudo apt install keychain

puis

pour Bash: ajouter au fichier ~/.bashrc

eval `keychain --eval --agents ssh id_rsa`

pour Zsh: ajouter au fichier .zshrc

eval `keychain --eval --agents ssh id_rsa`

ou ajouter au fichier .zshrc

function check_ssh {
  [[ $3 =~ '\bssh\b' ]] || return
  [[ -n "$SSH_AGENT_PID" && -e "/proc/$SSH_AGENT_PID" ]] \
    && ssh-add -l >/dev/null && return
  eval `keychain --eval id_dsa --timeout 60`
}    
autoload -U add-zsh-hook
add-zsh-hook preexec check_ssh

https://unix.stackexchange.com/a/532477


Dernière mise à jour: April 7, 2020