Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

(시리즈 글이 3개 있습니다.)
.NET Framework: 407. 닷넷 사용자 정의 예외 클래스의 최소 구현 코드
; https://www.sysnet.pe.kr/2/0/1580

.NET Framework: 455. 닷넷 사용자 정의 예외 클래스의 최소 구현 코드 - 두 번째 이야기
; https://www.sysnet.pe.kr/2/0/1735

.NET Framework: 527. 닷넷 사용자 정의 예외 클래스의 최소 구현 코드 - 세 번째 이야기
; https://www.sysnet.pe.kr/2/0/10842




닷넷 사용자 정의 예외 클래스의 최소 구현 코드 - 세 번째 이야기

닷넷 4.0에서 바뀐 보안 정책으로 인해 예외 클래스의 최소 구현 코드에 변화가 있습니다.

닷넷 사용자 정의 예외 클래스의 최소 구현 코드
; https://www.sysnet.pe.kr/2/0/1580

닷넷 사용자 정의 예외 클래스의 최소 구현 코드 - 두 번째 이야기
; https://www.sysnet.pe.kr/2/0/1735

가령, 닷넷 4.0 어셈블리에 APTCA를 부여한 경우,

[assembly: AllowPartiallyTrustedCallers]

.NET CLR4 보안 모델 - 3. CLR4 보안 모델에서의 APTCA 역할
; https://www.sysnet.pe.kr/2/0/1682

사용자 정의 예외 타입을 이렇게 구현하면,

using System;
using System.Runtime.Serialization;

namespace TestApp
{
    [Serializable]
    public class MyException : System.Exception, ISerializable
    {
        public MyException()
        {
        }

        public MyException(string message) : base(message)
        {
        }

        public MyException(string message, Exception innerException)
            : base(message, innerException)
        {
        }

        protected MyException(SerializationInfo info, StreamingContext context)
            : base(info, context)
        {
        }

        public override void GetObjectData(SerializationInfo info, StreamingContext context)
        {
            base.GetObjectData(info, context);
        }
    }
}

다음과 같은 예외가 발생합니다.

System.TypeLoadException occurred
  HResult=-2146233054
  Message=Inheritance security rules violated while overriding member: 'TestApp.MyException.GetObjectData(System.Runtime.Serialization.SerializationInfo, System.Runtime.Serialization.StreamingContext)'. Security accessibility of the overriding method must match the security accessibility of the method being overriden.
  Source=TestApp
  TypeName=TestApp.MyException.GetObjectData(System.Runtime.Serialization.SerializationInfo, System.Runtime.Serialization.StreamingContext)
  StackTrace:
       at TestApp.MyMethod()
  InnerException: 

이 예외가 다소 황당한데요. System.TypeLoadException이기 때문에 디버깅 도중 F9(Step-Into) 기능으로도 문제의 코드까지 진입을 하지 못합니다. 따라서 위의 오류 메시지를 이해하지 못하면 정확히 왜 이런 문제가 발생하는지 파악조차 못할 수가 있는데요.

문제의 원인은, 닷넷 4.0의 보안 모델에 따라 상속받은 메서드에 지정된 "security accessibility" 특성이 반드시 부모 클래스의 가상 메서드에 지정된 것과 일치해야 한다는 점입니다. 확인을 위해 System.Exception 예외를 .NET Reflector로 확인해 보면 GetObjectData에 SecurityCritical 특성이 부여된 것을 볼 수 있습니다.

namespace System
{
    public class Exception : ISerializable, _Exception
    {
        // ...[생략]...
        [SecurityCritical]
        public virtual void GetObjectData(SerializationInfo info, StreamingContext context)
        // ...[생략]...
    }
}

따라서, 닷넷 4.0에서의 예외 클래스는 APTCA를 고려해 다음과 같이 예외 클래스를 정의해야 합니다.

using System;
using System.Runtime.Serialization;

namespace TestApp
{
    [Serializable]
    public class MyException : System.Exception, ISerializable
    {
        public MyException()
        {
        }

        public MyException(string message) : base(message)
        {
        }

        public MyException(string message, Exception innerException)
            : base(message, innerException)
        {
        }

        protected MyException(SerializationInfo info, StreamingContext context)
            : base(info, context)
        {
        }

