GNU/Linux >> Belajar Linux >  >> Linux

dapatkan sidik jari kunci SSH dalam format hex (lama) pada versi baru openssh

Klien melaporkan hash sha1 dari kunci server sebagai urutan 16 pasang digit hex, seperti ini:

    a7:b1:3e:3d:84:24:a2:5a:91:5f:6f:e9:cf:dd:2b:6a

Ini hash MD5.

Seperti yang Anda lihat berjalan

ssh-keygen -l -E md5 -f ssh_host_ecdsa_key.pub

akan memberi Anda sidik jari yang sama dengan yang Anda butuhkan tanpa harakiri seperti yang Anda jelaskan dalam jawaban Anda.


Ternyata, SSH Cookbook memiliki cara untuk membuat kunci secara manual dalam format hex lama. Saya menggunakan ini di server freebsd.

awk '{print $2}' key.pub | base64 -d | md5 | sed 's/../&:/g; s/:.*$//'

Menguraikan ini:

awk '{print $2}' key.pub

cetak kolom kedua (dipisahkan spasi) di "key.pub", yang merupakan kunci itu sendiri

base64 -d

kuncinya disandikan base64. Ini akan menampilkan byte sebenarnya dari kunci

md5

ini setara dengan freebsd dari 'md5sum -b' yang ditentukan dalam resep di halaman buku masak ssh

sed 's/../&:/g; s/:.*$//'

Ada dua perintah sed di sini:

s/../&:/g;

ganti setiap pasangan karakter pada baris (berkat bendera 'g' di bagian akhir) dengan pasangan yang sama diikuti dengan tanda titik dua

s/:.*$//'

hapus tanda titik dua di belakang (ganti tanda titik dua diikuti dengan spasi diikuti dengan apa pun hingga akhir baris tanpa apa pun).


Dalam kasus seperti ini saya menggunakan skrip kecil berikut (diuji pada Debian dan Ubuntu):

#!/bin/sh

# Gather the public ssh host keys for the given host
# and for each key print the fingerprint in hex format using the given
# checksum command (e.g. md5sum, sha256sum, ...)

if [ "$#" != 2 ]; then
  echo "usage: $0 hostname checksum_command"
  exit 1
fi

ssh-keyscan $1 2>/dev/null | while read -r line; do
  echo "Scanned key:"
  echo $line
  echo "$2 fingerprint:"
  echo $line | awk '{print $3}' | base64 -d | $2 -b | awk '{print $1}' | sed 's/../&:/g' | sed 's/:$//'
  echo
done

Contoh penggunaan:

$ myscript host.example.com md5sum
Scanned key:
host.example.com ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIJUXq7vpcEpnZQxxiLw/tdg8ui4LoqbW1O5nGyLtGw49
md5sum fingerprint:
6c:ef:26:f7:98:ad:ed:5b:cc:ff:83:13:46:c9:f6:79

Scanned key:
host.example.com ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQC4aLMajBvisnWNR2VX5K1KEkNeRmzlcs+svbY6/DiumMTZNtqB5duZjGkMmEbIclHaT7rQG9efAWsNhai5cJVRZ4VX1Gu/TLycEk4OY56MrrWjQYweSUr/W6E0eVCf7gh/ym2vMcevct4373fGDdlogk9Wa97lDV6PUXRy/znxRlo3tBc6KMOZIBoPu8UjeLr2ZPNPjO6hXX/96HbYfboxjhMl5eb8AWR0MGd4qU7RZZa2XhT4/4eSo8h9gEq8V3tasB24fMdw3K+HRiDyZm8uoNq+IrJlC22pBpzxRQtsv0Nd+uC5pK/UPVI3AFfdHMrmn7IHRio8aEaTloM6MRysGMtXE0kFQ/pV2U3TBmK/9wxID83qMDsQeUH4oTyjSJ0dCBuqgVQUg44z5qXVOK7gruvZSTyH7DsIyAXhlvLNwdtXPJ4HPQ90ZxLpiFWYgSPErQgbfgKeFkoSQiSP1M+UMkITCGRKMeUeDINheRJh/5y8+C3DjE54xyI4903ztyI7HqgVTOOFCtf+dlhCuS6+J20PFXEHDMdGCwmPQrKOG9Rb4NBxuvtn7MxJnwnlIu3nhDjr8SlZDOTvuK+bLpc4AZwEsNY7ANKFvj2mqE6hjkhu+x7khg84VQ6BKOmHIQnMrCpqICaNgB7Vz2d183BETrnfKQaPh79G5cQox5vwvw==
md5sum fingerprint:
b2:9c:cd:30:b1:38:e3:d1:17:d6:73:eb:03:9a:80:83

