Microsoft MVP성태의 닷넷 이야기
오류 유형: 340. HTTP Error 500.23 - Internal Server Error [링크 복사], [링크+제목 복사],
조회: 21134
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
[captcha.zip]    

(시리즈 글이 15개 있습니다.)
오류 유형: 2. [COM+] CreateObject 와 HTTP 500 - Internal server error
; https://www.sysnet.pe.kr/2/0/242

오류 유형: 111. IIS - 500.19 오류 (0x8007000d)
; https://www.sysnet.pe.kr/2/0/976

오류 유형: 201. ASP.NET 웹 사이트를 IIS 7 이상의 환경에서 호스팅할 때 500 오류 발생
; https://www.sysnet.pe.kr/2/0/1563

오류 유형: 219. IIS 500 Internal Server Error - Skydrive에 공유된 경우
; https://www.sysnet.pe.kr/2/0/1612

오류 유형: 232. IIS 500 Internal Server Error - NTFS 암호화된 폴더에 웹 애플리케이션이 위치한 경우
; https://www.sysnet.pe.kr/2/0/1722

오류 유형: 340. HTTP Error 500.23 - Internal Server Error
; https://www.sysnet.pe.kr/2/0/10997

오류 유형: 360. IIS - 500.19 오류 (0x80070021)
; https://www.sysnet.pe.kr/2/0/11061

개발 환경 구성: 307. ASP.NET Core Web Application을 IIS에서 호스팅하는 방법
; https://www.sysnet.pe.kr/2/0/11120

오류 유형: 580. HTTP Error 500.0/500.33 - ANCM In-Process Handler Load Failure
; https://www.sysnet.pe.kr/2/0/12064

오류 유형: 631. .NET Core 웹 응용 프로그램 오류 - HTTP Error 500.35 - ANCM Multiple In-Process Applications in same Process
; https://www.sysnet.pe.kr/2/0/12268

오류 유형: 662. ASP.NET Core와 500.19, 500.21 오류 (0x8007000d)
; https://www.sysnet.pe.kr/2/0/12356

개발 환경 구성: 635. 비주얼 스튜디오에서 실행하던 ASP.NET Core (.NET Framework) 응용 프로그램을 명령행에서 실행하는 방법 (2)
; https://www.sysnet.pe.kr/2/0/12955

.NET Framework: 1164. HTTP Error 500.31 - ANCM Failed to Find Native Dependencies
; https://www.sysnet.pe.kr/2/0/12982

오류 유형: 884. HTTP 500.0 - 명령행에서 실행한 ASP.NET Core 응용 프로그램을 실행하는 방법
; https://www.sysnet.pe.kr/2/0/13488

오류 유형: 899. HTTP Error 500.32 - ANCM Failed to Load dll
; https://www.sysnet.pe.kr/2/0/13579




HTTP Error 500.23 - Internal Server Error

.NET에서 사용할 수 있는 Captcha 라이브러리로 다음의 소스 코드를 다운로드 받아 실행해 보았습니다.

ASP.NET Captcha
; https://captcha.codeplex.com/
; https://www.codeproject.com/Articles/8751/A-CAPTCHA-Server-Control-for-ASP-NET

그런데, 해당 프로젝트의 기본 실행 설정으로 되어 있는 IIS Express는 다음과 같은 오류 메시지를 담은 결과만 낼 뿐 제대로 실행되지 않았습니다.

HTTP Error 500.23 - Internal Server Error

An ASP.NET setting has been detected that does not apply in Integrated managed pipeline mode.

Detailed Error Information:

Module
   ConfigurationValidationModule 

Notification
   BeginRequest 

Handler
   PageHandlerFactory-Integrated-4.0 

Error Code
   0x80070032 

늘 말하지만... 개인적으로 500 에러는 정말 싫어하는 것 중의 하나입니다. ^^;

검색해 보면 다음의 글이 나오는데,

HTTP Error 500.23 - How do i solve this?  
; http://forums.iis.net/t/1161020.aspx?HTTP+Error+500+23+How+do+i+solve+this+

해결책은 web.config에서 "Integrated" 모드를 끄라는 것입니다.

<system.webServer>

    <validation validateIntegratedModeConfiguration="false" />

</system.webServer> 

그렇게 해결하는 것도 가능하지만 최신 환경을 거슬러서 이전 모드로 IIS를 구동하도록 돌리는 것은 향후의 마이그레이션을 위해 썩 좋은 방법은 아닙니다.

그러고 보니, validateIntegratedModeConfiguration 설정으로 integrated 모드를 끄는 것에 대해 전에도 한번 설명한 적이 있습니다.

ASP.NET 웹 사이트를 IIS 7 이상의 환경에서 호스팅할 때 500 오류 발생
; https://www.sysnet.pe.kr/2/0/1563

위의 경우는 system.web/httpModules에 등록된 DomainServiceModule 때문에 발생한 것이었는데요. 이번 Captcha 라이브러리도 500 에러가 발생한 이유는 비슷합니다. 즉 system.web/httpHandlers가 등록된 것이 그 원인입니다.

