Go에서 RSA 키를 생성하는 방법: OpenSSL의 `genrsa`와 동일합니까?
Go에서 RSA 키 생성: OpenSSL의 genrsa 유틸리티와 동일
문제:
RSA 키 쌍 생성 및 공개 추출 키는 암호화에서 일반적인 작업이 될 수 있습니다. OpenSSL의 genrsa 유틸리티는 이를 수행하는 편리한 방법을 제공합니다. 하지만 Go를 사용하여 동일한 기능을 어떻게 달성할 수 있습니까?
해결책:
Go에서 RSA 핵심 구성 요소를 생성하고 추출하려면 다음 단계를 따르세요.
1. RSA 키 쌍 생성
rsa.GenerateKey를 사용하여 RSA 키 쌍을 생성할 수 있습니다. 이 함수는 *rand.Rand 소스를 입력으로 사용합니다.
2. 공개 키 추출
개인 키에서 공개 구성 요소를 얻으려면 rsa.PrivateKey.Public을 사용합니다. rsa.PublicKey 인터페이스가 반환됩니다.
3. PKCS#1 PEM 형식으로 변환
개인 키와 공개 키 모두 PKCS#1 ASN.1 DER 형식으로 변환해야 합니다. 이를 위해서는 x509.MarshalPKCS1PrivateKey 및 x509.MarshalPKCS1PublicKey를 사용하세요.
4. PEM 블록으로 인코딩
PEM 인코딩은 변환된 키를 인식 가능한 PEM 블록으로 래핑하는 데 사용됩니다. pem.EncodeToMemory가 이를 달성할 수 있습니다.
5. 파일에 출력 쓰기
마지막 단계에서는 개인 키와 공개 키를 별도의 파일에 작성하는 작업이 포함됩니다.
예:
package main import ( "crypto/rand" "crypto/rsa" "crypto/x509" "encoding/pem" "io/ioutil" ) func main() { filename := "key" bitSize := 4096 // Generate RSA key pair. key, err := rsa.GenerateKey(rand.Reader, bitSize) if err != nil { panic(err) } // Extract public component. pub := key.Public() // Encode private key to PKCS#1 PEM. keyPEM := pem.EncodeToMemory( &pem.Block{ Type: "RSA PRIVATE KEY", Bytes: x509.MarshalPKCS1PrivateKey(key), }, ) // Encode public key to PKCS#1 PEM. pubPEM := pem.EncodeToMemory( &pem.Block{ Type: "RSA PUBLIC KEY", Bytes: x509.MarshalPKCS1PublicKey(pub.(*rsa.PublicKey)), }, ) // Write private key to file. if err := ioutil.WriteFile(filename+".rsa", keyPEM, 0700); err != nil { panic(err) } // Write public key to file. if err := ioutil.WriteFile(filename+".rsa.pub", pubPEM, 0755); err != nil { panic(err) } }
이 예에서는 key.rsa(개인 키)와 key.rsa.pub(공개 키)라는 두 개의 파일을 생성합니다.
위 내용은 Go에서 RSA 키를 생성하는 방법: OpenSSL의 `genrsa`와 동일합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Go Language Pack 가져 오기 : 밑줄과 밑줄이없는 밑줄의 차이점은 무엇입니까?

Beego 프레임 워크에서 페이지간에 단기 정보 전송을 구현하는 방법은 무엇입니까?

MySQL 쿼리 결과 목록을 GO 언어로 사용자 정의 구조 슬라이스로 변환하는 방법은 무엇입니까?

GO에서 제네릭에 대한 사용자 정의 유형 제약 조건을 어떻게 정의 할 수 있습니까?

이동 중에 테스트를 위해 모의 개체와 스터브를 작성하려면 어떻게합니까?

추적 도구를 사용하여 GO 응용 프로그램의 실행 흐름을 이해하려면 어떻게해야합니까?
