Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)
(시리즈 글이 3개 있습니다.)
개발 환경 구성: 220. supportedRuntime 설정을 위한 app.config Transformation
; https://www.sysnet.pe.kr/2/0/1662

.NET Framework: 1193. (appsettings.json처럼) web.config의 Debug/Release에 따른 설정 적용
; https://www.sysnet.pe.kr/2/0/13028

VS.NET IDE: 200. C# - app.config 파일의 출력을 Configuration(Debug/Release)에 따라 제어하는 방법
; https://www.sysnet.pe.kr/2/0/13918




(appsettings.json처럼) web.config의 Debug/Release에 따른 설정 적용

appsettings.json의 경우 "ASPNETCORE_ENVIRONMENT=Development" 환경 변수가 설정돼 있다면 "appsettings.Development.json"의 내용이 적용되는데요, 아쉽게도 web.config의 경우에는 이런 배려가 없습니다.

대신 web.config에는 (기본적으로) Debug/Release에 따른 Web.Debug.config과 Web.Release.config 파일을 이용한 Transform 절차가 있습니다. 그러나 역시 이번에도 아쉽지만, 해당 transform 절차는 프로젝트를 Publish하는 단계에서만 실행되므로 appsettings.json처럼 비주얼 스튜디오에서 개발 시에는 혜택을 받지 못합니다.

하지만, 아예 방법이 없는 것은 아닙니다. Publish 단계에 transform 절차가 진행된다는 것은 결국 msbuild의 Task로 동작하는 것이므로, 마찬가지로 csproj의 내용에 해당 절차를 포함하면 되기 때문입니다. 이에 대한 csproj 예제를 다음의 글에서 찾을 수 있습니다.

How to enable transformations on build with Visual Studio
; https://gist.github.com/EdCharbeneau/9135216

위의 방법을 적용하면 이제 web.config의 관리 방법이 달라집니다. 우선, 기존에 가지고 있던 web.config을 복사해 web.base.config과 같은 식의 파일로 새롭게 생성합니다. 그다음, csproj에 다음의 작업을 추가하면 됩니다.

<Target Name="BeforeBuild">
    <TransformXml Source="Web.Base.config" Transform="Web.$(Configuration).config" Destination="Web.config" />
</Target>     

간단하게 위의 작업을 설명하면, web.base.config에 (디버그 빌드 중이라면) web.debug.config의 내용을 적용한 후 새롭게 web.config 파일로 만들어 줍니다. 따라서 이후부터는 변경 사항을 web.config이 아닌, web.base.config 파일에 적용해야 합니다. 바로 이게 좀 아쉬운 건데요, 어쩌면 스택오버플로우 같은 사이트에서 "web.config에 변경 사항을 아무리 적용해도 빌드만 했다 하면 원복 된다는..." 희한한 현상을 겪는 개발자의 질문을 보게 될지도 모릅니다. ^^




물론, 다음과 같이 해도 됩니다.

<Target Name="BeforeBuild">
    <TransformXml Source="Web.config" Transform="Web.$(Configuration).config" Destination="Web.config" />
</Target>     

위와 같이 하면, 자신이 편집한 web.config 파일이 web.Debug.config 파일이 적용된 후 다시 그 내용을 web.config으로 쓰기 때문에 결국 원하는 동작은 수행할 수 있습니다. 하지만, 원본 web.config 파일이 바뀌게 되고 그 과정에서 xml의 정규화까지 이뤄지므로 생성된 web.config의 내용이 낯설어진다는 불편함이 있습니다.

따라서, 위에서 설명한 어떤 방식이든 각자의 장/단점이 있습니다.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 4/13/2022]

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

비밀번호

댓글 작성자
 




1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13904정성태3/25/20253172디버깅 기술: 218. Windbg로 살펴보는 Win32 Critical Section파일 다운로드1
13903정성태3/24/20252361VS.NET IDE: 197. (OneDrive, Dropbox 등의 공유 디렉터리에 있는) C++ 프로젝트의 출력 경로 변경하기
13902정성태3/24/20252843개발 환경 구성: 742. Oracle - 테스트용 hr 계정 및 데이터 생성파일 다운로드1
13901정성태3/9/20253182Windows: 280. Hyper-V의 3가지 Thread Scheduler (Classic, Core, Root)
13900정성태3/8/20253935스크립트: 72. 파이썬 - SQLAlchemy + oracledb 연동
13899정성태3/7/20252536스크립트: 71. 파이썬 - asyncio의 ContextVar 전달
13898정성태3/5/20253341오류 유형: 948. Visual Studio - Proxy Authentication Required: dotnetfeed.blob.core.windows.net
13897정성태3/5/20254281닷넷: 2326. C# - PowerShell과 연동하는 방법 (두 번째 이야기)파일 다운로드1
13896정성태3/5/20254075Windows: 279. Hyper-V Manager - VM 목록의 CPU Usage 항목이 항상 0%로 나오는 문제
13895정성태3/4/20254019Linux: 117. eBPF / bpf2go - Map에 추가된 요소의 개수를 확인하는 방법
13894정성태2/28/20253861Linux: 116. eBPF / bpf2go - BTF Style Maps 정의 구문과 데이터 정렬 문제
13893정성태2/27/20253380Linux: 115. eBPF (bpf2go) - ARRAY / HASH map 기본 사용법
13892정성태2/24/20254783닷넷: 2325. C# - PowerShell과 연동하는 방법파일 다운로드1
13891정성태2/23/20253545닷넷: 2324. C# - 프로세스의 성능 카운터용 인스턴스 이름을 구하는 방법파일 다운로드1
13890정성태2/21/20253319닷넷: 2323. C# - 프로세스 메모리 중 Private Working Set 크기를 구하는 방법(Win32 API)파일 다운로드1
13889정성태2/20/20254690닷넷: 2322. C# - 프로세스 메모리 중 Private Working Set 크기를 구하는 방법(성능 카운터, WMI) [1]파일 다운로드1
13888정성태2/17/20253770닷넷: 2321. Blazor에서 발생할 수 있는 async void 메서드의 부작용
13887정성태2/17/20254842닷넷: 2320. Blazor의 razor 페이지에서 code-behind 파일로 코드를 분리 및 DI 사용법
13886정성태2/15/20253661VS.NET IDE: 196. Visual Studio - Code-behind처럼 cs 파일을 그룹핑하는 방법
13885정성태2/14/20254755닷넷: 2319. ASP.NET Core Web API / Razor 페이지에서 발생할 수 있는 async void 메서드의 부작용
13884정성태2/13/20255156닷넷: 2318. C# - (async Task가 아닌) async void 사용 시의 부작용파일 다운로드1
13883정성태2/12/20254854닷넷: 2317. C# - Memory Mapped I/O를 이용한 PCI Configuration Space 정보 열람파일 다운로드1
13882정성태2/10/20253625스크립트: 70. 파이썬 - oracledb 패키지 연동 시 Thin / Thick 모드
13881정성태2/7/20254001닷넷: 2316. C# - Port I/O를 이용한 PCI Configuration Space 정보 열람파일 다운로드1
13880정성태2/5/20255253오류 유형: 947. sshd - Failed to start OpenSSH server daemon.
13879정성태2/5/20255285오류 유형: 946. Ubuntu - N: Updating from such a repository can't be done securely, and is therefore disabled by default.
1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...