        [SecurityCritical]
        public override void GetObjectData(SerializationInfo info, StreamingContext context)
        {
            base.GetObjectData(info, context);
        }
    }
}





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







[최초 등록일: ]
[최종 수정일: 2/1/2020]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 16  17  18  19  20  21  22  23  24  25  26  [27]  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13262정성태2/15/202313507디버깅 기술: 191. dnSpy를 이용한 (소스 코드가 없는) 닷넷 응용 프로그램 디버깅 방법 [1]
13261정성태2/15/202312993Windows: 224. Visual Studio - 영문 폰트가 Fullwidth Latin Character로 바뀌는 문제
13260정성태2/14/202312229오류 유형: 847. ilasm.exe 컴파일 오류 - error : syntax error at token '-' in ... -inf
13259정성태2/14/202312175.NET Framework: 2095. C# - .NET5부터 도입된 CollectionsMarshal
13258정성태2/13/202312971오류 유형: 846. .NET Framework 4.8 Developer Pack 설치 실패 - 0x81f40001
13257정성태2/13/202312381.NET Framework: 2094. C# - Job에 Process 포함하는 방법 [1]파일 다운로드1
13256정성태2/10/202312503개발 환경 구성: 665. WSL 2의 네트워크 통신 방법 - 두 번째 이야기
13255정성태2/10/202312731오류 유형: 845. gihub - windows2022 이미지에서 .NET Framework 4.5.2 미만의 프로젝트에 대한 빌드 오류
13254정성태2/10/202312597Windows: 223. (WMI 쿼리를 위한) PowerShell 문자열 escape 처리
13253정성태2/9/202313731Windows: 222. C# - 다른 윈도우 프로그램이 실행되었음을 인식하는 방법파일 다운로드1
13252정성태2/9/202311618오류 유형: 844. ssh로 명령어 수행 시 멈춤 현상
13251정성태2/8/202312202스크립트: 44. 파이썬의 3가지 스레드 ID
13250정성태2/8/202313799오류 유형: 843. System.InvalidOperationException - Unable to configure HTTPS endpoint
13249정성태2/7/202314422오류 유형: 842. 리눅스 - You must wait longer to change your password
13248정성태2/7/202311076오류 유형: 841. 리눅스 - [사용자 계정] is not in the sudoers file. This incident will be reported.
13247정성태2/7/202312635VS.NET IDE: 180. Visual Studio - 닷넷 소스 코드 디버깅 중 "Decompile source code"가 동작하는 않는 문제
13246정성태2/6/202312457개발 환경 구성: 664. Hyper-V에 설치한 리눅스 VM의 VHD 크기 늘리는 방법 - 두 번째 이야기
13245정성태2/6/202312996.NET Framework: 2093. C# - PKCS#8 PEM 파일을 이용한 RSA 개인키/공개키 설정 방법파일 다운로드1
13244정성태2/5/202312112VS.NET IDE: 179. Visual Studio - External Tools에 Shell 내장 명령어 등록
13243정성태2/5/202313270디버깅 기술: 190. windbg - Win32 API 호출 시점에 BP 거는 방법 [1]
13242정성태2/4/202312082디버깅 기술: 189. ASP.NET Web Application (.NET Framework) 프로젝트의 숨겨진 예외 - System.UnauthorizedAccessException
13241정성태2/3/202310677디버깅 기술: 188. ASP.NET Web Application (.NET Framework) 프로젝트의 숨겨진 예외 - System.IO.FileNotFoundException
13240정성태2/1/202311364디버깅 기술: 187. ASP.NET Web Application (.NET Framework) 프로젝트의 숨겨진 예외 - System.Web.HttpException
13239정성태2/1/202310720디버깅 기술: 186. C# - CacheDependency의 숨겨진 예외 - System.Web.HttpException
13238정성태1/31/202315036.NET Framework: 2092. IIS 웹 사이트를 TLS 1.2 또는 TLS 1.3 프로토콜로만 운영하는 방법
13237정성태1/30/202314318.NET Framework: 2091. C# - 웹 사이트가 어떤 버전의 TLS/SSL을 지원하는지 확인하는 방법
... 16  17  18  19  20  21  22  23  24  25  26  [27]  28  29  30  ...