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

비밀번호

댓글 작성자
 




... 181  182  183  184  185  186  187  188  [189]  190  191  192  193  194  195  ...
NoWriterDateCnt.TitleFile(s)
222정성태4/13/200618643.NET Framework: 65. VS.NET 2005: 파일 기반 웹 프로젝트의 "Virtual Path" 제거
220정성태4/13/200616324.NET Framework: 64. ClickOnce - 배포 시 오류 : "Error: An unexpected error occurred -- The parameter is incorrect."
219정성태4/13/200631179.NET Framework: 63. ClickOnce - 최초 실행 시 보안 경고창 없애는 방법 [1]
216정성태4/13/200618236스크립트: 8. 3월 1일 ActiveX Patch 적용 후, JS 로 수정한 임베딩 컨트롤이 여전히 비활성화 되는 문제 [2]
215정성태4/13/200619556.NET Framework: 62. ASP.NET 웹 컨트롤 렌더링 가로채기
214정성태4/13/200618909.NET Framework: 61. DateTime - DateTime = 사이의 "Month" 수 계산 [2]
213정성태4/13/200621174.NET Framework: 60. localhost 이외의 컴퓨터에서 asmx 테스트 페이지 호출 [1]
218정성태4/13/200619521    답변글 .NET Framework: 60.1. asmx 테스트 페이지를 보여주고 싶지 않을 때
211정성태4/13/200617426VS.NET IDE: 38. VS.NET 2005 - "Export Template" 메뉴
210정성태4/13/200616898.NET Framework: 59. EXE 참조 가능 - VS.NET 2005 [2]
209정성태4/13/200616421스크립트: 7. 4월 12일 ActiveX 패치 문제를 해결할 수 있는 가장 간단한 방법 [6]파일 다운로드1
208정성태10/21/200616155Windows: 1. 성태도 ^^ Vista 설치 해봤습니다.
212정성태10/20/200615672    답변글 Windows: 1.1. Vista 에서 WinFX 런타임 구동
207정성태4/13/200624635VC++: 23. VC++ RGS 파일에 사용자 정의 파라미터 추가
205정성태4/13/200621703VS.NET IDE: 37. devenv.exe를 이용한 Command Line 컴파일 [1]
204정성태5/8/200616924웹: 2. Server Unavailable - Server Application Unavailable
203정성태4/13/200615771웹: 1. IIS 설정 옵션: Verify(Check) that file exists
202정성태4/13/200615480VS.NET IDE: 36. Automatically synchronize with an Internet time server
201정성태4/13/200618504기타: 12. XMLHTTP Failure and SUS Admin
200정성태4/13/200617895.NET Framework: 58. 웹 서비스 메서드 호출 오류 유형 - text/html; charset=xxx, but expected 'text/xml'
199정성태4/13/200619263스크립트: 6. XHTML or HTML 4.01 표준 준수
194정성태4/13/200618569VC++: 22. IDL Library 절
193정성태4/13/200618983.NET Framework: 57. IComponentChangeService 인터페이스
192정성태6/1/200616232VC++: 21. Visual C++ struct와 class의 차이점
189정성태4/13/200623954VC++: 20. ActiveX CAB 파일 오류 유형 - 파일을 대상 디렉터리로 복사할 수 없음. [6]
187정성태11/24/200518250VS.NET IDE: 35. VS.NET 2005 IDE Tip - 2번째 : XML / XSL 지원 강화
... 181  182  183  184  185  186  187  188  [189]  190  191  192  193  194  195  ...