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



노트북을 Vista 운영체제로 설치한 이후, 제 홈페이지에 꽤나 문제가 있었습니다. 예전과 다름없이 빌드하고 홈페이지를 업데이트시켰는데, 다음과 같은 오류가 발생하더군요.

[오류 보기]

이벤트 뷰어에서는 이런 오류 정보를 확인할 수 있습니다.

이벤트 형식:	경고
이벤트 원본:	ASP.NET 2.0.50727.0
이벤트 범주:	웹 이벤트 

...[중간 생략]...

이벤트 발생 횟수: 1 
이벤트 정보 코드: 0 
 
...[중간 생략]...
 
예외 정보: 
    예외 형식: HttpException 
    예외 메시지: 파일이나 어셈블리 'TestLib, Version=3.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a' 또는 
    여기에 종속되어 있는 파일이나 어셈블리 중 하나를 로드할 수 없습니다. 
    강력한 이름 시그니처를 확인할 수 없습니다. 어셈블리가 훼손된 경우이거나, 
    서명 연기되었지만 정확한 개인 키로 완전히 서명되지 않은 경우입니다. 
    (예외가 발생한 HRESULT: 0x80131045) 
 

해당 DLL은 비록 서명이 되어 있긴 하지만, GAC에 등록하진 않고 사용하던 어셈블리였습니다. HRESULT 오류 코드값을 확인해 보면, "FUSION_E_SIGNATURE_CHECK_FAILED"라는 것을 알 수 있는데, 일단 이런 오류 메시지가 발생하게 되면 해당 DLL을 직접 GAC 폴더에 끌어다 놓기를 해도 다음과 같은 오류 메시지만을 담은 메시지 창이 뜨면서 등록이 안 됩니다.

어셈블리 캐시 뷰어 - 설치하지 못했습니다.

어셈블리 'TestLib.dll'에 대해 강력한 이름 시그니처를 확인할 수 없습니다. 
어셈블리가 훼손된 경우이거나, 서명 연기되었지만 정확한 개인 키로 완전히 서명되지 않은 경우입니다.

위와 같은 오류가 발생한 이후부터 제가 시도해 본 방법은 Vista 운영체제가 아닌 다른 컴퓨터의 VS.NET 2005에서 동일하게 빌드를 한 다음 배포를 한 경우인데, 이런 때는 정상적으로 동작을 했으며 GAC 수동 등록도 잘 되었습니다. 또한, Vista에서의 VS.NET 2005에서도 MSI 셋업 파일로 해당 DLL을 GAC에 배포하도록 하게 된 경우에는 정상적으로 등록이 되었습니다.

아무래도, 이 문제는 Vista에 설치된 .NET 관련 서명 코드와 이전 운영체제 환경의 서명 확인 과정이 다소 틀린 것에서 발생하는 문제가 아닌가 예상만 해볼 뿐입니다. 참고로, 제가 웹 사이트를 "Longhorn" 서버에 옮긴 이후로는 이러한 서명 확인 오류가 발생하지 않았습니다.

일단, 현재는 이 정도만 트레이스를 해보았지만... 혹시 Vista에서의 개발 환경을 구성하셔서 프로젝트 중인 분들이 이런 오류를 만났는지 궁금하군요. ^^




오류 발생 환경을 정리해 보면 다음과 같습니다.

