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

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

Mary-Kate Olsen
풀어 주다: 2024-10-26 16:41:30
원래의
434명이 탐색했습니다.

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

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