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

Web Site Model 프로젝트에서 Trace.WriteLine 출력이 dbgview.exe에서 확인이 안 되는 문제


Web Site 모델에 대해서 생소한 분은 우선 다음의 글을 참조하시고,

Web Site Model 
; https://www.sysnet.pe.kr/2/0/312

그래서, 아래의 글에 잠시 소개되는 것처럼 DLL 없이 순수하게 파일만으로 구성한 웹 사이트를 만드는 것도 가능합니다.

IIS Express - localhost 이외의 호스트 이름으로 접근하는 방법
; https://www.sysnet.pe.kr/2/0/1030

어쨌든! 이런 Web Site 모델의 경우 기본적으로 Debug 및 Trace 개체의 WriteLine 출력이 안되는 것을 확인할 수 있습니다.

// default.aspx 웹 페이지를 방문해도 dbgview.exe에서는 아무런 출력결과도 확인이 안됨
public partial class _Default : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        System.Diagnostics.Debug.WriteLine("Debug.WriteLine");
        System.Diagnostics.Trace.WriteLine("Trace.WriteLine");
    }
}

실제로, 위의 웹 페이지를 방문할 때 default.aspx/cs 파일을 빌드하기 위해 다음과 같이 빌드 프로세스가 실행됩니다.

"C:\Windows\Microsoft.NET\Framework\v4.0.30319\csc.exe" /noconfig /fullpaths @"C:\...[AppDataLocal]...\Temp\Temporary ASP.NET Files\website1\bd62c795\3e1d734d\gfrfbecn.cmdline"


(csc.exe 실행 후 곧바로 지워버리기 때문에) "gfrfbecn.cmdline" 파일의 내용을 확인할 수는 없었지만, 생각해 보면 Debug/Trace 출력이 없음을 이해할 수 있습니다. 빌드는 해야 하는데, 적절한 컴파일 옵션이 주어지지 않았기 때문에 컴파일러 입장에서는 '기본값'으로 .aspx/.cs 파일을 빌드할 수밖에 없었을 것입니다.

그렇다면, 원하는 데로 옵션을 지정해 주어야 할 텐데요. 우선, 상대적으로 간단한 Debug.WriteLine부터 가능하도록 해보겠는데, 이를 위해 다음과 같이 컴파일러에게 디버그 모드로 .aspx/.cs 파일을 빌드하도록 지정해 줄 수 있습니다.

<configuration>
  <system.web>
    <compilation debug="true" targetFramework="4.0" />
    ...[생략]...
  </system.web>
</configuration>

위의 변경 이후에는, default.aspx 웹 페이지를 방문하면 "Debug.WriteLine" 출력을 dbgview.exe에서 확인할 수 있습니다.




Trace.WriteLine 출력은 어떨까요? 아쉽게도 Debug 출력처럼 간단하게 속성 값만 변경해 주는 수준에서는 해결이 안되고 다음과 같이 복잡한 컴파일러 옵션을 재정의 해주어야 합니다.

  <system.codedom>
    <compilers>
      <compiler language="c#;cs;csharp"
              extension=".cs"
              compilerOptions="/d:TRACE"
              type="Microsoft.CSharp.CSharpCodeProvider, System, Version=2.0.3500.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" 
              warningLevel="1" />
    </compilers>
  </system.codedom>
  

아하... 그렇군요. 일반 DLL/EXE 빌드에서와 마찬가지로 TRACE 매크로 상수 값을 compilerOptions 속성에 지정하는 것으로 해결할 수 있습니다. 이제는 정상적으로 Debug/Trace.WriteLine 구문이 동작하는 것을 확인할 수 있습니다.

그런데, 위의 구문을 가만히 보면 compilerOptions가 단지 /d:TRACE 정의만을 위한 것은 아니라는 것을 눈치채셨을 것입니다. 따라서 <compilation debug="true" targetFramework="4.0" />의 debug 속성값을 false로 바꾼 상태에서도 결국 다음과 같이 compilerOptions을 주게 되면 동일하게 Debug/Trace를 활성화시킬 수 있다는 것이고!

<compiler language="c#;cs;csharp"
        extension=".cs"
        compilerOptions="/d:TRACE;DEBUG"

