>  기사  >  백엔드 개발  >  Go 1.5에서 PKCS8 개인 키를 마샬링하는 방법은 무엇입니까?

Go 1.5에서 PKCS8 개인 키를 마샬링하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-10-26 16:41:30349검색

 How to Marshal PKCS8 Private Keys in Go 1.5?

Go에서 PKCS8 개인 키 마샬링

Go 1.5에서 PKCS8 개인 키를 마샬링할 수 있나요? 구체적으로 PKCS8용 x509.MarshalPKCS1PrivateKey와 유사한 방법이 있습니까?

해결책:

이 작업에 대한 표준 기능이 없더라도 사용자 지정 솔루션을 사용할 수 있습니다. :

<code class="go">import (
    "crypto/rsa"
    "crypto/asn1"
    "crypto/x509"
)

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)
}</code>

위 내용은 Go 1.5에서 PKCS8 개인 키를 마샬링하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.