Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

manifest - The value "x64" of attribute "processorArchitecture" in element "assemblyIdentity" is invalid.

manifest 파일에 오류가 있으면, 애당초 실행조차 안 되면서 화면에는 다음과 같은 식의 오류가 발생합니다.

The application has failed to start because its side-by-side configuration is incorrect. Please see the application event log or use the command-line sxstrace.exe tool for more detail.


문제의 원인은 다행히 이벤트 로그를 보면 나오는데요, 이번에는 다음과 같은 식의 오류 항목이 있었습니다.

Activation context generation failed for "c:\temp\ConsoleApp1\bin\Debug\ConsoleApp1.exe".Error in manifest or policy file "c:\temp\ConsoleApp1\bin\Debug\ATLProject1.dll.MANIFEST" on line 4. The value "x64" of attribute "processorArchitecture" in element "assemblyIdentity" is invalid.


그러니까, processorArchitecture의 값이 잘못되었다는 건데요.

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0">

  <assemblyIdentity version="1.0.0.0" processorArchitecture="x64"  ...>
  </assemblyIdentity>
  
  ...[생략]...

</assembly>

x86 아니면, x64일 거라 생각해 정한 값인데 공식 문서를 보니,

Application Manifests
; https://learn.microsoft.com/en-us/windows/win32/sbscs/application-manifests

Specifies the processor. The valid values are x86 for 32-bit Windows and ia64 for 64-bit Windows. Optional.


마이크로소프트가 "ia64"로 정해 놓았군요. 이제는 역사의 뒤안길로 사라진 Itanium의 레거시를 저기서 보게 될 줄이야... ^^; 어쨌든 해결 방법은 (AMD64 환경임에도 불구하고) ia64로 하면 정상적으로 실행은 됩니다. 하지만, 이 값의 성격이 "Optional"이니 .NET 응용 프로그램의 자유로운 x86/x64 환경을 고려하면 그냥 삭제하는 것이 권장됩니다.




그런데, 편집하다 보니 다음과 같은 manifest 오류도 발생했습니다.

Activation context generation failed for "c:\temp\ConsoleApp1\bin\Debug\ConsoleApp1.exe".Error in manifest or policy file "c:\temp\ConsoleApp1\bin\Debug\ATLProject1.dll.MANIFEST" on line 17. The value "CB82A462-8F49-4434-987B-CB8FBC8A9115" of attribute "iid" in element "comInterfaceExternalProxyStub" is invalid.


무슨 의미냐면, GUID 문자열 형식에서 "{", "}" 문자가 빠졌다는 것입니다.

<comInterfaceExternalProxyStub name="IATLSimpleObject" 
                                iid="CB82A462-8F49-4434-987B-CB8FBC8A9115" 
                                proxyStubClsid32="{00020424-0000-0000-C000-000000000046}" 
                                baseInterface="{00020400-0000-0000-C000-000000000046}" 
                                tlbid="{0B2AAC68-8E4B-4BAA-85D7-4DF62A224D9F}">
</comInterfaceExternalProxyStub>

따라서 다음과 같이 수정해 주면 해결됩니다.

<comInterfaceExternalProxyStub name="IATLSimpleObject" 
                                iid="{CB82A462-8F49-4434-987B-CB8FBC8A9115}" 
                                proxyStubClsid32="{00020424-0000-0000-C000-000000000046}" 
                                baseInterface="{00020400-0000-0000-C000-000000000046}" 
                                tlbid="{0B2AAC68-8E4B-4BAA-85D7-4DF62A224D9F}">
</comInterfaceExternalProxyStub>




그나저나... 이렇게 자잘하게 오류가 나는 것이 꽤나 귀찮은 면이 있군요. ^^; 그래서 그냥 COM DLL로부터 manifest 파일을 실수 없이 생성할 도구를 만들었고, 그게 지난 글에 소개한 COMRegFreeManifest 프로그램입니다.

Reg-free COM 개체 사용을 위한 manifest 파일 생성 도구 - COMRegFreeManifest
; https://www.sysnet.pe.kr/2/0/12160




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







