Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

(시리즈 글이 14개 있습니다.)
.NET Framework: 292. RSACryptoServiceProvider의 공개키와 개인키 구분
; https://www.sysnet.pe.kr/2/0/1218

.NET Framework: 327. RSAParameters와 System.Numerics.BigInteger 이야기
; https://www.sysnet.pe.kr/2/0/1295

.NET Framework: 329. C# - Rabin-Miller 소수 생성방법을 이용하여 RSACryptoServiceProvider의 개인키를 직접 채워보자
; https://www.sysnet.pe.kr/2/0/1300

.NET Framework: 356. (공개키를 담은) 자바의 key 파일을 닷넷의 RSACryptoServiceProvider에서 사용하는 방법
; https://www.sysnet.pe.kr/2/0/1401

.NET Framework: 383. RSAParameters의 ToXmlString과 ExportParameters의 결과 비교
; https://www.sysnet.pe.kr/2/0/1491

.NET Framework: 565. C# - Rabin-Miller 소수 생성 방법을 이용하여 RSACryptoServiceProvider의 개인키를 직접 채워보자 - 두 번째 이야기
; https://www.sysnet.pe.kr/2/0/10925

.NET Framework: 566. openssl의 PKCS#1 PEM 개인키 파일을 .NET RSACryptoServiceProvider에서 사용하는 방법
; https://www.sysnet.pe.kr/2/0/10926

.NET Framework: 638. RSAParameters와 RSA
; https://www.sysnet.pe.kr/2/0/11140

.NET Framework: 1037. openssl의 PEM 개인키 파일을 .NET RSACryptoServiceProvider에서 사용하는 방법 (2)
; https://www.sysnet.pe.kr/2/0/12598

.NET Framework: 2093. C# - PKCS#8 PEM 파일을 이용한 RSA 개인키/공개키 설정 방법
; https://www.sysnet.pe.kr/2/0/13245

닷넷: 2297. C# - ssh-keygen으로 생성한 Public Key 파일 해석과 fingerprint 값(md5, sha256) 생성
; https://www.sysnet.pe.kr/2/0/13739

닷넷: 2297. C# - ssh-keygen으로 생성한 ecdsa 유형의 Public Key 파일 해석
; https://www.sysnet.pe.kr/2/0/13742

닷넷: 2300. C# - OpenSSH의 공개키 파일에 대한 "BEGIN OPENSSH PUBLIC KEY" / "END OPENSSH PUBLIC KEY" PEM 포맷
; https://www.sysnet.pe.kr/2/0/13747

닷넷: 2302. C# - ssh-keygen으로 생성한 Private Key와 Public Key 연동
; https://www.sysnet.pe.kr/2/0/13749




RSAParameters의 ToXmlString과 ExportParameters의 결과 비교

아래의 글에 덧글로 질문이 하나 달렸는데요.

RSAParameters와 System.Numerics.BigInteger 이야기 
; http://blog.naver.com/techshare/100159602002

질문의 요지는, 다음과 같이 RSAParameters로부터 서로 다른 방법으로 키를 뽑아냈는데,

using (RSACryptoServiceProvider RSA = new RSACryptoServiceProvider())
{
    RSAParameters rsaParam = RSA.ExportParameters(true);

    byte[] temp1 = rsaParam.Q; // 바이트 배열로 추출한 Q 인자

    String s = RSA.ToXmlString(true); // XML로 추출한 키
    XmlDocument doc = new XmlDocument();
    doc.LoadXml(s);
    XmlNodeList xmllist = doc.SelectNodes("/RSAKeyValue/Q");
    XmlNode node = xmllist[0];
    string ss = node.InnerText; // XML 내용 중 Q 인자의 문자열만 추출
}

temp1 바이트 내용과 ss 문자열의 내용이 어떤 관계인지를 모르겠다는 것입니다.

ss의 내용을 출력 - Console.WriteLine(ss);
uXYhzfSIZumJ5N2H8jx+qGisoSL6KYyCdyGSn7NEg2L5lJ5Aa+x9mUvQq3L2Ns5EvJAOIOGeLtY9Ys+bsmEzbw==

temp1의 내용을 출력 - Console.WriteLine(BitConverter.ToString(temp1));
B9-76-21-CD-F4-88-66-E9-89-E4-DD-87-F2-3C-7E-A8-68-AC-A1-22-FA-29-8C-82-77-21-92-9F-B3-44-83-62-F9-94-9E-40-6B-EC-7D-99-4B-D0-AB-72-F6-36-CE-44-BC-90-0E-20-E1-9E-2E-D6-3D-62-CF-9B-B2-61-33-6F

