Microsoft MVP성태의 닷넷 이야기
openssl genrsa 2048시 키 생성이 다르게 됩니다. [링크 복사], [링크+제목 복사]
조회: 3380
글쓴 사람
김재영 (kjyoffice at gmail.com)
홈페이지
첨부 파일
 

안녕하세요
요즘 암호화랑 보안성에 관심을 가져서 따라해보다가 막혀버린 것이 있습니다.

우선 참조한 문서는 성태님께서 작성한 문서입니다.
- https://www.sysnet.pe.kr/2/0/12992
- C# - BouncyCastle을 사용한 암호화/복호화 예제

이슈로는 openssl genrsa 2048시 키 생성이 다르게 됩니다.

성태님께서 언급한 방법대로
(Hyper-V의) 우분투 리눅스에서 아래의 명령을 실행했습니다.

# openssl genrsa 2048

성태님 문서에서는 키 시작에 RSA 단어가 있는데

-----BEGIN RSA PRIVATE KEY-----
...[생략]...
-----END RSA PRIVATE KEY-----

제가 우분투에서 생성한 키에는 RSA 단어가 없습니다.

-----BEGIN PRIVATE KEY-----
...[생략]...
-----END PRIVATE KEY-----

그래도 일단 성태님의 샘플 코드를 실행했습니다만
var rsaKey = pemReader.ReadObject() as Org.BouncyCastle.Crypto.AsymmetricCipherKeyPair;

이 부분에서 rsaKey가 계속 null이 나오고 있습니다.

혹시 제가 openssl 설정에서 빠트린 부분이 있을까요?


일단 키는 아무데서라도 만들어오자 싶어서
구글에서 "genrsa online"검색 온라인에서 키 만드는 사이트에서 생성
테스트 해보니 성태님 코드가 잘 됩니다.

제가 뭔가 빠트려서 그러는거 같은데 가이드나 참고 문서가 있다면 공유 부탁드리겠습니다.

구글에서 검색하여 아래의 문서도 찾았지만 지금의 저는 이해도가 떨어지고 있습니다. ㅠㅠ
https://stackoverflow.com/questions/20065304/differences-between-begin-rsa-private-key-and-begin-private-key

감사합니다.








[최초 등록일: ]
[최종 수정일: 2/5/2023]


비밀번호

댓글 작성자
 



2023-02-05 08시51분
아마도 아래의 덧글과 유사한 상황인 것 같은데요,

https://www.sysnet.pe.kr/2/0/10926#15913

그 덧글 바로 아래에 제가 답변을 했으니 그걸 참고해 보세요. RSA 문자열 유무는 언급하신 stackoverflow Q&A도 나오지만,

Differences between "BEGIN RSA PRIVATE KEY" and "BEGIN PRIVATE KEY"
; https://stackoverflow.com/questions/20065304/differences-between-begin-rsa-private-key-and-begin-private-key

간단하게 정리하면 "BEGIN RSA PRIVATE KEY"는 RSA 키로만 쓸 수 있고 PKCS#1 포맷입니다. 이후 RSA가 빠진 것은 PKCS#8 포맷이고, 그 자체에 개인키에 대한 종류도 지정할 수 있습니다.
정성태
2023-02-05 10시18분
[김재영] 수정된 코드를 신규 게시물로 작성했습니다.
[guest]

1  2  3  4  5  6  7  8  9  10  11  12  [13]  14  15  ...
NoWriterDateCnt.TitleFile(s)
5618김기헌3/2/20224333안녕하세요 생성자 옆에 this 키워드를 붙여 생성자를 여러 개 호출 시 질문드립니다 [2]
5617Edun2/25/20224458ArgumentOutOrRangeException에러 발생 [2]파일 다운로드1
5616csha...2/24/20224357readonly struct로 선언된 구조체를 특정 클래스에서 멤버변수로 가지는 경우 [1]
5615장성욱2/22/20226542SetThreadAffinityMask를 이용한 쓰레드 지정하는 방법에 대해 궁금합니다. [4]
5614민우2/22/20225828SSL 통신 문의 [6]
5613김인태2/22/20224387서버와 PC 간의 어플리케이션 성능 차이 [1]
5612팬입니다2/20/20224191Kastrel 서버 관련 [1]
5611차가워2/19/20224425stopWatch 늘어짐 문의 [3]
5610차가워2/18/20224314Stopwatch 늘어짐 문제 [1]
5609cs린이2/15/20224649c# 함수의 호출 방식에 대해 궁금합니다! [2]
5608지호2/10/20225158시작하세요 C# 8.0 중 제네릭타입의 IEnumerable [3]파일 다운로드1
5607이로운2/10/20224397안녕하세요. 궁금한게 있어서 질문드립니다. [1]
5605강성봉2/10/20224425TCP PSH flag 패킷 수신 에러 [1]
5604LW2/9/20224561VISUAL STUDIO 2019 ==> 2020 설치시 오류가 생겨서 문의드립니다. [3]
5603김진명2/9/20225837C# 10.0 출간은 언제쯤 계획하고 계신가요? [1]
5602신갑영2/8/20224639윈폼에 대해서 질문 드립니다. [1]
5601김인태2/4/20224881setup project 관련 [7]
5600itkim2/3/20225692윈도우 서버 계정 패스워드 인증 문의 [5]
5599레드골드2/3/20226165c#으로 ms word 제어 가능할까요? [6]
5598jaew...2/2/20224861Dictionary는 참조형식인가요?? [1]
5597재원2/2/20225204c# 9.0에 대한 내용을 받을 수 있나요? [1]
5596kss1/26/20224929듀얼 모니터 환경에서 wpf 프로그램 크기 변경 [2]
5594mira...1/25/20224578안녕하세요 try~catch 와 SuspendLayout~ResumeLayout 간 호출 문의드립니다! [2]
5593C#스터디1/12/20225483TaskAwaiter 구현 질문 입니다. [1]
5591유지킴12/24/20215108outofmemory in 32bit [2]파일 다운로드1
5590kss12/23/20214562포인터 메모리 에러 [1]
1  2  3  4  5  6  7  8  9  10  11  12  [13]  14  15  ...