>백엔드 개발 >Golang >Go에서 파일의 RSA 키를 읽는 방법은 무엇입니까?

Go에서 파일의 RSA 키를 읽는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-12 18:24:02542검색

How to Read an RSA Key from a File in Go?

파일에서 RSA 키를 읽는 방법

배경: RSA 키는 보안 통신을 위한 암호화에 널리 사용됩니다. RSA 기반 시스템을 구현할 때 인증이나 서명을 위해 파일에서 기존 개인 키를 로드해야 하는 경우가 많습니다. 그러나 파일에서 미리 생성된 키를 기반으로 키 구조를 구축하는 방법에 대한 포괄적인 지침을 찾는 것은 어려울 수 있습니다.

해결책: 파일에서 RSA 키를 읽으려면 다음 단계를 활용할 수 있습니다.

옵션 1: PKCS#1 인코딩된 키

  1. 개인 키가 PKCS#1 형식으로 인코딩되었는지 확인하세요. "-----BEGIN RSA PRIVATE KEY----"로 시작합니다.
  2. encoding/pem 패키지에서 Decode([]byte(pemString))를 사용하여 PEM으로 인코딩된 문자열을 디코딩합니다.
  3. x509 패키지의 ParsePKCS1PrivateKey(block.Bytes)를 사용하여 원시 키 바이트를 *rsa.PrivateKey로 구문 분석합니다.

옵션 2: PKCS#8 인코딩된 키

  1. 개인 키가 일반적으로 "-----BEGIN PRIVATE KEY-----"로 시작하는 PKCS#8 형식으로 인코딩되었는지 확인하세요.
  2. 디코드 옵션 1과 같은 PEM 인코딩 문자열.
  3. x509 패키지의 ParsePKCS8PrivateKey(block.Bytes)를 사용하여 원시 키 바이트를 *rsa.PrivateKey로 구문 분석합니다.

예제 코드:

// PKCS#1 Encoded Key Example
package main

import (
    "crypto/rsa"
    "crypto/x509"
    "encoding/pem"
)

func main() {
    keyPEMString := `-----BEGIN RSA PRIVATE KEY-----
    ... (Your PKCS#1 key here)
    -----END RSA PRIVATE KEY-----`

    keyData, _ := pem.Decode([]byte(keyPEMString))
    key, _ := x509.ParsePKCS1PrivateKey(keyData.Bytes)
    fmt.Println(key.N) // Access the RSA modulus
}

// PKCS#8 Encoded Key Example
package main

import (
    "crypto/rsa"
    "crypto/x509"
    "encoding/pem"
)

func main() {
    keyPEMString := `-----BEGIN PRIVATE KEY-----
    ... (Your PKCS#8 key here)
    -----END PRIVATE KEY-----`

    keyData, _ := pem.Decode([]byte(keyPEMString))
    key, _ := x509.ParsePKCS8PrivateKey(keyData.Bytes)
    rsaKey := key.(*rsa.PrivateKey)
    fmt.Println(rsaKey.N) // Access the RSA modulus
}

이러한 방법을 따르면 파일에서 RSA 키를 성공적으로 읽고 인스턴스화하여 애플리케이션에서 RSA 기반 작업을 수행할 수 있습니다.

위 내용은 Go에서 파일의 RSA 키를 읽는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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