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)
518정성태7/26/200730122오류 유형: 43. System.ComponentModel.LicenseException [1]
517정성태7/19/200718356개발 환경 구성: 26. VPC - 일반 사용자 계정으로 구동
516정성태7/19/200721591오류 유형: 42. TFS - Error loading menu: Index was outside the bounds of the array [2]
515정성태7/18/200729483오류 유형: 41. SSL 서버 자격 증명을 만드는 동안 심각한 오류가 발생했습니다.
514정성태7/14/200722039Team Foundation Server: 19. Orcas에서 개선되는 TFS 기능들
513정성태7/4/200733231.NET Framework: 91. Foreground Thread / Background Thread [1]
512정성태6/27/200722816오류 유형: 40. error PRJ0050: Failed to register output.
511정성태6/25/200730980.NET Framework: 90. XmlSerializer 생성자의 실행 속도를 올리는 방법 [2]
510정성태6/25/200746168디버깅 기술: 15. First-Chance Exception
508정성태6/21/200729047Team Foundation Server: 18. Team Build에 사용되는 각종 Property 값 [4]
507정성태6/11/200726635VS.NET IDE: 50. Orcas - UAC 설정 관련
506정성태6/9/200721541오류 유형: 39. VC Package not available or not registered
505정성태6/9/200721206오류 유형: 38. Visual SourceSafe - DB 잠김 오류
504정성태6/9/200726508오류 유형: 37. Visual SourceSafe - Anaylze 도중 비정상 종료
503정성태6/7/200729241VS.NET IDE: 49. Orcas - VC++ 다중 소스 동시 컴파일 옵션: /MP
502정성태6/7/200724028VS.NET IDE: 48. Orcas - VC++ 프로젝트 마이그레이션
500정성태6/4/200732801VS.NET IDE: 47. Orcas - Web Browser Debugger를 이용한 보호 모드의 ActiveX 컨트롤 디버깅
499정성태6/3/200725373VS.NET IDE: 46. Orcas - ComUtil로 인한 증분(/INCREMENTAL) 링크 옵션 사용 제한파일 다운로드1
498정성태5/31/200719857Windows: 26. 스마트 카드 암호 바꾸는 방법.
497정성태5/31/200723299오류 유형: 36. SQL 2005 - DB 속성창 띄울 때 오류
496정성태5/29/200721294VS.NET IDE: 45. VS.NET 2005/Orcas 솔루션 파일과 UAC
495정성태5/28/200723674VS.NET IDE: 44. Orcas와 VS.NET 2005의 혼합 개발 [1]
494정성태5/26/200727993오류 유형: 35. 비스타 탐색기 - 특정 파일을 오른쪽 마우스 클릭했을 때, 비정상 종료되는 문제
493정성태5/26/200727007오류 유형: 34. Windows Server 2008 : CA 인증서 발급 실패
492정성태5/23/200726516.NET Framework: 89. ManagedThreadId - 두 번째 이야기 [5]파일 다운로드1
491정성태5/21/200726637.NET Framework: 88. ManagedThreadId ? [4]
... 166  167  168  169  170  171  172  173  174  175  176  177  178  179  [180]  ...