Microsoft MVP성태의 닷넷 이야기
openssl genrsa 2048시 키 생성이 다르게 됩니다. [링크 복사], [링크+제목 복사],
조회: 3592
글쓴 사람
김재영 (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)
5857guest3/17/20233356귀도 반 로썸을 보고 [4]
5856guest3/17/20233464Form1_FormClosing에 closing time을 Sqlite 저장하는 법? [6]파일 다운로드1
5855욜로3/17/20233006C# 메타데이터에서 불러오는 참조 정의가 안됨 [1]
5854민성3/16/20233217안녕하세요 asp.net mvc using문 관련하여 [1]
5853pa3/16/20233418오피스 2016 업데이트 후 파일 출력 불가 [1]
5852guest3/16/20233181입력 foreach 검색/출력 foreach [3]
5851guest3/15/20233525foreach내 list변경 [10]
5850독서가3/14/20233220C#에서 동적dll 사용시 문의입니다. [4]파일 다운로드1
5849guest3/9/20233192C# wpf로 Web에서 구동되는 hts가능한가요? (노트북없고 스마트폰 없음) [4]
5848민성3/9/20233111도움 요청드립니다. [2]파일 다운로드1
5847guest3/7/20233282SQlike Like 구문 - 1시간째 인데 안되네요 [13]
5846Huuu...3/7/20232935웹 다운로드에 대한 고찰 [5]파일 다운로드1
5845guest3/7/20232976C# Split함수의 불친절함 [1]
5844까망이3/7/20233114c# 무료 디컴파일러는 어떤게 좋습니까? [1]
5843guest3/7/20233112판매 후 dll 등 에러 [5]
5842kr13/6/20233118publish 할 때 분석기 관련 dll 제외 [5]
5841guest3/3/20233281프로그램 판매 시 - Upgrade 버전 판매 [2]
5840joe3/2/20233380C# 클래스 라이브러리 수정 -> C++에서 참조시 함수 목록 갱신되지 않음. [4]파일 다운로드1
5839guest3/2/20233956윈도우 서비스 프로그램 - FORM 애플리케이션 감시서비스 [8]
5838랄랄라3/1/20233203event 사용 시 두 표현의 차이점이 있을까요? [1]
5837감사합니...2/28/20233384오라클 DB서버 접속관련 문의 드립니다.(Load Balancing, HA Events) [2]
5836박지범2/27/20233129static instance의 initialize 순서가 보장되나요? [6]
5835주민호2/25/20236113Windows Software Development Kit - 최신버전 1개 남기고 다 삭제하면 안되는지요? [10]파일 다운로드1
5834guest2/24/20233284Python IDE - 비주얼스튜디오 [3]
5833무지남2/23/20232908Async 메서드 그리고 나서 Bool 메서드 [5]
5832김지우2/21/20233212event와 delegate의 차이 , event를 써야하는 이유 [1]
1  2  3  [4]  5  6  7  8  9  10  11  12  13  14  15  ...