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 중국어 웹사이트의 기타 관련 기사를 참조하세요!