Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

Method not found: 'Void System.Reflection.Emit.DynamicMethod..ctor(System.String, System.Type, System.Type[])'.


A, B, C, D 컴퓨터에서 정상적으로 운영되는 ASP.NET 모듈이 새롭게 설치한 E 컴퓨터에서 예외가 발생했습니다. 구체적인 예외 오류는 다음과 같습니다.


Server Error in '/' Application.
--------------------------------------------------------------------------------

Method not found: 'Void System.Reflection.Emit.DynamicMethod..ctor(System.String, System.Type, System.Type[])'.
Description: An unhandled exception occurred during the execution of the current web request. Please review the stack trace for more information about the error and where it originated in the code.

Exception Details: System.MissingMethodException: Method not found: 'Void System.Reflection.Emit.DynamicMethod..ctor(System.String, System.Type, System.Type[])'.

Source Error:

An unhandled exception was generated during the execution of the current web request. Information regarding the origin and location of the exception can be identified using the exception stack trace below.

Stack Trace:
[MissingMethodException: Method not found: 'Void System.Reflection.Emit.DynamicMethod..ctor(System.String, System.Type, System.Type[])'.]
TestModule.MyMethod() +0
TestModule.TestMethod() +119
TestModule..cctor() +215
[TypeInitializationException: The type initializer for 'Jennifer40.Profiler.Interception' threw an exception.]
TestModule.Init(Object thisObject) +0



재미있는 것은 "E" 컴퓨터에 .NET 3.5를 설치하면 정상적으로 운영이 되었습니다. 오호라... 그렇다면 뭔가 변화가 있다는 것일 텐데, .NET Reflector를 통해서 A 컴퓨터와 E 컴퓨터의 DynamicMethod 타입을 비교해 보았습니다.

======= A 컴퓨터: .NET 3.5 =======
public DynamicMethod(string name, Type returnType, Type[] parameterTypes);
public DynamicMethod(string name, Type returnType, Type[] parameterTypes, bool restrictedSkipVisibility);
[MethodImpl(MethodImplOptions.NoInlining)]
public DynamicMethod(string name, Type returnType, Type[] parameterTypes, Module m);
[MethodImpl(MethodImplOptions.NoInlining)]
public DynamicMethod(string name, Type returnType, Type[] parameterTypes, Type owner);
[MethodImpl(MethodImplOptions.NoInlining)]
public DynamicMethod(string name, Type returnType, Type[] parameterTypes, Module m, bool skipVisibility);
[MethodImpl(MethodImplOptions.NoInlining)]
public DynamicMethod(string name, Type returnType, Type[] parameterTypes, Type owner, bool skipVisibility);
[MethodImpl(MethodImplOptions.NoInlining)]
public DynamicMethod(string name, MethodAttributes attributes, CallingConventions callingConvention, Type returnType, Type[] parameterTypes, Module m, bool skipVisibility);
[MethodImpl(MethodImplOptions.NoInlining)]
public DynamicMethod(string name, MethodAttributes attributes, CallingConventions callingConvention, Type returnType, Type[] parameterTypes, Type owner, bool skipVisibility);

======= E 컴퓨터: .NET 2.0 =======
public DynamicMethod(string name, Type returnType, Type[] parameterTypes, Module m);
public DynamicMethod(string name, Type returnType, Type[] parameterTypes, Type owner);
public DynamicMethod(string name, Type returnType, Type[] parameterTypes, Module m, bool skipVisibility);
public DynamicMethod(string name, Type returnType, Type[] parameterTypes, Type owner, bool skipVisibility);
public DynamicMethod(string name, MethodAttributes attributes, CallingConventions callingConvention, Type returnType, Type[] parameterTypes, Module m, bool skipVisibility);
public DynamicMethod(string name, MethodAttributes attributes, CallingConventions callingConvention, Type returnType, Type[] parameterTypes, Type owner, bool skipVisibility);

그렇군요. .NET 2.0에는 3개 인자를 받는 "public DynamicMethod(string name, Type returnType, Type[] parameterTypes);" 메서드가 없었기 때문에 이런 예외가 발생하게 된 것입니다.

