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

비밀번호

댓글 작성자
 




... 16  17  18  19  20  21  22  23  24  25  26  27  [28]  29  30  ...
NoWriterDateCnt.TitleFile(s)
12923정성태1/15/20227600개발 환경 구성: 626. ffmpeg.exe를 사용해 비디오 파일을 MPEG1 포맷으로 변경하는 방법
12922정성태1/14/20226647개발 환경 구성: 625. AKS - Azure Kubernetes Service 생성 및 SLO/SLA 변경 방법
12921정성태1/14/20225632개발 환경 구성: 624. Docker Desktop에서 별도 서버에 설치한 docker registry에 이미지 올리는 방법
12920정성태1/14/20226404오류 유형: 786. Camtasia - An error occurred with the camera: Failed to Add Video Sampler.
12919정성태1/13/20226232Windows: 199. Host Network Service (HNS)에 의해서 점유되는 포트
12918정성태1/13/20226450Linux: 47. WSL - shell script에서 설정한 환경 변수가 스크립트 실행 후 반영되지 않는 문제
12917정성태1/12/20225682오류 유형: 785. C# - The type or namespace name '...' could not be found (are you missing a using directive or an assembly reference?)
12916정성태1/12/20225411오류 유형: 784. TFS - One or more source control bindings for this solution are not valid and are listed below.
12915정성태1/11/20225695오류 유형: 783. Visual Studio - We didn't find any interpreters
12914정성태1/11/20227617VS.NET IDE: 172. 비주얼 스튜디오 2022의 파이선 개발 환경 지원
12913정성태1/11/20228138.NET Framework: 1133. C# - byte * (바이트 포인터)를 FileStream으로 쓰는 방법 [1]
12912정성태1/11/20228765개발 환경 구성: 623. ffmpeg.exe를 사용해 비디오 파일의 이미지를 PGM(Portable Gray Map) 파일 포맷으로 출력하는 방법 [1]
12911정성태1/11/20226101VS.NET IDE: 171. 비주얼 스튜디오 - 더 이상 만들 수 없는 "ASP.NET Core 3.1 Web Application (.NET Framework)" 프로젝트
12910정성태1/10/20226566제니퍼 .NET: 30. 제니퍼 닷넷 적용 사례 (8) - CPU high와 DB 쿼리 성능에 문제가 함께 있는 사이트
12909정성태1/10/20227965오류 유형: 782. Visual Studio 2022 설치 시 "Couldn't install Microsoft.VisualCpp.Redist.14.Latest"
12908정성태1/10/20225818.NET Framework: 1132. C# - ref/out 매개변수의 IL 코드 처리
12907정성태1/9/20226256오류 유형: 781. (youtube-dl.exe) 실행 시 "This app can't run on your PC" / "Access is denied." 오류 발생
12906정성태1/9/20226871.NET Framework: 1131. C# - 네임스페이스까지 동일한 타입을 2개의 DLL에서 제공하는 경우 충돌을 우회하는 방법 [1]파일 다운로드1
12905정성태1/8/20226535오류 유형: 780. Could not load file or assembly 'Microsoft.VisualStudio.TextTemplating.VSHost.15.0, Version=16.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a' or one of its dependencies.
12904정성태1/8/20228553개발 환경 구성: 623. Visual Studio 2022 빌드 환경을 위한 github Actions 설정 [1]
12903정성태1/7/20227150.NET Framework: 1130. C# - ELEMENT_TYPE_INTERNAL 유형의 사용 예
12902정성태1/7/20227190오류 유형: 779. SQL 서버 로그인 에러 - provider: Shared Memory Provider, error: 0 - No process is on the other end of the pipe.
12901정성태1/5/20227283오류 유형: 778. C# - .NET 5+에서 warning CA1416: This call site is reachable on all platforms. '...' is only supported on: 'windows' 경고 발생
12900정성태1/5/20228936개발 환경 구성: 622. vcpkg로 ffmpeg를 빌드하는 경우 생성될 구성 요소 제어하는 방법
12899정성태1/3/20228419개발 환경 구성: 621. windbg에서 python 스크립트 실행하는 방법 - pykd (2)
12898정성태1/2/20228974.NET Framework: 1129. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 비디오 인코딩 예제(encode_video.c) [1]파일 다운로드1
... 16  17  18  19  20  21  22  23  24  25  26  27  [28]  29  30  ...