Microsoft MVP성태의 닷넷 이야기
RSA 문의드립니다. [링크 복사], [링크+제목 복사]
조회: 5723
글쓴 사람
팡팡이
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

안녕하세요.
서버에서 개인키랑, 암호메세지를 받아서 복호화를 하려고합니다.

알고리즘은 2048 RSA/NONE/OAEPWITHSHA256ANDMGF1PADDING 사용하는데요.
data wrong에러가 나네요
온라인 RSA테스트에 돌려보면 잘 나오는 것으로 보아서 데이터 문제는 아닌 것 같아요.
BouncyCastle 라이브러리 사용하고 있어요.
BouncyCastle코드보니 지원하는 것 같은데 지원하는 것 맞을까요? ㅠㅠ
c#에서 복호화 가능한 알고리즘인가요? 알고리즘 지원하는 라이브러리가 있을까요?
.net Framework 4.8 사용하고 있습니다.

var c = CipherUtilities.GetCipher("RSA/NONE/OAEPWITHSHA256ANDMGF1PADDING");
            c.Init(false, key);
            byte[] outBytes = c.DoFinal(value);


[연관 글]






[최초 등록일: ]
[최종 수정일: 3/3/2022]


비밀번호

댓글 작성자
 



2022-03-03 07시21분
당연히 BouncyCastle 라이브러리는 RSA 암/복호화를 지원합니다. 도움이 될지 모르겠지만, 아래의 글을 참고하세요.

C# - BouncyCastle을 사용한 암호화/복호화 예제
; https://www.sysnet.pe.kr/2/0/12992
정성태
2022-03-04 12시34분
[팡팡이] 감사합니다. 덕분에 해결 되었어요.
온라인 rsa 테스트페이지에 돌려보며 테스트 해보았는데
RSA/NONE/OAEPWITHSHA256ANDMGF1PADDING 이
var decrypter = new OaepEncoding(new RsaBlindedEngine(), new Sha256Digest(), new Sha1Digest(), null); 로 돌려야 하네요?!!!
[guest]
2022-03-04 09시20분
아래의 글을 읽어보면,

what is deference between "RSA/ECB/OAEPWITHSHA256ANDMGF1PADDING" and "RSA/ECB/OAEPWITHSHA-256ANDMGF1PADDING"
; https://stackoverflow.com/questions/28190858/what-is-deference-between-rsa-ecb-oaepwithsha256andmgf1padding-and-rsa-ecb-oa

자바의 경우 provider에 따라 유사한 이름으로 정의돼 있습니다. "...SHA256..."으로 된 것은 BouncyCastle 측에서 제공하는 것이고, "...SHA-256..."으로 된 것은 Sun JCE에서 제공한다고 합니다. 다른 덧글에서는 그 점을 제외하고는 구현이 같다고 하는데, 마지막 덧글을 단 "tawek"에 의하면, SunJCE의 경우 SHA-1 for MGF1, SHA-256 for label hash인 반면, BouncyCastle에서 구현한 것은 MGF-1의 경우에도 SHA-256을 썼다고 합니다. 실제로 .NET의 경우 CipherUtilities.cs 소스 코드를 봐도 SHA-256으로 모두 OaepEncoding을 초기화하고 있습니다.

그러니까, 아마도 팡팡이 님이 테스트한 온라인 RSA 사이트의 경우 Sun JCE에서 제공하는 "...SHA-256..." 구성을 사용한 것으로 보입니다.
정성태

1  2  3  4  5  6  [7]  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5777감사합니...12/29/20223490UI Thread에 Invoke 처리관련 궁금합니다. [3]
5776pdf맨12/28/20223303C# MouseUp Event + pdf [10]
5775민성12/28/20223076안녕하세요 Class 관련해서 예외처리를 하나로 받아낼수 있는 방법 [1]
5774중급12/27/20223850중급개발자란 어느 수준인지요? [4]
5773김영식12/26/20223420c# 압축파일 읽어 올 때 BinaryRead 한글 처리 문제 [1]
5772눈송이12/26/20223524Excel VSTO 는 왜 Net Core, Net 5, 6 버전을 사용하지 않나요? [2]
5771김훈12/26/20223632c# .net client application 망분리(내부망,외부망) 환경에서 의문의 외부사이트 호출 대기 [2]
5770lsh12/26/20223227클라우디움안에 있는 파일을 File.Copy 하고싶은데 코드로는 접근을 못하나요? [1]
5769울타리12/20/20223293Active Directory 2012R2 2016 또는 2019 마이그렝션 문의 드립니다. [1]
5768c++12/14/20224046Thread를 사용한 C++ DLL에 관련된 질문입니다. [6]파일 다운로드2
5767민성12/9/20223392안녕하세요 ashx로 화일을 저장하고 화일명을 리턴하는데요 [1]
5766김명훈12/9/20223543웹브라우저에서 묻지 않고 바로 다운로드 [2]
5765hong12/1/20223769Winform(.Net6) 클라이언트에서 SignalR Core 웹서버에 접속시 인증서 문제 [3]파일 다운로드1
5764요한11/30/20224001c++ 동일한 객체인지 비교 방법문의 [2]
5763고필석11/30/20223495시작하자마자 비정상 종료하는 프로세스에 대한 문제 해결 조언 요청 드립니다. [3]
5762흰털너부리11/30/20223487wpf mvvm ui update 로딩중 표시 [1]
5761민성11/29/20223386죄송하지만 한가지만 더 여쭈어 보겠습니다 [1]
5760민성11/29/20223319안녕하세요 [2]
5759문정환11/28/20223651c# socket 통신할때 빅엔디언으로 바꿔줘야 하나요? [1]
5758라떼11/28/20224835Linux 에서 winform UI 어플리케이션 실행하기 [3]
5757흰털너부리11/25/20223806asp.net core EF AddDbContext,AddDbContextFactory 차이점 알려주세요 [1]
5756흰털너부리11/25/20223378asp.net core web api에서 json 특정 property 무시하는 방법 문의 드립니다. System.Text.Json 사용중입니다. [1]
5755문정환11/24/20223716싱글스레드 프로그램도 컨텍스트 스위칭이 생길 수 있나요? [4]
5754초급11/24/20223570c# 소켓통신 [1]
5753흰털너부리11/24/20223378List와 ObservableCollection을 비교 해서 다른 값 추출 FirstOrDefault 객체 비교 [4]파일 다운로드1
5752푸헐11/15/20223517app.config 에 connectionStrings를 aspnet_regiis로 enctyption [4]
1  2  3  4  5  6  [7]  8  9  10  11  12  13  14  15  ...