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

겪어보신 분들이 있을지 모르겠습니다.

제가 테스트한 것은

UNIX Type: L8 Version: SUNOS
poseidon FTP server

입니다.

파일 전송이나 로긴에서는 문제가 없는데 파일 목록을 받아오는 FtpFindFirstFile이나 CFtpFileFind에서는 정상적으로 목록을 받아오지 못합니다.

그 poseidon FTP 서버에 대해 LIST를 해보니까....

-rw------- 1 root root 478392 8월 27일 10:19 core
-rw-r--r-- 1 root other 2542 2001년 12월 12일 cshrc.org

위와 같은 식으로 특이하게 나옵니다.

첫 번째 항목은 "8월 27일 10:19"라고 나오고...
두 번째 항목은 "2001년 12월 12일"이라고 나온 것을 볼 수 있습니다.

이런 경우, WinINET에서 제공되는 편리한 FTP 라이브러리를 버리기에는 너무 아깝죠.
다른 공개 라이브러리 찾기도 그렇고, 새로 만들기에는 더더욱 귀찮을 테니까요.

아마도 MS에서도 이 부분을 예상하지 않았나 싶네요. ^^ CFtpConnection::FtpCommand 함수를 이용하시거나 FtpCommand 함수를 이용해서 직접 목록에 대한 파싱을 하는 것도 좋습니다. 목록 부분만 FtpCommand로 직접 처리를 하고 나머지에 대해서는 마찬가지로 CFtpConnection에서 제공되는 편리한 함수들을 사용하면 되니까요.

대략 다음과 같은 식으로 사용하면 되겠지요. ^^

    CString cmd = "CWD /userroot";
    m_ftpConnection->Command( cmd, CFtpConnection::CmdResponseType::CmdRespNone );

    CInternetFile *iFile = m_ftpConnection->Command( "LIST", CFtpConnection::CmdResponseType::CmdRespRead );
    CString readText;
    while ( iFile->ReadString( readText ) )
    {
          // readText 문자열 파싱
    }
    iFile->Close();








[최초 등록일: ]
[최종 수정일: 6/26/2021]

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

비밀번호

댓글 작성자
 




... 61  62  63  64  65  66  67  68  69  70  [71]  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
12221정성태6/3/202019692Windows: 170. 비어 있지 않은 디렉터리로 symbolic link(junction) 연결하는 방법
12220정성태6/3/202024377.NET Framework: 907. C# DLL로부터 TLB 및 C/C++ 헤더 파일(TLH)을 생성하는 방법
12219정성태6/1/202022426.NET Framework: 906. C# - lock (this), lock (typeof(...))를 사용하면 안 되는 이유파일 다운로드1
12218정성태5/27/202020972.NET Framework: 905. C# - DirectX 게임 클라이언트 실행 중 키보드 입력을 감지하는 방법 [3]
12217정성태5/24/202019682오류 유형: 615. Transaction count after EXECUTE indicates a mismatching number of BEGIN and COMMIT statements. Previous count = 0, current count = 1.
12216정성태5/15/202023048.NET Framework: 904. USB/IP PROJECT를 이용해 C#으로 USB Keyboard 가상 장치 만들기 [14]파일 다운로드1
12215정성태5/12/202028880개발 환경 구성: 490. C# - (Wireshark의) USBPcap을 이용한 USB 패킷 모니터링 [10]파일 다운로드1
12214정성태5/5/202021612개발 환경 구성: 489. 정식 인증서가 있는 경우 Device Driver 서명하는 방법 (2) - UEFI/SecureBoot [1]
12213정성태5/3/202021808개발 환경 구성: 488. (User-mode 코드로 가상 USB 장치를 만들 수 있는) USB/IP PROJECT 소개
12212정성태5/1/202018864개발 환경 구성: 487. UEFI / Secure Boot 상태인지 확인하는 방법
12211정성태4/27/202021813개발 환경 구성: 486. WSL에서 Makefile로 공개된 리눅스 환경의 C/C++ 소스 코드 빌드
12210정성태4/20/202023914.NET Framework: 903. .NET Framework의 Strong-named 어셈블리 바인딩 (1) - app.config을 이용한 바인딩 리디렉션 [1]파일 다운로드1
12209정성태4/13/202019467오류 유형: 614. 리눅스 환경에서 C/C++ 프로그램이 Segmentation fault 에러가 발생한 경우 (2)
12208정성태4/12/202017353Linux: 29. 리눅스 환경에서 C/C++ 프로그램이 Segmentation fault 에러가 발생한 경우
12207정성태4/2/202018701스크립트: 19. Windows PowerShell의 NonInteractive 모드
12206정성태4/2/202020291오류 유형: 613. 파일 잠금이 바로 안 풀린다면? - The process cannot access the file '...' because it is being used by another process.
12205정성태4/2/202017301스크립트: 18. Powershell에서는 cmd.exe의 명령어를 지원하진 않습니다.
12204정성태4/1/202018109스크립트: 17. Powershell 명령어에 ';' (semi-colon) 문자가 포함된 경우
12203정성태3/18/202021196오류 유형: 612. warning: 'C:\ProgramData/Git/config' has a dubious owner: '...'.
12202정성태3/18/202024489개발 환경 구성: 486. .NET Framework 프로젝트를 위한 GitLab CI/CD Runner 구성
12201정성태3/18/202021198오류 유형: 611. git-credential-manager.exe: Using credentials for username "Personal Access Token". [1]
12200정성태3/18/202021072VS.NET IDE: 145. NuGet + Github 라이브러리 디버깅 관련 옵션 3가지 - "Enable Just My Code" / "Enable Source Link support" / "Suppress JIT optimization on module load (Managed only)"
12199정성태3/17/202019062오류 유형: 610. C# - CodeDomProvider 사용 시 Unhandled Exception: System.IO.DirectoryNotFoundException: Could not find a part of the path '...\f2_6uod0.tmp'.
12198정성태3/17/202022647오류 유형: 609. SQL 서버 접속 시 "Cannot open user default database. Login failed."
12197정성태3/17/202022107VS.NET IDE: 144. .NET Core 콘솔 응용 프로그램을 배포(publish) 시 docker image 자동 생성 - 두 번째 이야기 [1]
12196정성태3/17/202018472오류 유형: 608. The ServicedComponent being invoked is not correctly configured (Use regsvcs to re-register).
... 61  62  63  64  65  66  67  68  69  70  [71]  72  73  74  75  ...