golang - marshal PKCS8私钥?

时间:2015-11-26 06:49:04

标签: go pkcs#8

有没有办法在1.5中编组PKCS8私钥? 例如类似于或从x509.MarshalPKCS1PrivateKey开始的东西?

2 个答案:

答案 0 :(得分:4)

有趣的是,没有标准功能可以做到这一点,但这是一个自定义解决方案:

type pkcs8Key struct {
    Version             int
    PrivateKeyAlgorithm []asn1.ObjectIdentifier
    PrivateKey          []byte
}


func rsa2pkcs8(key *rsa.PrivateKey) ([]byte, error) {
    var pkey pkcs8Key
    pkey.Version = 0 
    pkey.PrivateKeyAlgorithm = make([]asn1.ObjectIdentifier, 1)
    pkey.PrivateKeyAlgorithm[0] = asn1.ObjectIdentifier{1, 2, 840, 113549, 1, 1, 1}
    pkey.PrivateKey = x509.MarshalPKCS1PrivateKey(key)

    return asn1.Marshal(pkey)
}

答案 1 :(得分:1)

自从上面给出答案以来,go 1.10已通过x509.MarshalPKCS8PrivateKey方法发布。