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

비밀번호

댓글 작성자
 




... 181  182  183  184  185  186  [187]  188  189  190  191  192  193  194  195  ...
NoWriterDateCnt.TitleFile(s)
285정성태6/20/200622562오류 유형: 9. [TFS] Report 관련 서비스를 조회할 때 rsErrorImpersonatingUser 오류 메시지 발생 [1]
284정성태6/19/200620290VS.NET IDE: 40. FxCop - IDE 에서 제공해 주는 SuppressMessage 코드
283정성태1/19/200721167Team Foundation Server: 8. 소스 세이프에서 TFS SourceControl 로 마이그레이션 [2]
279정성태12/27/200626559개발 환경 구성: 3. VS.NET 원격 디버깅 [1]
280정성태6/12/200626031    답변글 개발 환경 구성: 3.1. VS.NET 2003 원격 디버깅 설정
281정성태8/11/200627507    답변글 개발 환경 구성: 3.2. VS.NET 2005 원격 디버깅 설정
315정성태8/11/200628174        답변글 개발 환경 구성: 3.3. VS.NET 2005 원격 디버깅 설정 - ASP.NET F5 디버깅
278정성태6/11/200624703오류 유형: 8. [Outlook] 0x8004011D 에러 - "Exchange over the Internet" 환경
276정성태6/7/200618221Team Foundation Server: 7. 외부 빌드 머신 구성
287정성태6/24/200615820    답변글 Team Foundation Server: 7.1. 외부 빌드 머신 구성 - 다른 블로그 자료
275정성태6/7/200623701디버깅 기술: 4. VC++ 8.0 원격 디버깅 구성 - Side-by-Side DLL 문제.
269정성태6/6/200620942Team Foundation Server: 6. HTTPS를 통한 Team Server 접근 [1]
270정성태6/5/200617881    답변글 Team Foundation Server: 6.1. HTTPS를 통한 Team Server 접근 [1]
273정성태6/6/200620606    답변글 Team Foundation Server: 6.2. 두번째 방법 - HTTPS 를 통한 Team Server 접근 [1]
267정성태6/4/200619914Team Foundation Server: 5. 인터넷으로 Team Server 접근 [2]
266정성태6/8/200616514오류 유형: 7. [설치] mpoai9.dll 관련 오류
265정성태6/1/200624223디버깅 기술: 3. 원격 컴퓨터 디버깅 - VPC 설정
314정성태8/11/200621286    답변글 디버깅 기술: 3.1. Managed 원격 디버깅과 WinDBG 원격 디버깅
264정성태6/1/200630381오류 유형: 6. [VC++ 컴파일] already defined in ntdll.lib(ntdll.dll)
263정성태6/1/200631389디버깅 기술: 2. 커널 구조체 살펴보기 [5]
262정성태6/1/200623653오류 유형: 5. [설치] WinFX Beta2 - 설치시 문제점 해결
261정성태6/1/200620144웹: 3. IIS 6.0 - AppPool을 활용하여 실 서버(운영 서버)에서 디버깅
258정성태6/1/200628057디버깅 기술: 1. 디버깅 방법 - CLR 프로파일러 [1]파일 다운로드1
274정성태6/7/200620971    답변글 디버깅 기술: 1.1. 디버깅 방법 - CLR 프로파일러 ( on Vista )
254정성태6/1/200617455개발 환경 구성: 2. VPC에 Vista 설치하는 방법 [2]
255정성태6/1/200617129    답변글 개발 환경 구성: 2.1. msconfig 설정과 Windows Activation
... 181  182  183  184  185  186  [187]  188  189  190  191  192  193  194  195  ...