Microsoft MVP성태의 닷넷 이야기
openssl genrsa 2048시 키 생성이 다르게 됩니다. [링크 복사], [링크+제목 복사],
조회: 13780
글쓴 사람
김재영 (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)
5766김명훈12/9/202212891웹브라우저에서 묻지 않고 바로 다운로드 [2]
5765hong12/1/202213248Winform(.Net6) 클라이언트에서 SignalR Core 웹서버에 접속시 인증서 문제 [3]파일 다운로드1
5764요한11/30/202213365c++ 동일한 객체인지 비교 방법문의 [2]
5763고필석11/30/202212676시작하자마자 비정상 종료하는 프로세스에 대한 문제 해결 조언 요청 드립니다. [3]
5762흰털너부리11/30/202212649wpf mvvm ui update 로딩중 표시 [1]
5761민성11/29/202212618죄송하지만 한가지만 더 여쭈어 보겠습니다 [1]
5760민성11/29/202213162안녕하세요 [2]
5759문정환11/28/202213124c# socket 통신할때 빅엔디언으로 바꿔줘야 하나요? [1]
5758라떼11/28/202216286Linux 에서 winform UI 어플리케이션 실행하기 [3]
5757흰털너부리11/25/202214694asp.net core EF AddDbContext,AddDbContextFactory 차이점 알려주세요 [1]
5756흰털너부리11/25/202214758asp.net core web api에서 json 특정 property 무시하는 방법 문의 드립니다. System.Text.Json 사용중입니다. [1]
5755문정환11/24/202215171싱글스레드 프로그램도 컨텍스트 스위칭이 생길 수 있나요? [4]
5754초급11/24/202215110c# 소켓통신 [1]
5753흰털너부리11/24/202213882List와 ObservableCollection을 비교 해서 다른 값 추출 FirstOrDefault 객체 비교 [4]파일 다운로드1
5752푸헐11/15/202213002app.config 에 connectionStrings를 aspnet_regiis로 enctyption [4]
5751차가워11/8/202215654vs2022 preview net7 AOT 콘솔 실행 성능 [7]
5749차가워11/4/202213505전처리 지시문 #if DEBUG 배포시 실행 여부 [1]
5748김기헌11/3/202215188안녕하세요 선생님 싱글톤 패턴을 꼭 이렇게 사용해야 하나요? [6]
5747김기헌11/2/202213725안녕하세요 선생님 네트워크 관련 용어 중 IP 주소가 왜 논리적 주소라고 표현되는 건가요? [2]
5746물냉면이...11/2/202213820서로 다른 클래스에 있는 동일 함수의 일괄 호출 방법에 대해 궁금합니다. [3]
5745흰털너부리11/1/202213448.net core web api 사용 제한에 관한 질문 입니다. [2]
5744차가워10/31/202215929윈폼 Console.WriteLine(); 연산 문의 [1]
5743흰털너부리10/27/202213963reflection, static, override 질문입니다. [1]
5742차가워10/27/202212637하나의 socket에 여러 스레드가 접근 하는 경우 [1]
5741조호상10/27/202213198OpenCVSharp4 구현 가능 문의 [1]
5740혜성10/26/202215640Visual Studio 2022 C# 콘솔 프로그램 기본 코드 변경된 이유는 무엇인가요? [2]
1  2  3  4  5  6  7  8  [9]  10  11  12  13  14  15  ...