다행히 Captcha 라이브러리는 integrated 또는 classic 모드에 상관없이 잘 동작하기 때문에 validateIntegratedModeConfiguration 설정을 이용할 필요없이 그냥 system.webServer 노드로 위치를 옮겨 주기만 하면 됩니다.

=== before ===

<system.web>
    <httpHandlers>
        <add verb="GET" path="CaptchaImage.aspx" type="WebControlCaptcha.CaptchaImageHandler, WebControlCaptcha"/>
    </httpHandlers>
</system.web>

=== after ===

<system.webServer>
    <handlers>
        <add name="captcha" verb="GET" path="CaptchaImage.aspx" type="WebControlCaptcha.CaptchaImageHandler, WebControlCaptcha"/>
    </handlers>
</system.webServer>

이렇게 변경하고 다시 실행하면 정상적으로 Captcha 라이브러리가 동작하는 것을 확인할 수 있습니다.

captcha_500_1.png

(첨부 파일은 web.config만 변경된 captcha 라이브러리 소스입니다.)




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







[최초 등록일: ]
[최종 수정일: 5/21/2021]

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

비밀번호

댓글 작성자
 




... 166  [167]  168  169  170  171  172  173  174  175  176  177  178  179  180  ...
NoWriterDateCnt.TitleFile(s)
862정성태5/3/201020734제니퍼 .NET: 3. 제2회 닷넷 개발자 컨퍼런스에서 뵙겠습니다. ^^
861정성태5/1/201021344.NET Framework: 177. .NET 2.0 Profiler에 .NET 4.0 지원 추가
860정성태4/30/201026421오류 유형: 95. .NET 4.0 설치 오류 - 0x800c0005 [1]
858정성태4/29/201030327제니퍼 .NET: 2. JENNIFER .NET을 이용한 .NET 웹 사이트 모니터링 (2) - 설치 [3]
857정성태4/27/201028467제니퍼 .NET: 1. JENNIFER .NET을 이용한 .NET 웹 사이트 모니터링 (1) - 임시 라이선스 요청 및 다운로드
855정성태4/24/201025431.NET Framework: 176. DataContext가 thread-safe한 것인가?
854정성태4/22/201022264오류 유형: 94. 팀 프로젝트 생성 오류 - TF218017, TF250044
853정성태4/22/201022891오류 유형: 93. TFS 2010 오류: rsProcessingAborted, rsErrorExecutingCommand
852정성태4/21/201024143Team Foundation Server: 33. 단일 서버에 Team Foundation Server 2010 설치하는 방법
851정성태4/14/201034602오류 유형: 92. Task Scheduler 오류: 2147942667 (0x8007010B)
850정성태4/7/201023075.NET Framework: 175. WCF - webHttpBinding + PUT 메서드 구현파일 다운로드1
848정성태3/30/201036741개발 환경 구성: 73. 한 대의 PC에서 여러 개의 키입력 매크로 프로그램이 가능할까? [5]파일 다운로드5
846정성태3/29/201034641VC++: 39. C++에서 싱글톤 구현하기 [8]파일 다운로드1
844정성태3/19/201022094개발 환경 구성: 72. Adobe Creative Suite 3 Master Collection - 하드 디스크로부터 설치하는 방법
843정성태3/19/201031143Windows: 50. Windows Server 2008 R2 시스템에 Windows 7 멀티 부팅하는 방법
842정성태3/17/201026747Windows: 49. VHD 파일 지원
841정성태3/16/201027373.NET Framework: 174. 작업자 프로세스(w3wp.exe)가 재시작되는 시점을 알 수 있는 방법 [1]
840정성태3/4/201020727개발 환경 구성: 71. w3wp.exe에 환경 변수 전달하는 방법 [1]
836정성태2/13/201024188VS.NET IDE: 67. Visual Studio 2010: 베타 2에서 RC 마이그레이션
835정성태1/26/201025422.NET Framework: 173. WCF - webHttpBinding + IIS 6.0 윈도우 인증 구현 예제 [3]파일 다운로드1
834정성태1/25/201025949.NET Framework: 172. WCF - webHttpBinding 윈도우 인증 구현 예제 [3]파일 다운로드1
833정성태1/25/201025294.NET Framework: 171. WCF - webHttpBinding 구현 예제 [1]파일 다운로드1
832정성태1/25/201029129.NET Framework: 170. PerformanceCounter의 RawValue/NextValue()에서 멈춤 현상
831정성태1/14/201018959개발 환경 구성: 70. WSS - check out 메뉴에서 오류나는 문제
830정성태1/10/201023479개발 환경 구성: 69. Windows Internal Database
829정성태1/7/201022861개발 환경 구성: 68. ODP.NET + OraMTS 사용
... 166  [167]  168  169  170  171  172  173  174  175  176  177  178  179  180  ...