ss의 내용에 보면 끝에 "=="라는 문자열이 보이는데요. Base64 인코딩되었다는 것을 의미하지요. 그래서 다음과 같이 검증해 볼 수 있습니다.

Console.WriteLine(Convert.ToBase64String(temp1) == ss);

당연히 True가 출력됩니다.

여기까지 읽으면 재미없는 분도 있으실 테니 ^^ 시간되시면 다음의 글들도 읽어보시면 좋겠지요.

RSACryptoServiceProvider의 공개키와 개인키 구분
; https://www.sysnet.pe.kr/2/0/1218

C# - Rabin-Miller 소수 생성방법을 이용하여 RSACryptoServiceProvider의 개인키를 직접 채워보자
; https://www.sysnet.pe.kr/2/0/1300 




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 6/11/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 166  167  168  169  170  171  172  [173]  174  175  176  177  178  179  180  ...
NoWriterDateCnt.TitleFile(s)
783정성태10/7/200932260.NET Framework: 164. WPF - 데이터 바인딩된 트리에서 부모 노드 찾는 방법 [1]파일 다운로드1
782정성태10/6/200934505개발 환경 구성: 51. Windows 7 - 다중 원격 접속(Remote Desktop) 허용
781정성태9/30/200931022.NET Framework: 163. WPF - TreeView 자동 스크롤 기능 해지 [2]파일 다운로드1
780정성태9/28/200934989Windows: 48. Windows 7/2008에서 ping을 위한 echo 요청 열기 [2]
779정성태9/24/200926201.NET Framework: 162. WPF - 중첩된 ScrollViewer의 크기 제어 - 두 번째 이야기파일 다운로드1
778정성태9/23/200928098오류 유형: 87. 시스템 시간 변경 후 Session이 맺어진 WCF 클라이언트의 예외 발생파일 다운로드1
776정성태9/17/200927115개발 환경 구성: 50. Reference assembly
775정성태9/13/200943837VC++: 37. XmlCodeGenerator를 C/C++ 코드 생성에 적용 [2]파일 다운로드1
773정성태9/5/200934674오류 유형 : 85. DEP 비호환 ActiveX 오류
772정성태9/2/200931018.NET Framework: 161. WPF - 윈도우 이벤트 가로채기 [1]파일 다운로드1
771정성태8/28/200924937.NET Framework: 160. WPF - 입력 포커스 외곽선 없애는 방법
770정성태8/26/200927681.NET Framework: 159. WCF - 같은 컴퓨터에서만 WCF 요청을 서비스하도록 설정
769정성태8/25/200930626개발 환경 구성: 49. GAC와 같은 Namespace Extension에 의해서 보여지는 폴더의 원본 확인 방법
768정성태8/24/200930178오류 유형: 85. WCF 연결 오류: MessageSecurityException
767정성태8/23/200938127.NET Framework: 158. 닷넷 프로파일러 - IL 코드 재작성 [14]
766정성태8/23/200939337.NET Framework: 157. C# 4.0 - dynamic 키워드 [4]파일 다운로드1
765정성태8/22/200933057.NET Framework: 156. XamDataGrid의 UnboundField 사용파일 다운로드1
764정성태8/21/200927109Windows: 47. Windows Virtual PC에 설치된 Windows 7 VPC에서 Aero 효과 사용 [3]
763정성태8/20/200930712Windows: 46. Windows 7 - XP 모드 응용 프로그램 바로가기 만드는 방법 [2]
762정성태8/18/200936458개발 환경 구성: 48. 개발자 PC 환경 - 유니코드(Unicode)를 위한 설정 [3]
760정성태8/17/200942702개발 환경 구성: 47. XmlCodeGenerator 1.0.0.4 업데이트 [2]
759정성태8/16/200934676.NET Framework: 155. 닷넷 프로파일러의 또 다른 응용: Visual Studio 2010 Historical Debugging
758정성태8/15/200928164VS.NET IDE: 65. WPF 프로젝트용 Visual Studio 패치들 [2]
757정성태8/12/200927659오류 유형: 84. TFS 작업 항목 보기 오류 - WorkItemTypeDeniedOrNotExistException
756정성태8/9/200926768오류 유형: 83. A revocation check could not be performed for the certificate.
755정성태8/6/200924504.NET Framework: 154. 이벤트 2중 구독
... 166  167  168  169  170  171  172  [173]  174  175  176  177  178  179  180  ...