dongqing904999 2016-11-08 22:26
浏览 119

如何使用tls cert和key创建PGP密钥,以及如何使用PGP私钥在golang中解密PGP消息?

started with the following logic,

(based on: RSA key part is common for TLS and PGP)

tlsCert, err := tls.LoadX509KeyPair(certFilePath, keyFilePath)
if err != nil {
    return
}
certx509, _ := ioutil.ReadFile(certFilePath)

block, _ := pem.Decode([]byte(certx509))
certTest, err := x509.ParseCertificate(block.Bytes)
if err != nil {
    return
}

privateKeyTest := tlsCert.PrivateKey

config = &packet.Config{}
config.DefaultCompressionAlgo = 1
config.DefaultCipher = 9
config.DefaultHash = 3
entity, _ = openpgp.NewEntity("", "", "", config)
entity.PrimaryKey.PublicKey = (certTest.PublicKey).(*rsa.PublicKey)
entity.PrivateKey.PrivateKey = privateKeyTest.(*rsa.PrivateKey)

entitylist := make(openpgp.EntityList, 1)
entitylist[0] = entity

md, err := openpgp.ReadMessage(encryptedmessagebytes, entitylist , nil, config)

openpgp.ReadMessage returns the following error

openpgp: invalid data: tag byte does not have MSB set

I think I'm missing something while creating the entity. Can you please help me with this?

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
    • ¥15 如何在scanpy上做差异基因和通路富集?
    • ¥20 关于#硬件工程#的问题,请各位专家解答!
    • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
    • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
    • ¥30 截图中的mathematics程序转换成matlab
    • ¥15 动力学代码报错,维度不匹配
    • ¥15 Power query添加列问题
    • ¥50 Kubernetes&Fission&Eleasticsearch
    • ¥15 報錯:Person is not mapped,如何解決?