douyalin2258 2018-07-20 13:52
浏览 45
已采纳

从openpgp.Entity中提取rsa.PrivateKey

RSA has several key formats. Is there a way to extract a PKCS 1 private key from a PGP key in golang? Something lik this (it does not work):

var e *openpgp.Entity
e, err := openpgp.NewEntity("test11", "test", "test@test.com", nil)
if err != nil {
    fmt.Println(err)
    return
}

key, ok := e.PrivateKey.PrivateKey.(rsa.PrivateKey)
if !ok {
    // Here is the problem in this solution
    fmt.Printf("Assertation failed")
}

pkcs1PrivateKey := x509.MarshalPKCS1PrivateKey(&key)

privkey_pem := pem.EncodeToMemory(
    &pem.Block{
        Type:  "RSA PRIVATE KEY",
        Bytes: pkcs1PrivateKey,
    },
)
fmt.Printf(string(privkey_pem))
  • 写回答

2条回答 默认 最新

  • doujiu9172 2018-07-20 16:09
    关注

    You need to cast to *rsa.PrivateKey and call MarshalPKCS1PrivateKey(key):

    key, ok := e.PrivateKey.PrivateKey.(*rsa.PrivateKey)
    if !ok {
        // Here is the problem in this solution
        fmt.Printf("Assertation failed")
    }
    
    pkcs1PrivateKey := x509.MarshalPKCS1PrivateKey(key)
    

    But this will only make this bit of code work. In production code, you'll need to do a type switch like @Jimb mentioned.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 对于squad数据集的基于bert模型的微调
  • ¥15 为什么我运行这个网络会出现以下报错?CRNN神经网络
  • ¥20 steam下载游戏占用内存
  • ¥15 CST保存项目时失败
  • ¥15 树莓派5怎么用camera module 3啊
  • ¥20 java在应用程序里获取不到扬声器设备
  • ¥15 echarts动画效果的问题,请帮我添加一个动画。不要机器人回答。
  • ¥15 Attention is all you need 的代码运行
  • ¥15 一个服务器已经有一个系统了如果用usb再装一个系统,原来的系统会被覆盖掉吗
  • ¥15 使用esm_msa1_t12_100M_UR50S蛋白质语言模型进行零样本预测时,终端显示出了sequence handled的进度条,但是并不出结果就自动终止回到命令提示行了是怎么回事: