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

C# - CodeDomProvider 사용 시 Unhandled Exception: System.IO.DirectoryNotFoundException: Could not find a part of the path '...\f2_6uod0.tmp'.

CodeDomProvider를 사용한 응용 프로그램이 고객사의 특정 서버에서만 다음과 같은 식의 컴파일 오류가 발생하고,

Line number 0, Error Number: CS2001, 'Source file 'C:\Windows\TEMP\kilsykm3.0.cs' could not be found
Line number 0, Error Number: CS2001, 'Source file 'C:\Windows\TEMP\kilsykm3.1.cs' could not be found
Line number 0, Error Number: CS2001, 'Source file 'C:\Windows\TEMP\kilsykm3.2.cs' could not be found
Line number 0, Error Number: CS2008, 'No source files specified

구체적인 예외 메시지는 DirectoryNotFoundException으로 나옵니다.

Unhandled Exception: System.IO.DirectoryNotFoundException: Could not find a part of the path 'C:\temp\ConsoleApp1\bin\Debug\extension\f2_6uod0.tmp'.
   at System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath)
   at System.IO.FileStream.Init(String path, FileMode mode, FileAccess access, Int32 rights, Boolean useRights, FileShare share, Int32 bufferSize, FileOptions options, SECURITY_ATTRIBUTES secAttrs, String msgPath, Boolean bFromProxy)
   at System.IO.FileStream..ctor(String path, FileMode mode, FileAccess access, FileShare share, Int32 bufferSize, FileOptions options, String msgPath, Boolean bFromProxy)
   at System.IO.FileStream..ctor(String path, FileMode mode, FileAccess access)
   at System.CodeDom.Compiler.TempFileCollection.EnsureTempNameCreated()
   at System.CodeDom.Compiler.TempFileCollection.AddExtension(String fileExtension, Boolean keepFile)
   at Microsoft.CSharp.CSharpCodeGenerator.FromSourceBatch(CompilerParameters options, String[] sources)
   at Microsoft.CSharp.CSharpCodeGenerator.System.CodeDom.Compiler.ICodeCompiler.CompileAssemblyFromSourceBatch(CompilerParameters options, String[] sources)
   at System.CodeDom.Compiler.CodeDomProvider.CompileAssemblyFromSource(CompilerParameters options, String[] sources)
   at ConsoleApp1.Program.Main(String[] args) in C:\temp\ConsoleApp1\Program.cs:line 57

고객사 서버를 구체적으로 검사할 만한 상황은 아니었지만, 그동안의 경험으로 ^^ 봤을 때 아마도 해당 서버에 설치해 둔 보안 프로그램이 "C:\Windows" 하위 폴더에 생성된 임시 파일들을 강제 삭제하기 때문에 CompileAssemblyFromSourceBatch 메서드 수행 시점에는 해당 파일들이 없어 저런 오류가 발생하는 것으로 보입니다.

그래서 임시 파일의 생성 경로를 "%TEMP%"가 아닌 명시적인 로컬 폴더를 지정하는 것으로 바꿨고, 이후 오류 없이 응용 프로그램이 잘 동작했습니다. ^^




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







[최초 등록일: ]
[최종 수정일: 3/17/2020]

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

비밀번호

댓글 작성자
 




... 181  182  183  184  185  186  187  188  189  190  [191]  192  193  194  195  ...
NoWriterDateCnt.TitleFile(s)
276정성태6/7/200621826Team Foundation Server: 7. 외부 빌드 머신 구성
287정성태6/24/200619624    답변글 Team Foundation Server: 7.1. 외부 빌드 머신 구성 - 다른 블로그 자료
275정성태6/7/200627669디버깅 기술: 4. VC++ 8.0 원격 디버깅 구성 - Side-by-Side DLL 문제.
269정성태6/6/200624529Team Foundation Server: 6. HTTPS를 통한 Team Server 접근 [1]
270정성태6/5/200621919    답변글 Team Foundation Server: 6.1. HTTPS를 통한 Team Server 접근 [1]
273정성태6/6/200624607    답변글 Team Foundation Server: 6.2. 두번째 방법 - HTTPS 를 통한 Team Server 접근 [1]
267정성태6/4/200623977Team Foundation Server: 5. 인터넷으로 Team Server 접근 [2]
266정성태6/8/200620236오류 유형: 7. [설치] mpoai9.dll 관련 오류
265정성태6/1/200628008디버깅 기술: 3. 원격 컴퓨터 디버깅 - VPC 설정
314정성태8/11/200625310    답변글 디버깅 기술: 3.1. Managed 원격 디버깅과 WinDBG 원격 디버깅
264정성태6/1/200634724오류 유형: 6. [VC++ 컴파일] already defined in ntdll.lib(ntdll.dll)
263정성태6/1/200635419디버깅 기술: 2. 커널 구조체 살펴보기 [5]
262정성태6/1/200628253오류 유형: 5. [설치] WinFX Beta2 - 설치시 문제점 해결
261정성태6/1/200624166웹: 3. IIS 6.0 - AppPool을 활용하여 실 서버(운영 서버)에서 디버깅
258정성태6/1/200632136디버깅 기술: 1. 디버깅 방법 - CLR 프로파일러 [1]파일 다운로드1
274정성태6/7/200625016    답변글 디버깅 기술: 1.1. 디버깅 방법 - CLR 프로파일러 ( on Vista )
254정성태6/1/200621379개발 환경 구성: 2. VPC에 Vista 설치하는 방법 [2]
255정성태6/1/200621390    답변글 개발 환경 구성: 2.1. msconfig 설정과 Windows Activation
259정성태6/1/200620284    답변글 개발 환경 구성: 2.2. Vista VPC에 터미널 서비스 - 원격 접속
253정성태6/1/200618024기타: 14. .NET 2.0 이 지원되는 NDoc 2.0 을 배포합니다.
251정성태6/1/200621414오류 유형: 4. [OS 지원 API] SHParseDisplayName과 Windows 2000
252정성태6/1/200620752    답변글 오류 유형: 4.1. NET BCL 에서 제공되는 FolderBrowserDialog [2]
249정성태6/1/200620758.NET Framework: 71. VB.NET 이외의 언어에서 My 네임스페이스 사용
250정성태6/1/200623743    답변글 .NET Framework: 71.1. VB.NET 이외의 언어에서 My 네임스페이스 사용
248정성태6/1/200622109기타: 13. Code Center Premium에서 Win32 API 소스 찾기
245정성태6/1/200629413오류 유형: 3. [C# / VC++] error C2146: syntax error : missing ';' before identifier 'GetType'
... 181  182  183  184  185  186  187  188  189  190  [191]  192  193  194  195  ...