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

비밀번호

댓글 작성자
 




... 151  152  153  154  155  156  157  158  159  160  161  162  [163]  164  165  ...
NoWriterDateCnt.TitleFile(s)
969정성태12/31/201040320VC++: 45. Winsock 2 Layered Service Provider - Visual Studio 2010용 프로젝트 [1]파일 다운로드1
968정성태12/30/201026550개발 환경 구성: 94. 개발자가 선택할 수 있는 윈도우에서의 네트워크 프로그래밍 기술 [2]
967정성태12/27/201028339.NET Framework: 197. .NET 코드 - 단일 Process 실행파일 다운로드1
966정성태12/26/201026275.NET Framework: 196. .NET 코드 - 창 흔드는 효과파일 다운로드1
965정성태12/25/201027790개발 환경 구성: 93. MSBuild를 이용한 닷넷 응용프로그램의 다중 어셈블리 출력 빌드파일 다운로드1
964정성태12/21/2010142950개발 환경 구성: 92. 윈도우 서버 환경에서, 최대 생성 가능한 소켓(socket) 연결 수는 얼마일까? [14]
963정성태12/13/201027836개발 환경 구성: 91. MSBuild를 이용한 닷넷 응용프로그램의 플랫폼(x86/x64)별 빌드 [2]파일 다운로드1
962정성태12/10/201022741오류 유형: 110. GAC 등록 - Failure adding assembly to the cache: Invalid file or assembly name.
961정성태12/10/201099741개발 환경 구성: 90. 닷넷에서 접근해보는 PostgreSQL DB [5]
960정성태12/8/201045042.NET Framework: 195. .NET에서 코어(Core) 관련 CPU 정보 알아내는 방법파일 다운로드1
959정성태12/8/201031859.NET Framework: 194. Facebook 연동 - API Error Description: Invalid OAuth 2.0 Access Token
958정성태12/7/201028838개발 환경 구성: 89. 배치(batch) 파일에서 또 다른 배치 파일을 동기 방식으로 실행 및 반환값 얻기 [2]
957정성태12/6/201031577디버깅 기술: 31. Windbg - Visual Studio 디버그 상태에서 종료해 버리는 응용 프로그램 [3]
953정성태11/28/201036818.NET Framework: 193. 페이스북(Facebook) 계정으로 로그인하는 C# 웹 사이트 제작 [5]
952정성태11/25/201025247.NET Framework: 192. GC의 부하는 상대적인 것! [4]
950정성태11/18/201076626.NET Framework: 191. ClickOnce - 관리자 권한 상승하는 방법 [17]파일 다운로드2
954정성태11/29/201048611    답변글 .NET Framework: 191.1. [답변] 클릭원스 - 요청한 작업을 수행하려면 권한 상승이 필요합니다. (Exception from HRESULT: 0x800702E4) [2]
949정성태11/16/201027158오류 유형: 109. System.ServiceModel.Security.SecurityNegotiationException
948정성태11/16/201035941.NET Framework: 190. 트위터 계정으로 로그인하는 C# 웹 사이트 제작 [7]파일 다운로드1
947정성태11/14/201041641.NET Framework: 189. Mono Cecil로 만들어 보는 .NET Decompiler [1]파일 다운로드1
946정성태11/11/201041459.NET Framework: 188. .NET 64비트 응용 프로그램에서 왜 (2GB) OutOfMemoryException 예외가 발생할까? [1]파일 다운로드1
945정성태11/11/201024972VC++: 44. C++/CLI 컴파일 오류 - error C4368: mixed types are not supported
944정성태11/11/201031458VC++: 43. C++/CLI 컴파일 오류 - error C2872: 'IServiceProvider' : ambiguous symbol could be ...
943정성태11/8/201030563디버깅 기술: 30. windbg ".loadby sos" 명령어 [2]
942정성태11/7/201042158.NET Framework: 187. 실행 시에 메서드 가로채기 - CLR Injection: Runtime Method Replacer 개선 [7]파일 다운로드3
941정성태11/6/201025077.NET Framework: 186. windbg로 확인하는 .NET CLR LCG 메서드(DynamicMethod) [1]파일 다운로드1
... 151  152  153  154  155  156  157  158  159  160  161  162  [163]  164  165  ...