Microsoft MVP성태의 닷넷 이야기
오류 유형: 4.1. NET BCL 에서 제공되는 FolderBrowserDialog [링크 복사], [링크+제목 복사],
조회: 18504
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
부모글 보이기/감추기


짐작할 수 있겠지만, System.Windows.Forms.FolderBrowserDialog 는 P/Invoke 를 통해서 Win32 에서 제공되는 SHBrowserForFolder 를 이용하고 있습니다.

Reflector 등을 통해서 보면, 아래와 같은 API 를 Import 하고 있습니다.

[SuppressUnmanagedCodeSecurity, ComVisible(false)]
internal class Shell32
{
      // Methods
      public Shell32();
      [DllImport("shell32.dll", CharSet=CharSet.Auto)]
      public static extern IntPtr SHBrowseForFolder([In] UnsafeNativeMethods.BROWSEINFO lpbi);
      [DllImport("shell32.dll")]
      public static extern int SHGetMalloc([Out, MarshalAs(UnmanagedType.LPArray)] UnsafeNativeMethods.IMalloc[] ppMalloc);
      [DllImport("shell32.dll", CharSet=CharSet.Auto)]
      public static extern bool SHGetPathFromIDList(IntPtr pidl, IntPtr pszPath);
      [DllImport("shell32.dll")]
      public static extern int SHGetSpecialFolderLocation(IntPtr hwnd, int csidl, ref IntPtr ppidl);
}

보시면 아시겠지만, SHParseDisplayName 함수가 빠져 있습니다. Windows 2000 에서는 안된다고 하는 문서 명시를 하기 보다는 아예 폴더 자체를 지정할 수 없도록 선택을 한 것입니다. 물론, FolderBrowserDialog 에는 다음과 같은 속성을 통해서 루트 경로를 지정할 수 있는 기능은 제공합니다.

public Environment.SpecialFolder RootFolder {get; set;}

여기서의 SpecialFolder 타입은 enum 입니다. 실제로 이 Enum 값은 Win32 에서 제공되는 함수에 제한을 받습니다. 위의 dllimport 목록에서 볼 수 있는 SHGetSpecialFolderLocation 함수인데, 구체적인 선언은 다음과 같습니다.

HRESULT SHGetSpecialFolderLocation( HWND hwndOwner,
    int nFolder,
    LPITEMIDLIST *ppidl
);

인자의 nFolder 값에 해당하는 Shell 개체에 대한 PIDL 값을 ppidl 로 반환해 주는 함수입니다. 다행히도 이 함수의 최소 지원 운영체제는 Windows NT 4.0 및 Windows 95 입니다.

결국, Windows 2000 에서의 문제를 피하기 위해 nFolder 에 허용하는 값을 제외한 직접적인 폴더 경로를 지정하는 것은 가능하지 않습니다.






[최초 등록일: ]
[최종 수정일: 6/2/2006]

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

비밀번호

댓글 작성자
 



2007-01-13 12시18분
[그러면] 결국 2000 에서는 구현이 안된다는 것인가요?
[guest]
2007-01-13 07시16분
SHParseDisplayName 함수가 Windows 2000에서 제공이 안될 뿐입니다. SHBrowserForFolder 함수 자체는 정상적으로 기능을 합니다.
kevin25

... 46  47  48  49  50  51  52  53  54  55  56  57  [58]  59  60  ...
NoWriterDateCnt.TitleFile(s)
12523정성태1/31/202117708개발 환경 구성: 529. 기존 github 프로젝트를 Azure Devops의 Board에 연결하는 방법
12522정성태1/31/202119920개발 환경 구성: 528. 오라클 클라우드의 리눅스 VM - 9000 MTU Jumbo Frame 테스트
12521정성태1/31/202118237개발 환경 구성: 527. 이더넷(Ethernet) 환경의 TCP 통신에서 MSS(Maximum Segment Size) 확인 [1]
12520정성태1/30/202117357개발 환경 구성: 526. 오라클 클라우드의 VM에 ping ICMP 여는 방법
12519정성태1/30/202116431개발 환경 구성: 525. 오라클 클라우드의 VM을 외부에서 접근하기 위해 포트 여는 방법
12518정성태1/30/202134642Linux: 37. Ubuntu에 Wireshark 설치 [2]
12517정성태1/30/202121972Linux: 36. 윈도우 클라이언트에서 X2Go를 이용한 원격 리눅스의 GUI 접속 - 우분투 20.04
12516정성태1/29/202118296Windows: 188. Windows - TCP default template 설정 방법
12515정성태1/28/202120243웹: 41. Microsoft Edge - localhost에 대해 http 접근 시 무조건 https로 바뀌는 문제 [3]
12514정성태1/28/202120446.NET Framework: 1021. C# - 일렉트론 닷넷(Electron.NET) 소개 [1]파일 다운로드1
12513정성태1/28/202116816오류 유형: 698. electronize - User Profile 디렉터리에 공백 문자가 있는 경우 빌드가 실패하는 문제 [1]
12512정성태1/28/202118088오류 유형: 697. The program can't start because VCRUNTIME140.dll is missing from your computer. Try reinstalling the program to fix this problem.
12511정성태1/27/202117769Windows: 187. Windows - 도스 시절의 8.3 경로를 알아내는 방법
12510정성태1/27/202118614.NET Framework: 1020. .NET Core Kestrel 호스팅 - Razor 지원 추가 [1]파일 다운로드1
12509정성태1/27/202117745개발 환경 구성: 524. Jupyter Notebook에서 C#(F#, PowerShell) 언어 사용을 위한 환경 구성 [3]
12508정성태1/27/202117691개발 환경 구성: 523. Jupyter Notebook - Slide 플레이 버튼이 없는 경우
12507정성태1/26/202118272VS.NET IDE: 157. Visual Studio - Syntax Visualizer 메뉴가 없는 경우
12506정성태1/25/202121238.NET Framework: 1019. Microsoft.Tye 기본 사용법 소개 [1]
12505정성태1/23/202117294.NET Framework: 1018. .NET Core Kestrel 호스팅 - Web API 추가 [1]파일 다운로드1
12504정성태1/23/202120008.NET Framework: 1017. .NET 5에서의 네트워크 라이브러리 개선 (2) - HTTP/2, HTTP/3 관련 [1]
12503정성태1/21/202118446오류 유형: 696. C# - HttpClient: Requesting HTTP version 2.0 with version policy RequestVersionExact while HTTP/2 is not enabled.
12502정성태1/21/202119018.NET Framework: 1016. .NET Core HttpClient의 HTTP/2 지원파일 다운로드1
12501정성태1/21/202117757.NET Framework: 1015. .NET 5부터 HTTP/1.1, 2.0 선택을 위한 HttpVersionPolicy 동작 방식파일 다운로드1
12500정성태1/21/202118858.NET Framework: 1014. ASP.NET Core(Kestrel)의 HTTP/2 지원 여부파일 다운로드1
12499정성태1/20/202120254.NET Framework: 1013. .NET Core Kestrel 호스팅 - 포트 변경, non-localhost 접속 지원 및 https 등의 설정 변경 [1]파일 다운로드1
12498정성태1/20/202117856.NET Framework: 1012. .NET Core Kestrel 호스팅 - 비주얼 스튜디오의 Kestrel/IIS Express 프로파일 설정
... 46  47  48  49  50  51  52  53  54  55  56  57  [58]  59  60  ...