Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

UWP(유니버설 윈도우 플랫폼) 앱에서 global::System.Diagnostics.Debugger.Break 예외 발생 시 대응 방법

경력자들에게는 당연한 것이, 처음 개발하는 분들에게는 완전 새로운 문제일 수 있음을 다음의 질문을 통해서 느끼게 되었습니다. ^^

유니버셜앱 예외 발생: 'System.UnauthorizedAccessException' 해결방법
; https://social.msdn.microsoft.com/Forums/ko-KR/8b403c9c-0023-4c38-a695-829eb22309aa/-systemunauthorizedaccessexception-?forum=visualcsharpko

유니버셜 앱으로 서버를 생성 하였는데요. 여기서 request로 들어간 정보를 어떻게 화면에 출력 해야 할지 모르겠습니다. 
; https://social.msdn.microsoft.com/Forums/ko-KR/2f41a641-1af0-4b64-b844-05f049fb4f81/-request-?forum=visualcsharpko

현재 UWP 앱을 개발하면서 예외가 발생하면 보통 다음과 같이 App.g.i.cs 파일의 Debugger.Break를 가리키게 됩니다.

first_change_in_uwp_1.png

App.UnhandledException 이벤트가 걸린 것인데, 원인은 간단합니다. 프로그램 실행 시 어디선가 예외가 발생했고 그곳의 코드는 개발자에 의해 try/catch가 씌워지지 않았기 때문에 원래는 프로그램 종료가 되어야 하지만 현재 Debugger가 붙어 있는 상태이므로 (global::System.Diagnostics.Debugger.IsAttached) 친절한 비주얼 스튜디오는 예외가 발생했음을 개발자에게 알려주었던 것입니다.

문제는? 도대체 어떤 문제로 인해 들어왔는지 알 수가 없다는 것이죠. ^^

걱정하지 마십시오. 금방 찾아낼 수 있습니다. 위와 같이 디버거가 멈췄을 때 "Output" 창을 보면 구체적으로 어떤 예외로 인해 프로그램이 종료할 뻔 했는지를 알려주는 것을 볼 수 있습니다.

first_change_in_uwp_2.png

위의 화면에서는 System.UnauthorizedAccessException 예외인데요. 이제 "Debug" / "Windows" / "Exception Settings" (단축키: Ctrl+Alt+E) 메뉴를 선택하고 "Search" 패널에 System.UnauthorizedAccessException 문자열을 입력한 후 나타나는 하단의 예외 항목을 체크해주시면 됩니다.

first_change_in_uwp_3.png

이렇게 설정하고 다시 실행하여 예외를 재현하면 다음과 같은 식으로 문제가 발생했던 바로 그 라인에서 디버거가 멈추게 됩니다.

first_change_in_uwp_4.png

에러 메시지에 나오듯이,

Exception thrown: 'System.UnauthorizedAccessException' in App1.exe

WinRT information: At least one of either InternetClientServer or PrivateNetworkClientServer capabilities is required to listen for or receive traffic

Additional information: Access is denied.



At least one of either InternetClientServer or PrivateNetworkClientServer capabilities is required to listen for or receive traffic

If there is a handler for this exception, the program may be safely continued.

권한 설정이 부족하다는 것을 알 수 있고 이에 대처해 문제를 해결해 주시면 됩니다.




아니... 그럴 거면 미리 그 설정을 비주얼 스튜디오에서 기본값으로 했으면 더 좋았지 않았겠습니까? 라고 묻는 분들도 계실 텐데요. 이게 참 그렇습니다. 왜냐하면 의도적으로 발생하는 예외도 있고 그것을 개발자가 try/catch로 잡는 경우도 있는데 그 때마다 저렇게 실행이 멈추는 것이 좋지는 않기 때문에 기본값이 그렇게 안되어 있는 것입니다.

보다 자세한 내용은 다음의 글을 참고하시면 됩니다. ^^

First-Chance Exception
; https://www.sysnet.pe.kr/2/0/510




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 12/10/2015]

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)
1024정성태4/22/201129242오류 유형: 118. Windows 2008 서버에서 Event Viewer / PowerShell 실행 시 비정상 종료되는 문제 [1]
1023정성태4/20/201130137.NET Framework: 210. Windbg 환경에서 확인해 본 .NET 메서드 JIT 컴파일 전과 후 [1]
1022정성태4/19/201125680디버깅 기술: 38. .NET Disassembly 창에서의 F11(Step-into) 키 동작파일 다운로드1
1021정성태4/18/201128017디버깅 기술: 37. .NET 4.0 응용 프로그램의 Main 함수에 BreakPoint 걸기
1020정성태4/18/201128627오류 유형: 117. Failed to find runtime DLL (mscorwks.dll), 0x80004005
1019정성태4/17/201129253디버깅 기술: 36. Visual Studio의 .NET Disassembly 창의 call 호출에 사용되는 주소의 의미는? [1]파일 다운로드1
1018정성태4/16/201132911오류 유형: 116. 윈도우 업데이트 오류 - 0x8020000E
1017정성태4/14/201127724개발 환경 구성: 115. MSBuild - x86/x64, .NET 2/4, debug/release 빌드에 대한 배치 처리파일 다운로드1
1016정성태4/13/201143750개발 환경 구성: 114. Windows Thin PC 설치 [2]
1015정성태4/9/201129112.NET Framework: 209. AutoReset, ManualReset, Monitor.Wait의 차이파일 다운로드1
1014정성태4/7/2011106550오류 유형: 115. ORA-12516: TNS:listener could not find available handler with matching protocol stack [2]
1013정성태4/7/201124370Team Foundation Server: 45. SharePoint 2010 + TFS 2010 환경에서 ProcessGuidance.html 파일 다운로드 문제
1012정성태4/6/201133133.NET Framework: 208. WCF - 접속된 클라이언트의 IP 주소 알아내는 방법 [1]
1011정성태3/31/201135463오류 유형: 114. 인증서 갱신 오류 - The request contains no certificate template information.
1010정성태3/30/201126197개발 환경 구성: 113. 응용 프로그램 디자인 스케치 도구 - SketchFlow [4]
1009정성태3/29/201138579개발 환경 구성: 112. Visual Studio 2010 - .NET Framework 소스 코드 디버깅 [4]
1008정성태3/27/201130935.NET Framework: 207. C# - Right operand가 음수인 Shift 연산 결과 [2]
1007정성태3/16/201131799개발 환경 구성: 111. Excel - XML 파일 연동 [5]파일 다운로드1
1006정성태3/15/201125541.NET Framework: 206. XML/XSD - 외래키처럼 참조 제한 거는 방법파일 다운로드1
1005정성태3/11/201135349개발 환경 구성: 110. 엑셀 매크로 함수 관련 오류 [2]
1004정성태3/3/201124606개발 환경 구성: 109. SharePoint Health Analyzer 디스크 부족 경고 제어
1003정성태3/3/201125631오류 유형: 113. SQL Server - DB Attach 시 Parameter name: nColIndex 오류 발생
1002정성태3/2/201123929Team Foundation Server: 44. TFS 설치 후, Team Portal의 Dashboard를 빠르게 확인하는 방법
1001정성태3/2/201128031Team Foundation Server: 43. TFS 2010 + SharePoint 2010 설치
1000정성태3/1/201132997오류 유형: 112. Remote FX RDP 연결 시 오류 유형 2가지 [5]
999정성태2/28/201146561개발 환경 구성: 108. RemoteFX - Windows 7 가상 머신에서 DirectX 9c 환경을 제공 [5]
... 151  152  153  154  155  156  157  158  159  160  [161]  162  163  164  165  ...