[오류가 발생한 환경
빌드 환경:
 - Visual Studio.NET 2005 영문 버전
 - Windows Vista 영문 버전
 
ASP.NET 구동 환경:
 - Windows 2003 (.NET 2.0 / .NET 3.0 설치)
 

반면에 다음과 같은 환경에서는 오류가 발생하지 않았습니다.

[정상적인 환경 1]
빌드 환경:
 - Visual Studio.NET 2005 영문 버전에서 빌드 후 MSI 설치 파일로 배포
 - Windows Vista 영문 버전
 
ASP.NET 구동 환경:
 - Windows 2003 (.NET 2.0 / .NET 3.0 설치)
 
[정상적인 환경 2]
빌드 환경:
 - Visual Studio.NET 2005 영문 버전
 - Windows 2003 영문 버전
 
ASP.NET 구동 환경:
 - Windows 2003 (.NET 2.0 / .NET 3.0 설치) 
 
[정상적인 환경 3]
빌드 환경:
 - Visual Studio.NET 2005 영문 버전
 - Windows Vista 영문 버전
 
ASP.NET 구동 환경:
 - Longhorn 빌드 5600
 



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







[최초 등록일: ]
[최종 수정일: 6/20/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)
13410정성태9/11/202316762닷넷: 2141. C# 12 - Interceptor (컴파일 시에 메서드 호출 재작성) [1]
13409정성태9/8/202317140닷넷: 2140. C# - Win32 API를 이용한 모니터 전원 끄기
13408정성태9/5/202315620Windows: 251. 임의로 만든 EXE 파일을 포함한 ZIP 파일의 압축을 해제할 때 Windows Defender에 의해 삭제되는 경우
13407정성태9/4/202315823닷넷: 2139. C# - ParallelEnumerable을 이용한 IEnumerable에 대한 병렬 처리
13406정성태9/4/202315593VS.NET IDE: 186. Visual Studio Community 버전의 라이선스
13405정성태9/3/202317687닷넷: 2138. C# - async 메서드 호출 원칙
13404정성태8/29/202317768오류 유형: 876. Windows - 키보드의 등호(=, Equals sign) 키가 눌리지 않는 경우
13403정성태8/21/202314161오류 유형: 875. The following signatures couldn't be verified because the public key is not available: NO_PUBKEY EB3E94ADBE1229CF
13402정성태8/20/202315630닷넷: 2137. ILSpy의 nuget 라이브러리 버전 - ICSharpCode.Decompiler
13401정성태8/19/202316861닷넷: 2136. .NET 5+ 환경에서 P/Invoke의 성능을 높이기 위한 SuppressGCTransition 특성 [1]
13400정성태8/10/202315646오류 유형: 874. 파이썬 - pymssql을 윈도우 환경에서 설치 불가
13399정성태8/9/202313846닷넷: 2135. C# - 지역 변수로 이해하는 메서드 매개변수의 값/참조 전달
13398정성태8/3/202318841스크립트: 55. 파이썬 - pyodbc를 이용한 SQL Server 연결 사용법
13397정성태7/23/202317562닷넷: 2134. C# - 문자열 연결 시 string.Create를 이용한 GC 할당 최소화
13396정성태7/22/202316968스크립트: 54. 파이썬 pystack 소개 - 메모리 덤프로부터 콜 스택 열거
13395정성태7/20/202315488개발 환경 구성: 685. 로컬에서 개발 중인 ASP.NET Core/5+ 웹 사이트에 대해 localhost 이외의 호스트 이름으로 접근하는 방법
13394정성태7/16/202313625오류 유형: 873. Oracle.ManagedDataAccess.Client - 쿼리 수행 시 System.InvalidOperationException
13393정성태7/16/202314917닷넷: 2133. C# - Oracle 데이터베이스의 Sleep 쿼리 실행하는 방법
13392정성태7/16/202313830오류 유형: 872. Oracle - ORA-01031: insufficient privileges
13391정성태7/14/202314456닷넷: 2132. C# - sealed 클래스의 메서드를 callback 호출했을 때 인라인 처리가 될까요?
13390정성태7/12/202315457스크립트: 53. 파이썬 - localhost 호출 시의 hang 현상
13389정성태7/5/202316050개발 환경 구성: 684. IIS Express로 호스팅하는 웹을 WSL 환경에서 접근하는 방법
13388정성태7/3/202316414오류 유형: 871. 윈도우 탐색기에서 열리지 않는 zip 파일 - The Compressed (zipped) Folder '[...].zip' is invalid. [1]파일 다운로드1
13387정성태6/28/202314084오류 유형: 870. _mysql - Commands out of sync; you can't run this command now
13386정성태6/27/202316601Linux: 61. docker - 원격 제어를 위한 TCP 바인딩 추가
13385정성태6/27/202314939Linux: 60. Linux - 외부에서의 접속을 허용하기 위한 TCP 포트 여는 방법
... 16  17  18  19  20  21  22  23  24  [25]  26  27  28  29  30  ...