Microsoft MVP성태의 닷넷 이야기
reflection, static, override 질문입니다. [링크 복사], [링크+제목 복사],
조회: 4029
글쓴 사람
흰털너부리
홈페이지
첨부 파일
 

암호화 테스트 한 솔루션입니다.

AES256 tripleDes 검증했습니다.

잘작동하는데 왜 작동하는지 궁금해서 질문 드립니다.

여기에 소스 코드 올려놨습니다.

https://github.com/jys923/CryptSample.git

TripleDESSample/MyDES.cs의 CreateWeakEncryptor 질문 입니다.

.net tripleDes가 약한 키는 못쓰게 막혀있습니다.

약한키도 사용가능하게 CreateWeakEncryptor 로 키 체크 부분을 우회한 코드입니다.

데충 리플렉션으로 약한 키 생성 부분을 우회 한건 알것 같습니다.

Q. 그런데 MyDES 가 스태틱인 이유?
Q. 스태틱인데 MyDES.CreateWeakEncryptor 가 아니고
Q. new TripleDESCryptoServiceProvider().CreateWeakEncryptor 이렇게 사용 가능한 이유
Q. using에 참조도 없는데 CreateWeakEncryptor 사용 가능한 이유
Q. public static ICryptoTransform CreateWeakEncryptor(this TripleDESCryptoServiceProvider cryptoProvider, byte[] key, byte[] iv)
this 왜 있는건지?

Q. 해당 코드를 아예 다른 파일로 만들어서 클래스로 분리 해야 작동하는 이유
#region TripleDESCryptoExtensions
        public static ICryptoTransform CreateWeakEncryptor(this TripleDESCryptoServiceProvider cryptoProvider, byte[] key, byte[] iv)
        {
            // reflective way of doing what CreateEncryptor() does, bypassing the check for weak keys
            MethodInfo mi = cryptoProvider.GetType().GetMethod("_NewEncryptor", BindingFlags.NonPublic | BindingFlags.Instance);
            object[] Par = { key, cryptoProvider.Mode, iv, cryptoProvider.FeedbackSize, 0 };
            ICryptoTransform trans = mi.Invoke(cryptoProvider, Par) as ICryptoTransform;
            return trans;
        }

        public static ICryptoTransform CreateWeakEncryptor(this TripleDESCryptoServiceProvider cryptoProvider)
        {
            return CreateWeakEncryptor(cryptoProvider, cryptoProvider.Key, cryptoProvider.IV);
        }

        public static ICryptoTransform CreateWeakDecryptor(this TripleDESCryptoServiceProvider cryptoProvider, byte[] key, byte[] iv)
        {
            // reflective way of doing what CreateDecryptor() does, bypassing the check for weak keys
            MethodInfo mi = cryptoProvider.GetType().GetMethod("_NewEncryptor", BindingFlags.NonPublic | BindingFlags.Instance);
            object[] Par = { key, cryptoProvider.Mode, iv, cryptoProvider.FeedbackSize, 1 };
            ICryptoTransform trans = mi.Invoke(cryptoProvider, Par) as ICryptoTransform;
            return trans;
        }

        public static ICryptoTransform CreateWeakDecryptor(this TripleDESCryptoServiceProvider cryptoProvider)
        {
            return CreateWeakDecryptor(cryptoProvider, cryptoProvider.Key, cryptoProvider.IV);
        }
        #endregion



전부 static에 연관되는 이야기 같은데 잘모르겠네요.

static은 정적 처음 실행 할때 생성, new 말고 클래스 명으로 사용 가능 이런 것 뿐이 모르네요.

긴 질문 읽어주셔서 감사합니다.








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


비밀번호

댓글 작성자
 



2022-10-27 06시58분
질문의 내용은 C# 3.0에 나온 "확장 메서드"를 기본적으로 모르기 때문에 나오는 것입니다. 그걸 공부하신 다음에,

Extension Methods (C# Programming Guide)
; https://learn.microsoft.com/en-us/dotnet/csharp/programming-guide/classes-and-structs/extension-methods

그래도 이해가 안 되는 부분이 있으면 다시 질문해 주세요.

참고로, 제 책을 가지고 있다면 "8.7 확장 메서드" 절을 보시면 됩니다.
정성태

... 31  32  33  34  35  36  37  38  39  40  41  [42]  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
4801spow...2/3/201710528C#의 참조 동작관련하여 아이디어 문의 드립니다 [4]
4800오세운2/1/201714599C# 에서 C++ DLL임포트 질문입니다. [2]
4798guest1/29/201711950picturebox의 image.dispose [1]
4797김철환1/13/201711899책에 관한 질문입니다 [3]
4796Bere...1/13/201711944++ 후위연산자와 = 을 함께 사용할 때 생성되는 IL 코드 관련... [2]
4795김철환1/11/201713137이벤트 부분을 읽고 있는데 이해가 안되서 질문합니다.. [11]
4794김철환1/10/201710429안녕하세요 c# 6.0 책을 구매한 사람인데요 [3]
4793장준영1/7/201712493안녕하세요 c언어 처음 공부해보는 학생입니다 [4]파일 다운로드1
4792김재영1/4/201713419소스코드 공개 전 성태님의 의견을 듣고싶습니다 [3]
4791C#초보12/28/201613355비동기 소켓 close시 ObjectDisposedException 문제점 질문 있습니다.. [1]
4790미나리12/24/201613593파워포인트 쇼 제어 SimpleHttpServer.cs 작동문제 [4]파일 다운로드1
4789김솔지12/21/201612413프린트 시, 프린트하는 파일의 파일명 구하는 부분에 대해서 질문드립니다. [1]
4788짜두12/19/201612141Visual Studio 2015 에서 msbuild 12 사용 [5]
4787guest12/18/201613924VLC라이브러리에 대해 아시나요? [3]파일 다운로드1
4785Hyou...12/16/201614048WPF 개발 시 MVVM 프레임워크 사용 [2]
4784ds12/15/201610688문의 드립니다. [2]
4783후배12/13/201612288MemoryStream에 관한 질문 입니다. [5]
4782김형민12/6/201610604[ C# 6.0 ] 126p 오타인가요? [6]
4781질문자11/29/201610743ms워드 저장 오류 [1]
4780최진11/28/201615186안녕 하세요 빌드 관련해서 질문드립니다 꾸벅 [4]
4779손니11/28/201611536안녕하세요 질문하다 드려도 될까요 [3]
4778김상호11/25/201611054재귀호출->비재귀호출 [2]파일 다운로드1
4777권오영11/12/201613311아래 질문 상세 소스전체입니다.. [3]
4776권오영11/11/201611212제가 이클립스를 공부중인데..이상한것을 찾았습니다.. [2]
4775이성환11/11/201614636안녕하세요. SnapsToDevicePixels 질문입니다. [5]파일 다운로드1
4774popo11/10/201611324.net SSL통신 관련 질문 드립니다. [1]
... 31  32  33  34  35  36  37  38  39  40  41  [42]  43  44  45  ...