>백엔드 개발 >Golang >Go에서 ECDSA 개인 키를 어떻게 안전하게 저장하나요?

Go에서 ECDSA 개인 키를 어떻게 안전하게 저장하나요?

Barbara Streisand
Barbara Streisand원래의
2024-11-11 05:08:02911검색

How do you securely store ECDSA private keys in Go?

Go에서 ECDSA 개인 키 저장: 종합 가이드

Go에서 ECDSA(타원 곡선 디지털 서명 알고리즘)로 작업할 때 개인 키를 안전하게 저장하는 데 필요합니다. ecdsa.GenerateKey 메서드는 개인/공개 키 쌍을 생성하는 방법을 제공하지만 개인 키 저장은 개발자에게 맡깁니다. 이 가이드에서는 Go에서 ECDSA 개인 키를 저장하는 데 권장되는 접근 방식을 자세히 알아볼 것입니다.

사용자 정의 마샬링과 표준 인코딩

키 마샬링을 수동으로 구현할지 아니면 수동으로 구현할지 의문이 듭니다. 표준 인코딩 방법을 사용합니다. 권장되는 접근 방식은 키 저장을 위해 표준 Go 라이브러리를 활용하는 것입니다. 이는 다른 애플리케이션과의 상호 운용성을 보장하고 업계 모범 사례를 준수합니다.

PEM 인코딩: 다목적 옵션

PEM(Privacy-Enhanced Mail) 인코딩은 널리 채택되는 키 저장 표준. 여러 단계로 구성됩니다.

  1. 암호화 알고리즘: ECDSA 알고리즘은 키 생성에 사용됩니다.
  2. X.509 인코딩: 개인 키는 일반적으로 사용되는 X.509 형식으로 인코딩됩니다. 인증서.
  3. PEM 형식: 결과는 쉽게 처리할 수 있도록 PEM 블록으로 래핑됩니다.

인코딩 및 디코딩 키

다음 코드 샘플은 PEM을 사용하여 ECDSA 키를 인코딩 및 디코딩하는 방법을 보여줍니다. 인코딩:

import (
    "crypto/ecdsa"
    "crypto/elliptic"
    "crypto/pem"
    "crypto/rand"
    "fmt"
    "reflect"
)

func encode(privateKey *ecdsa.PrivateKey, publicKey *ecdsa.PublicKey) (string, string) {
    // Marshal the private key to X.509 format
    x509Encoded, _ := x509.MarshalECPrivateKey(privateKey)

    // Encode the X.509-formatted key into PEM format
    pemEncoded := pem.EncodeToMemory(&pem.Block{Type: "PRIVATE KEY", Bytes: x509Encoded})

    // Marshal the public key to X.509 format
    x509EncodedPub, _ := x509.MarshalPKIXPublicKey(publicKey)

    // Encode the X.509-formatted public key into PEM format
    pemEncodedPub := pem.EncodeToMemory(&pem.Block{Type: "PUBLIC KEY", Bytes: x509EncodedPub})

    return string(pemEncoded), string(pemEncodedPub)
}

func decode(pemEncoded string, pemEncodedPub string) (*ecdsa.PrivateKey, *ecdsa.PublicKey) {
    // Decode the PEM-encoded private key from a string
    block, _ := pem.Decode([]byte(pemEncoded))

    // Extract the X.509-formatted private key from the PEM block
    x509Encoded := block.Bytes

    // Parse the X.509-formatted private key
    privateKey, _ := x509.ParseECPrivateKey(x509Encoded)

    // Decode the PEM-encoded public key from a string
    blockPub, _ := pem.Decode([]byte(pemEncodedPub))

    // Extract the X.509-formatted public key from the PEM block
    x509EncodedPub := blockPub.Bytes

    // Parse the X.509-formatted public key
    genericPublicKey, _ := x509.ParsePKIXPublicKey(x509EncodedPub)

    // Convert the generic public key to an ecdsa.PublicKey
    publicKey := genericPublicKey.(*ecdsa.PublicKey)

    return privateKey, publicKey
}

// Test the encoding and decoding functionality
func test() {
    // Generate an ECDSA key pair
    privateKey, _ := ecdsa.GenerateKey(elliptic.P384(), rand.Reader)
    publicKey := &privateKey.PublicKey

    // Encode the key pair into PEM
    encPriv, encPub := encode(privateKey, publicKey)

    // Decode the PEM-encoded key pair
    priv2, pub2 := decode(encPriv, encPub)

    // Compare the original and decoded keys
    if !reflect.DeepEqual(privateKey, priv2) {
        fmt.Println("Private keys do not match.")
    }
    if !reflect.DeepEqual(publicKey, pub2) {
        fmt.Println("Public keys do not match.")
    }
}

이러한 기술을 활용하여 개발자는 Go에서 ECDSA 개인 키를 안전하게 저장하고 관리할 수 있습니다. PEM 인코딩은 강력하고 널리 사용되는 키 저장 형식을 제공하여 다양한 애플리케이션과의 상호 운용성을 지원하고 데이터 무결성을 보장합니다.

위 내용은 Go에서 ECDSA 개인 키를 어떻게 안전하게 저장하나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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