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

비밀번호

댓글 작성자
 




... 166  167  168  169  170  [171]  172  173  174  175  176  177  178  179  180  ...
NoWriterDateCnt.TitleFile(s)
734정성태6/4/200926393.NET Framework: 140. WPF - CellPadding 속성을 구현하는 Grid Layout [2]파일 다운로드1
733정성태5/29/200931751.NET Framework: 139. WPF - "M/d/yyyy h:mm:ss tt" 형식으로만 날짜를 출력하는 문제
732정성태5/27/200926787Team Foundation Server: 32. 팀 빌드 오류 확인 방법
731정성태5/27/200921782Team Foundation Server: 31. 팀 빌드 스케줄 확인 방법
730정성태5/26/200927364VS.NET IDE: 63. Visual Studio 2010 - Parallel Stacks [1]
729정성태5/25/200927047.NET Framework: 138. InternalsVisibleTo와 Public Key 값
728정성태5/23/200937499.NET Framework: 137. C#에서 Union 구조체 다루기파일 다운로드1
727정성태5/22/200922474오류 유형: 82. 메서드가 많은 경우 프록시 클래스 생성 실패
726정성태5/21/200921983VS.NET IDE: 62. Visual Studio 2010 Beta1 버그 피드백 - EnC기능 오류 [1]
725정성태5/21/200925304VS.NET IDE: 61. Visual Studio 2010 베타1과 Visual Studio 2008의 혼합 개발 [2]
724정성태5/19/200939403.NET Framework: 136. 자바와 닷넷의 압축 호환파일 다운로드2
723정성태5/18/200933388.NET Framework: 135. C# - Deflate, GZip, Zip
722정성태5/18/200921943개발 환경 구성: 45. SQL 서버 2008 백업 구성 [2]
721정성태5/14/200927566오류 유형: 81. Package 실행 오류 - Error 15404
720정성태5/13/200924293오류 유형: 80. SQL Server 2008 - Package 실행 오류의 구체적인 원인 확인
719정성태5/12/200925502.NET Framework: 134. WPF - XBAP을 호스팅하고 있는 인터넷 익스플로러 인터페이스 구하기파일 다운로드1
717정성태5/11/200925755개발 환경 구성: 44. VHD 파일 크기 확장하는 방법 - 두 번째 이야기
714정성태5/7/200924301Windows: 45. Windows 7 RC와 함께 공개된 Windows Virtual PC 베타
713정성태4/30/200956037오류 유형: 79. DLL 'xxxxx.dll'을(를) 로드할 수 없습니다. [1]
712정성태4/28/200928688오류 유형: 78. Windows Vista/2008에서의 MSXML4.cab 파일 배포 문제
711정성태4/27/200928263개발 환경 구성: 43. Hyper-V VHD 파일 크기 확장하는 방법
710정성태4/26/200928873.NET Framework: 133. CallbackOnCollectedDelegate was detected [4]파일 다운로드1
709정성태4/24/200925125개발 환경 구성: 42. Windows Vista SP1에서 사용 가능한 Hyper-V 관리 도구
708정성태4/23/200929992.NET Framework: 132. ClickOnce 배포를 명령행 수작업 구성파일 다운로드1
707정성태4/22/200929619개발 환경 구성: 41. Hyper-V에 Linux 설치 - SUSE Linux Enterprise Server 11
706정성태4/21/200925505.NET Framework: 131. ClickOnce - 그룹화시켜 다운로드파일 다운로드1
... 166  167  168  169  170  [171]  172  173  174  175  176  177  178  179  180  ...