첨부된 파일은 위의 코드를 포함한 예제 프로젝트인데, '웹 사이트 유형'이기 때문에 별도의 csproj 프로젝트 파일이 없습니다.




마치기 전에, 한 가지 언급하자면 compiler 노드의 설정에서 type 값이 중요합니다.

<system.codedom>
    <compilers>
        <compiler language="c#;cs;csharp" extension=".cs" compilerOptions="/d:TRACE"
             type="Microsoft.CSharp.CSharpCodeProvider, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
    </compilers>
</system.codedom>

웹상의 자료를 검색하면, 위의 type 값이 생략된 것을 종종 볼 수 있는데요. 그런 경우 compilerOptions 설정이 전혀 효력이 없었습니다. 또한, system.web/compilation[@targetFramework] 값이 "4.0"이어도 compiler[@type] 내의 Version 속성은 "2.0.0.0"도 허용이 됩니다. (아마도 .NET 2.0도 함께 설치되어 있어야 할 것입니다.)




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







[최초 등록일: ]
[최종 수정일: 7/18/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)
649정성태1/18/200929196Windows: 38. Q1U UMPC에 Windows 7 베타 설치하기
648정성태1/18/200927932Windows: 37. Windows PE를 USB 메모리에 적용
647정성태1/18/200938075Windows: 36. Windows PE ISO 이미지 만들기 [1]
646정성태1/18/200931016디버깅 기술: 23. COMPLUS_ZapDisable - JIT 최적화 코드 생성 제어 [1]
645정성태1/11/200929822Windows: 35. 서명되지 않은 드라이버 로딩 방법
644정성태1/11/200920910Windows: 34. VPC 설치 후기 [2]
643정성태1/10/200926269Windows: 33. Windows 7 베타와 VMA 충돌 [1]
642정성태1/8/200924976개발 환경 구성: 34. Sysinternals의 모든 툴을 한번에 업데이트 하는 방법 [1]
641정성태1/7/200922114기타: 27. D820 - A09 바이오스 업데이트 프로그램 패치 [2]
640정성태1/4/200923832Team Foundation Server: 29. ClickOnce 응용 프로그램 배포를 Team Build에 추가.
639정성태1/4/200921779Team Foundation Server: 28. PFX 코드 서명을 포함한 프로젝트의 팀 빌드 실패 - MSB4018
638정성태1/3/200924894.NET Framework: 119. WPF - 의존 속성 정의에서 XamlParseException 발생하는 예 [2]
637정성태1/1/200927078기타: 26. 2008년 인기 순위 정리
636정성태12/31/200822215.NET Framework: 118. 2진 검색을 이용한 리스트 정렬 삽입파일 다운로드1
635정성태12/29/200824824오류 유형: 66. 파일 암호화 오류 - Recovery policy configured for this system contains invalid recovery certificate
634정성태12/29/200839136기타: 25. 가상 키보드 관련 정리 [4]
633정성태12/20/200824676기타: 24. RMClock for x64 [2]
632정성태12/19/200833323기타: 23. D820 - 배터리 없이 바이오스 업데이트 방법 [2]파일 다운로드1
631정성태12/10/200841959VC++: 36. Detours 라이브러리를 이용한 Win32 API - Sleep 호출 가로채기 [3]
630정성태12/9/200822732.NET Framework: 117. WPF - TreeView에서 항목이 펼쳐질 때 Cursors.Wait 사용파일 다운로드1
629정성태12/7/200831937.NET Framework: 116. 소켓 연결 시간 제한
628정성태12/6/200820814.NET Framework: 115. Marshal 타입 관련 2가지 자원 해제 메서드파일 다운로드1
627정성태12/6/200823235VS.NET IDE: 58. VS.NET IDE 팁 - 커서 위치 이동 [1]
626정성태12/6/200823470오류 유형: 65. TF53018: The application tier XXXXXXX is attempting to connect to a data tier with an incompatible version
625정성태12/6/200823612오류 유형: 64. TFS 2008 SP1 설치 - MsiApplyMultiplePatches returned 0x643
624정성태12/5/200824591.NET Framework: 114. WPF 이벤트에 속한 핸들러 확인 [2]파일 다운로드1
... 166  167  168  169  170  171  172  173  [174]  175  176  177  178  179  180  ...