Go - 如何从PublicKey生成SSH PublicKey指纹,PublicKey的类型可能是[rsa dsa ssh-rsa ssh-dss ecdsa]之一

时间:2017-09-26 12:33:25

标签: go ssh-keys

我只有一个PublicKey字符串,如何获取PublicKey指纹? 我有一些https://go-review.googlesource.com/c/crypto/+/32814的想法,但我不知道如何 实现ssh.PublicKey接口。

1 个答案:

答案 0 :(得分:4)

您可能希望使用ssh包中的ssh.ParseAuthorizedKey来加载密钥:

https://godoc.org/golang.org/x/crypto/ssh#ParseAuthorizedKey

这将为您提供一个公钥,您可以调用ssh.FingerprintLegacyMD5来获取指纹(假设您需要md5)。

https://godoc.org/golang.org/x/crypto/ssh#FingerprintLegacyMD5 https://godoc.org/golang.org/x/crypto/ssh#FingerprintSHA256

func main() {
    // Read a key from a file in authorized keys file line format
    // This could be an rsa.pub file or a line from authorized_keys
    pubKeyBytes := []byte(`ssh-rsa AAAABMYKEY...ABC me@myplace.local`)

    // Parse the key, other info ignored
    pk, _, _, _, err := ssh.ParseAuthorizedKey(pubKeyBytes)
    if err != nil {
        panic(err)
    }

    // Get the fingerprint
    f := ssh.FingerprintLegacyMD5(pk)

    // Print the fingerprint
    fmt.Printf("%s\n", f)
}

提供了两种指纹功能,不确定您需要哪种功能。