Microsoft MVP성태의 닷넷 이야기
openssl genrsa 2048시 키 생성이 다르게 됩니다. [링크 복사], [링크+제목 복사],
조회: 3645
글쓴 사람
김재영 (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]

... 31  32  [33]  34  35  36  37  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
5044엿장수8/20/20188554graphedit 에 등록되어있는 필터를 가져와서 사용하는방법을 알고싶습니다 [2]
5043hori...8/20/20188213Expression에 대한 책의 예제 관련하여 질문드립니다. [1]
5042황윤하8/20/20189978모드버스 TCP 관련 질문 [3]
5041david8/18/20189586.NET WebAPI 에서 Response 지연되는 이유 [3]
5040농상8/14/20189048정규표현식에 대해서 [3]
5039유영태8/14/201810623비동기 소켓사용후 해당 스레드가 남아있을때 처리 방법 [4]파일 다운로드1
5038이정석8/9/20188791서버파일 로컬파일 비교 [2]
5037jjh8/8/201812059c# 으로 화면캡쳐해서 동영상으로 만드는앱을 만들고싶습니다 [6]
5036볼딱지8/8/20189934C# programming 개발 관련 질문이 있습니다. [1]
5035궁금합니...8/8/201810486C# 버전 고민 어떤 책을 사야하나요? [1]
5034신동열8/8/20189021덤프 파일 분석 관련해서 문의 드려요. [1]
5033최규성8/7/201811104C# WinForm, Oracle 9i 로 프로그래밍시 ODP.NET, 배포 설정 방법 질문입니다. [6]
5032이정석8/6/201812918C# 으로 만들 dll 등록 [7]
5031J.S.8/6/20188563System.Array class의 구조에 대한 질문 [1]
5030농상8/4/20189084람다 식을 이용한 메서드 정의 확대를 공부하고 있습니다. [2]
5029Soul...8/3/20188618C# ActiveX 컨트롤 질문드립니다. [4]
5028도토리8/1/20189161혹시 회사에서 TFS 구축시 SQL-Server 라이선스 정책 아시는분 계신지요? [2]
5027농상7/31/20189917Freachable Queue의 발음을 표기하면 어떨까요? [2]
5026농상7/31/201812365소멸자의 이름에 대해서 [2]
5025김기철7/30/20189851selenium 질문좀 드릴개요 [3]
5024농상7/29/20189132패턴 매칭 when에 대해서 질문있습니다. [2]
5023농상7/28/201812064패턴매칭에 대해서 질문 있습니다. [1]
5022농상7/28/20189102튜플에 대해서 건의가 있습니다. [1]
5021농상7/27/20188589예외필터에 대해서 질문이요 [4]
5020농상7/27/201811449null 조건 연산자 예제에서 잠깐 혼동이 일어났습니다. [1]
5019농상7/26/201813730오버플로우와 언더플로우 [2]
... 31  32  [33]  34  35  36  37  38  39  40  41  42  43  44  45  ...