그러하니, 혹시나 업데이트를 받지 않는 PC에서도 정상적으로 사용할 수 있도록 4개의 인자를 갖는 DynamicMethod 생성자를 사용하도록 변경하였습니다.

문제 해결 끝!




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/12/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)
11718정성태10/4/201820373개발 환경 구성: 404. (opkg가 설치된) Synology NAS(DS216+II)에 cmake 설치
11717정성태10/3/201822779사물인터넷: 48. 넷두이노의 C# 네트워크 프로그램 [1]
11716정성태10/3/201823552사물인터넷: 47. Raspberry PI Zero (W)에 FTDI 장치 연결 후 C/C++로 DTR 제어파일 다운로드1
11715정성태10/3/201821935사물인터넷: 46. Raspberry PI Zero (W)에 docker 설치
11714정성태10/2/201821679사물인터넷: 45. Raspberry PI에 ping을 hostname으로 하는 방법
11713정성태10/2/201823218개발 환경 구성: 403. Synology NAS(DS216+II)에 docker 설치 후 .NET Core 2.1 응용 프로그램 실행하는 방법
11712정성태10/2/201828616.NET Framework: 795. C# - 폰트 목록을 한글이 아닌 영문으로 구하는 방법 [3]
11711정성태10/2/201823913오류 유형: 490. 윈도우 라이선스 키 입력 오류 0xc004f050, 0xc004e028
11710정성태10/2/201823058.NET Framework: 794. C# - 같은 모양, 다른 값의 한글 자음을 비교하는 호환 분해 [5]
11709정성태9/30/201821706개발 환경 구성: 402. .NET Core 콘솔 응용 프로그램을 docker로 실행/디버깅하는 방법 [1]
11708정성태9/30/201824202개발 환경 구성: 401. .NET Core 콘솔 응용 프로그램을 배포(publish) 시 docker image 자동 생성 [2]파일 다운로드1
11707정성태9/30/201825435오류 유형: 489. ASP.NET Core를 docker에서 실행 시 "Failed with a critical error." 오류 발생 [1]
11706정성태9/29/201821093개발 환경 구성: 400. Synology NAS(DS216+II)에서 실행한 gcc의 Segmentation fault [2]
11705정성태9/29/201821821개발 환경 구성: 399. Synology NAS(DS216+II)에 gcc 컴파일러 설치
11704정성태9/29/201826326기타: 73. Synology NAS 신호음(beep) 끄기 [1]파일 다운로드1
11703정성태9/27/201820412개발 환경 구성: 398. Blazor 환경 구성 후 빌드 속도가 너무 느리다면? [2]
11702정성태9/26/201817939사물인터넷: 44. 넷두이노(Netduino)의 네트워크 설정 방법
11701정성태9/26/201823741개발 환경 구성: 397. 공유기를 일반 허브로 활용하는 방법파일 다운로드1
11700정성태9/21/201822244Graphics: 25. Unity - shader의 직교 투영(Orthographic projection) 행렬(UNITY_MATRIX_P)을 수작업으로 구성
11699정성태9/21/201820730오류 유형: 488. Add-AzureAccount 실행 시 "No subscriptions are associated with the logged in account in Azure Service Management (RDFE)." 오류
11698정성태9/21/201822056오류 유형: 487. 윈도우 성능 데이터를 원격 SQL에 저장하는 경우 "Call to SQLAllocConnect failed with %1." 오류 발생
11697정성태9/20/201820056Graphics: 24. Unity - unity_CameraWorldClipPlanes 내장 변수 의미
11696정성태9/19/201821716.NET Framework: 793. C# - REST API를 이용해 NuGet 저장소 제어파일 다운로드1
11695정성태9/19/201826954Graphics: 23. Unity - shader의 원근 투영(Perspective projection) 행렬(UNITY_MATRIX_P)을 수작업으로 구성
11694정성태9/17/201821058오류 유형: 486. nuget push 호출 시 405 Method Not Allowed 오류 발생
11693정성태9/16/201823517VS.NET IDE: 128. Unity - shader 코드 디버깅 방법
... 76  77  78  79  80  81  82  83  84  85  86  87  88  89  [90]  ...