[최초 등록일: ]
[최종 수정일: 12/1/2023]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 151  152  153  154  155  [156]  157  158  159  160  161  162  163  164  165  ...
NoWriterDateCnt.TitleFile(s)
1186정성태12/1/201134278.NET Framework: 279. WPF - 그리기 성능 및 Blurring 문제파일 다운로드1
1185정성태11/29/201124425.NET Framework: 278. WPF - Content의 Changed 이벤트에 해당하는게 뭔가요?파일 다운로드1
1184정성태11/29/201127668.NET Framework: 277. F#과 WPF가 어울리지 못하는 근본적인 이유 [2]
1183정성태11/26/201122892오류 유형: 140. Visual Studio 2010 - Floating된 에디트 윈도우가 사라지지 않는 경우 [2]
1182정성태11/25/201158901.NET Framework: 276. 중복 없는 숫자를 랜덤으로 배열하는 방법 [5]파일 다운로드1
1181정성태11/24/201129179디버깅 기술: 44. windbg의 mscordacwks DLL 로드 문제
1180정성태11/23/201139038.NET Framework: 275. 레지스트리 등록 및 Interop DLL 없이 COM 개체 사용하는 방법 [2]파일 다운로드1
1179정성태11/22/201129558.NET Framework: 274. ReaderWriterLockSlim은 언제 쓰는 걸까요? [4]파일 다운로드1
1178정성태11/19/201126138.NET Framework: 273. 설치된 .NET 버전에 민감한 코드를 포함하는 경우, 다중으로 어셈블리를 만들어야 할까요?파일 다운로드1
1177정성태11/18/201131436.NET Framework: 272. 소켓 연결 시간 제한 - 두 번째 이야기 [1]파일 다운로드1
1176정성태11/17/201130825.NET Framework: 271. C#에서 확인해 보는 관리 힙의 인스턴스 구조 [3]파일 다운로드1
1175정성태11/16/201128797.NET Framework: 270. .NET 참조 개체 인스턴스의 Object Header를 확인하는 방법 [1]파일 다운로드1
1174정성태11/15/201128151.NET Framework: 269. 일반 참조형의 기본 메모리 소비는 얼마나 될까요? [4]
1173정성태11/14/201124271.NET Framework: 268. .NET Array는 왜 12bytes의 기본 메모리를 점유할까? [1]
1172정성태11/13/201121207.NET Framework: 267. windbg - GC Heap에서 .NET 타입에 대한 배열을 찾는 방법
1171정성태11/12/201137948.NET Framework: 266. StringBuilder에서의 OutOfMemoryException 오류 원인 분석 [4]파일 다운로드1
1170정성태11/10/201127336.NET Framework: 265. Named 동기화 개체 생성 시 System.UnauthorizedAccessException 예외 발생하는 경우
1169정성태11/10/201130829.NET Framework: 264. 다중 LAN 카드 환경에서 Dns.GetHostAddresses(local)가 반환해 주는 IP의 우선순위는 어떻게 될까요? [4]
1168정성태11/6/201126749오류 유형: 139. TlbImp : error TI0000 : A single valid machine type compatible with the input type library must be specified
1167정성태11/5/201138544개발 환경 구성: 133. Registry 등록 과정 없이 COM 개체 사용 - 두 번째 이야기 [5]파일 다운로드4
1166정성태11/5/201124575.NET Framework: 263. byte[] pData = new byte[100000]로 인한 성능 차이? [1]파일 다운로드1
1165정성태11/3/201129637개발 환경 구성: 132. "Visual Studio Command Prompt (2010)" 명령행에서 2.0 버전의 MSBuild를 구동하는 방법 [2]파일 다운로드1
1164정성태11/1/201127736.NET Framework: 262. .NET 스레드 콜 스택 덤프 (4) - .NET 4.0을 지원하지 않는 MSE 응용 프로그램 원인 분석
1163정성태10/31/201127345.NET Framework: 261. .NET 스레드 콜 스택 덤프 (3) - MSE 소스 코드 개선파일 다운로드1
1162정성태10/30/201127412.NET Framework: 260. .NET 스레드 콜 스택 덤프 (2) - Managed Stack Explorer 소스 코드를 이용한 스택 덤프 구하는 방법파일 다운로드1
1161정성태10/29/201124130.NET Framework: 259. Type.GetMethod - System.Reflection.AmbiguousMatchException파일 다운로드1
... 151  152  153  154  155  [156]  157  158  159  160  161  162  163  164  165  ...