Microsoft MVP성태의 닷넷 이야기
.NET Framework: 535. aspnet.config 파일의 설정을 읽는 방법 [링크 복사], [링크+제목 복사],
조회: 14083
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

aspnet.config 파일의 설정을 읽는 방법

aspnet.config 파일의 기본 설정 파일 내용은 다음과 같이 <runtime />, <startup /> 설정만 갖는 것이 일반적입니다.

<?xml version="1.0" encoding="UTF-8" ?>
<configuration>
    <runtime>
        <legacyUnhandledExceptionPolicy enabled="false" />
        <legacyImpersonationPolicy enabled="true"/>
        <alwaysFlowImpersonationPolicy enabled="false"/>
        <SymbolReadingPolicy enabled="1" />
        <shadowCopyVerifyByTimestamp enabled="true"/>
    </runtime>
    <startup useLegacyV2RuntimeActivationPolicy="true" />
</configuration>

그런데 이 값들을 읽어내기 위해 일반적인 web.config 파일을 다루는 방법은 애석하게도 aspnet.config에는 통하지 않습니다. 가령, web.config은 machine.config으로부터 상속되어 내려오는 설정을 다음의 방법으로 읽는 것이 가능하지만,

How to: Access ASP.NET Configuration Settings Programmatically
; https://docs.microsoft.com/en-us/previous-versions/4c2kcht0(v=vs.140)

특이하게도 runtime 섹션에 대해서는 아래의 글에 설명된 것처럼,

ConfigurationManager - reading the “runtime” section
; https://toresenneseth.wordpress.com/2009/04/23/configurationmanager-reading-the-runtime-section/

GetSection 메서드를 이용하면 IgnoreSection 타입의 인스턴스가 반환됩니다.

System.Configuration.Configuration rootWebConfig1 =
            System.Web.Configuration.WebConfigurationManager.OpenWebConfiguration(null);

object objSection = rootWebConfig1.GetSection("runtime");
// objSection은 System.Configuration.IgnoreSection 타입의 인스턴스

그래서 아무런 값도 알아낼 수 없습니다. 설령 읽어냈다 해도 그것이 machine.config/web.config 내의 설정일 듯 싶고 aspnet.config의 내용이라는 보장이 없습니다.

어쩔 수 없군요. ^^; 이럴 땐 XmlDocument 타입을 이용해 직접 다음과 같이 읽어오는 것이 현재로써는 최선인 듯 합니다.

string path = System.Runtime.InteropServices.RuntimeEnvironment.GetRuntimeDirectory();
string aspnetPath = System.IO.Path.Combine(path, "aspnet.config");

XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load(aspnetPath);
bool canAbortThread = false;

XmlNode policyNode = xmlDoc.SelectSingleNode("/configuration/runtime/legacyUnhandledExceptionPolicy");
if (policyNode != null)
{
    string enabled = policyNode.Attributes.GetNamedItem("enabled").Value;
    canAbortThread = bool.Parse(enabled);
}




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







[최초 등록일: ]
[최종 수정일: 7/17/2021]

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

비밀번호

댓글 작성자
 




... 46  47  48  49  50  51  52  [53]  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12304정성태8/31/202010068개발 환경 구성: 505. 윈도우 - (네트워크 어댑터의 우선순위로 인한) 열거되는 IP 주소 순서를 조정하는 방법
12303정성태8/30/202010246개발 환경 구성: 504. ETW - 닷넷 프레임워크 기반의 응용 프로그램을 위한 명령행 도구 etrace 소개
12302정성태8/30/202010159.NET Framework: 936. C# - ETW 관련 Win32 API 사용 예제 코드 (5) - Private Logger파일 다운로드1
12301정성태8/30/202010428오류 유형: 641. error MSB4044: The "Fody.WeavingTask" task was not given a value for the required parameter "IntermediateDir".
12300정성태8/29/20209878.NET Framework: 935. C# - ETW 관련 Win32 API 사용 예제 코드 (4) CLR ETW Consumer파일 다운로드1
12299정성태8/27/202010803.NET Framework: 934. C# - ETW 관련 Win32 API 사용 예제 코드 (3) ETW Consumer 구현파일 다운로드1
12298정성태8/27/202010519오류 유형: 640. livekd - Could not resolve symbols for ntoskrnl.exe: MmPfnDatabase
12297정성태8/25/20209737개발 환경 구성: 503. SHA256 테스트 인증서 생성 방법
12296정성태8/24/202010176.NET Framework: 933. C# - ETW 관련 Win32 API 사용 예제 코드 (2) NT Kernel Logger파일 다운로드1
12295정성태8/24/20209593오류 유형: 639. Bitvise - Address is already in use; bind() in ListeningSocket::StartListening() failed: Windows error 10013: An attempt was made to access a socket ,,,
12293정성태8/24/202010909Windows: 171. "Administered port exclusions" 설명
12292정성태8/20/202012176.NET Framework: 932. C# - ETW 관련 Win32 API 사용 예제 코드 (1)파일 다운로드2
12291정성태8/15/202011067오류 유형: 638. error 1297: Device driver does not install on any devices, use primitive driver if this is intended.
12290정성태8/11/202011791.NET Framework: 931. C# - IP 주소에 따른 국가별 위치 확인 [8]파일 다운로드1
12289정성태8/6/20209283개발 환경 구성: 502. Portainer에 윈도우 컨테이너를 등록하는 방법
12288정성태8/5/20209252오류 유형: 637. WCF - The protocol 'net.tcp' does not have an implementation of HostedTransportConfiguration type registered.
12287정성태8/5/20209747오류 유형: 636. C# - libdl.so를 DllImport로 연결 시 docker container 내에서 System.DllNotFoundException 예외 발생
12286정성태8/5/202010632개발 환경 구성: 501. .NET Core 용 container 이미지 만들 때 unzip이 필요한 경우
12285정성태8/4/202011014오류 유형: 635. 윈도우 10 업데이트 - 0xc1900209 [2]
12284정성태8/4/202010346디버깅 기술: 169. Hyper-V의 VM에 대한 메모리 덤프를 뜨는 방법
12283정성태8/3/202010818디버깅 기술: 168. windbg - 필터 드라이버 확인하는 확장 명령어(!fltkd) [2]
12282정성태8/2/20209590디버깅 기술: 167. windbg 디버깅 사례: AppDomain 간의 static 변수 사용으로 인한 crash (2)
12281정성태8/2/202012100개발 환경 구성: 500. (PDB 연결이 없는) DLL의 소스 코드 디버깅을 dotPeek 도구로 해결하는 방법
12280정성태8/2/202011274오류 유형: 634. 오라클 (평생) 무료 클라우드 VM 생성 후 SSH 접속 시 키 오류 발생 [2]
12279정성태7/29/202012118개발 환경 구성: 499. 닷넷에서 접근해보는 InterSystems의 Cache 데이터베이스파일 다운로드1
12278정성태7/23/20209468VS.NET IDE: 149. ("Binary was not built with debug information" 상태로) 소스 코드 디버깅이 안되는 경우
... 46  47  48  49  50  51  52  [53]  54  55  56  57  58  59  60  ...