【问题标题】:How to convert a interface{} into type *rsa.PublicKey golang如何将 interface{} 转换为类型 *rsa.PublicKey golang
【发布时间】:2017-01-17 13:25:29
【问题描述】:

我将公钥存储在接口类型的变量中{}

-----BEGIN PUBLIC KEY-----    MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDdlatRjRjogo3WojgGHFHYLugdUWAY9iR3fy4arWNA1KoS8kVw33cJibXr8bvwUAUparCwlvdbH6dvEOfou0/gCFQsHUfQrSDv+MuSUMAe8jzKE4qW+jK+xQU9a03GUnKHkkle+Q0pX/g6jXZ7r1/xAK5Do2kQ+X5xK9cipRgEKwIDAQAB
-----END PUBLIC KEY-----

无论如何我可以将其转换为 golang 中的 *rsa.PublicKey 类型。它可能涉及一些中间步骤,例如先将 interface{} 转换为字符串。

【问题讨论】:

  • 界面中的数据是什么类型的?一个字符串,或者它已经是一个 *rsa.PublicKey 并且你只需要知道如何告诉 Go 它是什么?

标签: go


【解决方案1】:

一般来说,您会使用 crypto/x509 库解码 pem 文件(假设这是在 x509 中)证书。文档中提供的example如下:

package main

import (
    "crypto/dsa"
    "crypto/ecdsa"
    "crypto/rsa"
    "crypto/x509"
    "encoding/pem"
    "fmt"
)

func main() {
    const pubPEM = `
-----BEGIN PUBLIC KEY-----
MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAlRuRnThUjU8/prwYxbty
WPT9pURI3lbsKMiB6Fn/VHOKE13p4D8xgOCADpdRagdT6n4etr9atzDKUSvpMtR3
CP5noNc97WiNCggBjVWhs7szEe8ugyqF23XwpHQ6uV1LKH50m92MbOWfCtjU9p/x
qhNpQQ1AZhqNy5Gevap5k8XzRmjSldNAFZMY7Yv3Gi+nyCwGwpVtBUwhuLzgNFK/
yDtw2WcWmUU7NuC8Q6MWvPebxVtCfVp/iQU6q60yyt6aGOBkhAX0LpKAEhKidixY
nP9PNVBvxgu3XZ4P36gZV6+ummKdBVnc3NqwBLu5+CcdRdusmHPHd5pHf4/38Z3/
6qU2a/fPvWzceVTEgZ47QjFMTCTmCwNt29cvi7zZeQzjtwQgn4ipN9NibRH/Ax/q
TbIzHfrJ1xa2RteWSdFjwtxi9C20HUkjXSeI4YlzQMH0fPX6KCE7aVePTOnB69I/
a9/q96DiXZajwlpq3wFctrs1oXqBp5DVrCIj8hU2wNgB7LtQ1mCtsYz//heai0K9
PhE4X6hiE0YmeAZjR0uHl8M/5aW9xCoJ72+12kKpWAa0SFRWLy6FejNYCYpkupVJ
yecLk/4L1W0l6jQQZnWErXZYe0PNFcmwGXy1Rep83kfBRNKRy5tvocalLlwXLdUk
AIU+2GKjyT3iMuzZxxFxPFMCAwEAAQ==
-----END PUBLIC KEY-----`

    block, _ := pem.Decode([]byte(pubPEM))
    if block == nil {
        panic("failed to parse PEM block containing the public key")
    }

    pub, err := x509.ParsePKIXPublicKey(block.Bytes)
    if err != nil {
        panic("failed to parse DER encoded public key: " + err.Error())
    }

    switch pub := pub.(type) {
    case *rsa.PublicKey:
        fmt.Println("pub is of type RSA:", pub)
    case *dsa.PublicKey:
        fmt.Println("pub is of type DSA:", pub)
    case *ecdsa.PublicKey:
        fmt.Println("pub is of type ECDSA:", pub)
    default:
        panic("unknown type of public key")
    }
}

我不太确定你那里的编码。以下内容可能会帮助您克服这一障碍:

【讨论】:

  • 问题中的关键正是使用这种格式。使用提问者的密钥查看此工作示例:Go Playground。输出:*rsa.PublicKey &rsa.PublicKey{N:15560...TRIMMED...309090347, E:65537}
  • 此示例在“无法解析包含公钥的 PEM 块”时出现恐慌,请参阅playground
【解决方案2】:

您可以使用: rsaPublickey, _ := pub.(*rsa.PublicKey) 转换为 rsa.PublicKey

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2016-11-29
    • 2017-10-17
    • 2014-12-30
    • 2014-02-14
    • 1970-01-01
    • 1970-01-01
    • 2019-06-07
    • 2021-05-11
    相关资源
    最近更新 更多