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

비밀번호

댓글 작성자
 




... 106  107  108  109  [110]  111  112  113  114  115  116  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11174정성태4/3/201719392VC++: 116. Visual Studio 단위 테스트 - Failed to set up the execution context to run the test
11173정성태4/3/201722966VC++: 115. Visual Studio에서 C++ DLL을 대상으로 단위 테스트할 때 비정상 종료한다면?파일 다운로드1
11172정성태4/3/201722098.NET Framework: 651. C# - 특정 EXE 프로세스를 종료시킨 EXE를 찾아내는 방법파일 다운로드1
11171정성태3/31/201718800VS.NET IDE: 114. Visual Studio 디버깅 경고 창 - You are debugging a Release build of ...
11170정성태3/31/201720684.NET Framework: 650. C# - CachedAnonymousMethodDelegate 유형의 코드 생성
11169정성태3/30/201720548VC++: 114. C++ vtable의 가상 함수 호출 가로채기파일 다운로드1
11168정성태3/29/201723884VC++: 113. C++ 클래스 상속 관계의 vtable 생성 과정
11167정성태3/28/201724180VC++: 112. C++의 가상 함수 테이블 (vtable)은 언제 생성될까요? [2]
11166정성태3/28/201718410오류 유형: 382. System.Data.SqlClient.SqlException - Arithmetic overflow error converting IDENTITY to data type int.
11165정성태3/27/201721701오류 유형: 381. Visual C++에서 min, max 함수를 사용한 경우 C2589, C2059 컴파일 오류 발생
11164정성태3/27/201730018VC++: 111. C++ 클래스의 상속에 따른 메모리 구조 [2]파일 다운로드1
11163정성태3/25/201719803VC++: 110. CreateThread Win32 API에 C++ 클래스의 멤버 함수를 전달하는 방법파일 다운로드1
11162정성태3/24/201724033오류 유형: 380. Visual Studio 빌드 실패 - The OutputPath property is not set for project
11161정성태3/24/201716764오류 유형: 379. ICOMAdminCatalog.GetCollection 호출 시 0x80070422 예외 발생
11160정성태3/23/201721683.NET Framework: 649. ASP.NET - Server cannot append header after HTTP headers have been sent. (HTTP 헤더를 보낸 후에는 서버에서 헤더를 추가할 수 없습니다.)파일 다운로드1
11159정성태3/23/201718970Windows: 136. Memory-mapped File은 Private Bytes 크기에 포함될까요?파일 다운로드1
11158정성태3/22/201718619디버깅 기술: 85. Windbg - SOS 디버깅 사례 System.NullReferenceException 예외 추적
11157정성태3/22/201721861.NET Framework: 648. Dictionary<TKey, TValue>를 deep copy하는 방법파일 다운로드1
11156정성태3/21/201722486.NET Framework: 647. 닷넷(C#) 코드로 인증서 요청 코드 만드는 방법파일 다운로드1
11155정성태3/21/201722693.NET Framework: 646. SslStream의 CipherAlgorithm 선택이 가능할까요?파일 다운로드1
11154정성태3/5/201729695VC++: 109. DLL에서 STL 객체를 인자/반환값으로 갖는 함수를 제공할 때, 그 함수를 외부에서 사용하는 경우 비정상 종료한다면? [2]파일 다운로드1
11153정성태3/5/201729064VC++: 108. DLL에 정의된 C++ template 클래스의 복사 생성자 문제파일 다운로드1
11152정성태3/4/201722738VC++: 107. VirtualAlloc, HeapAlloc, GlobalAlloc, LocalAlloc, malloc, new의 차이점파일 다운로드1
11151정성태3/3/201723328VC++: 106. DLL 개발자가 주의해야 할 Secure CRT 함수 사용 [1]파일 다운로드1
11150정성태2/21/201719271.NET Framework: 645. Visual Studio Fakes 기능에서 Shim... 클래스가 생성되지 않는 경우 [5]
11149정성태2/21/201722944오류 유형: 378. A 64-bit test cannot run in a 32-bit process. Specify platform as X64 to force test run in X64 mode on X64 machine.
... 106  107  108  109  [110]  111  112  113  114  115  116  117  118  119  120  ...