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

비밀번호

댓글 작성자
 




... 76  77  78  79  80  81  [82]  83  84  85  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
11978정성태7/6/201922069Windows: 161. 계정 정보가 동일하지 않은 PC 간의 인증을 수행하는 방법 [1]
11977정성태7/6/201925958오류 유형: 554. git push - error: RPC failed; HTTP 413 curl 22 The requested URL returned error: 413 Request Entity Too Large
11976정성태7/4/201921122오류 유형: 553. (잘못 인증 한 후) 원격 git repo 재인증 시 "remote: HTTP Basic: Access denied" 오류 발생
11975정성태7/4/201928832개발 환경 구성: 448. Visual Studio Code에서 콘솔 응용 프로그램 개발 시 "입력"받는 방법
11974정성태7/4/201925618Linux: 22. "Visual Studio Code + Remote Development"로 윈도우 환경에서 리눅스(CentOS 7) C/C++ 개발
11973정성태7/4/201923635Linux: 21. 리눅스에서 공유 라이브러리가 로드되지 않는다면?
11972정성태7/3/201928830.NET Framework: 847. JAVA와 .NET 간의 AES 암호화 연동 [1]파일 다운로드1
11971정성태7/3/201923038개발 환경 구성: 447. Visual Studio Code에서 OpenCvSharp 개발 환경 구성
11970정성태7/2/201923139오류 유형: 552. 웹 브라우저에서 파일 다운로드 후 "Running security scan"이 끝나지 않는 문제
11969정성태7/2/201923660Math: 63. C# - 3층 구조의 신경망파일 다운로드1
11968정성태7/1/201930375오류 유형: 551. Visual Studio Code에서 Remote-SSH 연결 시 "Opening Remote..." 단계에서 진행되지 않는 문제 [1]
11967정성태7/1/201924953개발 환경 구성: 446. Synology NAS를 Windows 10에서 iSCSI로 연결하는 방법
11966정성태6/30/201923438Math: 62. 활성화 함수에 따른 뉴런의 출력을 그리드 맵으로 시각화파일 다운로드1
11965정성태6/30/201923887.NET Framework: 846. C# - 2차원 배열을 1차원 배열로 나열하는 확장 메서드파일 다운로드1
11964정성태6/30/201924275Linux: 20. C# - Linux에서의 Named Pipe를 이용한 통신
11963정성태6/29/201923974Linux: 19. C# - .NET Core Unix Domain Socket 사용 예제
11962정성태6/27/201921544Math: 61. C# - 로지스틱 회귀를 이용한 선형분리 불가능 문제의 분류파일 다운로드1
11961정성태6/27/201922296Graphics: 37. C# - PLplot - 출력 모음(Family File Output)
11960정성태6/27/201923824Graphics: 36. C# - PLplot의 16색 이상을 표현하는 방법과 subpage를 이용한 그리드 맵 표현
11959정성태6/27/201924884Graphics: 35. matplotlib와 PLplot의 한글 처리
11958정성태6/25/201929453Linux: 18. C# - .NET Core Console로 리눅스 daemon 프로그램 만드는 방법 [6]
11957정성태6/24/201925718Windows: 160. WMI 쿼리를 명령행에서 간단하게 수행하는 wmic.exe [2]
11956정성태6/24/201926101Linux: 17. CentOS 7에서 .NET Core Web App 실행 환경 구성 [1]
11955정성태6/20/201923913Math: 60. C# - 로지스틱 회귀를 이용한 분류파일 다운로드1
11954정성태6/20/201921562오류 유형: 550. scp - sudo: no tty present and no askpass program specified
11953정성태6/20/201919168오류 유형: 549. The library 'libhostpolicy.so' required to execute the application was not found in '...'
... 76  77  78  79  80  81  [82]  83  84  85  86  87  88  89  90  ...