$ myscript host.example.com sha256sum
Scanned key:
host.example.com ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQC4aLMajBvisnWNR2VX5K1KEkNeRmzlcs+svbY6/DiumMTZNtqB5duZjGkMmEbIclHaT7rQG9efAWsNhai5cJVRZ4VX1Gu/TLycEk4OY56MrrWjQYweSUr/W6E0eVCf7gh/ym2vMcevct4373fGDdlogk9Wa97lDV6PUXRy/znxRlo3tBc6KMOZIBoPu8UjeLr2ZPNPjO6hXX/96HbYfboxjhMl5eb8AWR0MGd4qU7RZZa2XhT4/4eSo8h9gEq8V3tasB24fMdw3K+HRiDyZm8uoNq+IrJlC22pBpzxRQtsv0Nd+uC5pK/UPVI3AFfdHMrmn7IHRio8aEaTloM6MRysGMtXE0kFQ/pV2U3TBmK/9wxID83qMDsQeUH4oTyjSJ0dCBuqgVQUg44z5qXVOK7gruvZSTyH7DsIyAXhlvLNwdtXPJ4HPQ90ZxLpiFWYgSPErQgbfgKeFkoSQiSP1M+UMkITCGRKMeUeDINheRJh/5y8+C3DjE54xyI4903ztyI7HqgVTOOFCtf+dlhCuS6+J20PFXEHDMdGCwmPQrKOG9Rb4NBxuvtn7MxJnwnlIu3nhDjr8SlZDOTvuK+bLpc4AZwEsNY7ANKFvj2mqE6hjkhu+x7khg84VQ6BKOmHIQnMrCpqICaNgB7Vz2d183BETrnfKQaPh79G5cQox5vwvw==
sha256sum fingerprint:
f4:61:58:e4:90:65:c4:70:98:7f:d1:40:0a:d8:d9:79:14:e6:91:dc:b6:ed:91:8c:c0:df:d9:65:db:dd:a0:18

Scanned key:
host.example.com ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIJUXq7vpcEpnZQxxiLw/tdg8ui4LoqbW1O5nGyLtGw49
sha256sum fingerprint:
4b:73:d1:d7:80:87:46:64:56:71:64:10:7a:66:83:9b:c7:58:39:0b:16:74:dd:9b:d9:4b:e5:d5:61:7e:99:45

Linux
  1. SSH tanpa kata sandi menggunakan pasangan kunci publik-swasta

  2. Bagaimana Cara Mendapatkan Versi Ksh dengan Aman?

  3. Ssh – Perbedaan Antara Kunci Openssh dan Kunci Putty?

  1. Pengaturan otentikasi berbasis SSH Key dari openSSH ke SSH2

  2. Cara Melakukan SSH dan SCP Tanpa Password dari SSH2 ke OpenSSH

  3. Beli versi Windows lama sekarang dan masih dapat upgrade gratis?

  1. 3 cara saya mengonfigurasi SSH untuk privasi

  2. Cara Mengatur Kunci SSH

  3. Bagaimana Mengonversi File PPK ke OpenSSH Keys dan Login menggunakan SSH di Linux?