Go的openpgp包中的PGP密钥装甲编码

时间:2018-02-22 23:51:15

标签: go public-key-encryption gnupg pgp openpgp

我正在尝试使用Go的openpgp/armor包以ASCII装甲编码打印PGP公钥。

我期望的输出:

-----BEGIN PGP PUBLIC KEY BLOCK-----

<base64 encoded bytes of public key>
<checksum>
-----END PGP PUBLIC KEY BLOCK-----

我得到的输出:

-----BEGIN PGP PUBLIC KEY BLOCK-----

<first part of base64 encoded bytes of public key>

它只打印公钥的第一部分。

公钥是从本地密钥环文件中获取的,并按如下方式处理:

keyRingFileBuffer, err := os.Open(keyRingFilePath)
if err != nil {
    log.Fatal(err)
}
defer keyRingFileBuffer.Close()

keyRing,err := openpgp.ReadKeyRing(keyRingFileBuffer)
if err != nil {
    log.Fatal(err)
}

for _, k := range keyRing {
    w, _ := armor.Encode(os.Stdout, openpgp.PublicKeyType, nil)
    k.PrimaryKey.Serialize(w)
}

我是否错误地使用了包裹?关于如何跟踪这个(在我看来)错误输出的原因的任何想法?

1 个答案:

答案 0 :(得分:3)

哎呀,在对这个问题给予赏金之后,我找到了答案。哦,好吧。

必须关闭armor编写器才能添加该结束行。

pubKeyBuf := bytes.NewBuffer(nil)
pubKeyWriter, err := armor.Encode(pubKeyBuf, openpgp.PublicKeyType, nil)
checkIfError(err)
err = e.Serialize(pubKeyWriter)
pubKeyWriter.Close()
checkIfError(err)