2016-10-31 10 views
0

"GetUrlCacheEntryInfo"라는 함수가 제공 한 정보를 출력하려했지만 작동하지 않습니다. 디버그 로그의 문자 만 인쇄합니다. 모든 데이터를 올바르게 인쇄하려면 어떻게해야합니까?GetUrlCacheEntryInfo usage

+0

당신이를 제공 할 수 –

답변

0

여기는 작동하는 예제입니다. 캐시에있는 URL (https://h6.msn.com/library/8.8/dapmsn.js)입니다. IE를 사용하지 않았기 때문에 FindFirstUrlCacheEntry에 처음 도착했습니다. 왜 한 문자 만 인쇄 할 수 있는지 어쩌면 당신이 넓은 문자열 인쇄 기능을 사용하지 않는 것입니다. (아래 샘플에 std::coutstd::wcout의 사용 참조) 적절하게 인쇄해야하므로 lpszSourceUrlNamelpszLocalFileName 필드는 넓은 문자열 필드입니다.

#include <Windows.h> 
#include <Wininet.h> 

#include <memory> 

#pragma comment(lib, "Wininet.lib") 

#include <iostream> 

bool GetUrlCacheEntryInfo(const wchar_t* pUrl, std::unique_ptr<unsigned char[]>& pUrlCacheEntryInfo, DWORD nBufferSize = sizeof(INTERNET_CACHE_ENTRY_INFO)) 
{ 
    std::unique_ptr<unsigned char[]> pTemporaryUrlCacheEntryInfo(new unsigned char[nBufferSize]); 
    if (GetUrlCacheEntryInfo(pUrl, reinterpret_cast<LPINTERNET_CACHE_ENTRY_INFO>(pTemporaryUrlCacheEntryInfo.get()), &nBufferSize) == FALSE) 
    { 
     const DWORD nError = GetLastError(); 
     if (nError == ERROR_INSUFFICIENT_BUFFER) 
     { 
      pTemporaryUrlCacheEntryInfo.reset(new unsigned char[nBufferSize]); 
      if (GetUrlCacheEntryInfo(pUrl, reinterpret_cast<LPINTERNET_CACHE_ENTRY_INFO>(pTemporaryUrlCacheEntryInfo.get()), &nBufferSize) == FALSE) 
      { 
       return false; 
      } 
     } 
     else 
     { 
      return false; 
     } 
    } 
    pUrlCacheEntryInfo = std::move(pTemporaryUrlCacheEntryInfo); 
    return true; 
} 

void PrintUrlCacheEntryInfo(LPINTERNET_CACHE_ENTRY_INFO pUrlCacheEntryInfo) 
{ 
    std::cout << "Cache Entry Info:\n\tSize: " << pUrlCacheEntryInfo->dwStructSize << "\n\tUrl: "; 
    std::wcout << pUrlCacheEntryInfo->lpszSourceUrlName; 
    std::cout << "\n\tLocal File:"; 
    std::wcout << pUrlCacheEntryInfo->lpszLocalFileName; 
    std::cout << "\n\tType: "; 
    switch (pUrlCacheEntryInfo->CacheEntryType) 
    { 
    case EDITED_CACHE_ENTRY: 
     std::cout << "EDITED_CACHE_ENTRY"; 
     break; 
    case SPARSE_CACHE_ENTRY: 
     std::cout << "SPARSE_CACHE_ENTRY"; 
     break; 
    case STICKY_CACHE_ENTRY: 
     std::cout << "STICKY_CACHE_ENTRY"; 
     break; 
    case TRACK_OFFLINE_CACHE_ENTRY: 
     std::cout << "TRACK_OFFLINE_CACHE_ENTRY"; 
     break; 
    case TRACK_ONLINE_CACHE_ENTRY: 
     std::cout << "TRACK_ONLINE_CACHE_ENTRY"; 
     break; 
    default: 
     std::cout << "UNKNOWN"; 
     break; 
    } 
    std::cout << "\n\tHeaders: "; 
    std::wcout << pUrlCacheEntryInfo->lpHeaderInfo; 
    std::cout << "\n"; 
} 

int main(int argc, char** argv) 
{ 
    const wchar_t* pUrl = L"https://h6.msn.com/library/8.8/dapmsn.js"; 
    std::unique_ptr<unsigned char[]> pUrlCacheEntryInfo; 
    if (GetUrlCacheEntryInfo(pUrl, pUrlCacheEntryInfo)) 
    { 
     PrintUrlCacheEntryInfo(reinterpret_cast<LPINTERNET_CACHE_ENTRY_INFO>(pUrlCacheEntryInfo.get())); 
    } 
    else 
    { 
     std::wcout << L"Cache entry for url " << pUrl << L" was not found!\n"; 
    } 
    return EXIT_SUCCESS; 
} 
+0

자, URLDownloadToFile이 appd에있는 파일을 다운로드하는 이유를 알고 있습니까? 직접 경로를 지정 경로로 다운로드하는 대신 ata (iecache)를 사용 하시겠습니까? – GDaniel

+0

내가 geturlcacheentryinfo에 대해 물어 본 이유는 다운로드 한 파일의 위치를 ​​찾고 싶기 때문이며 – GDaniel

+0

@GDaniel 아이디어가 없기 때문에 명시 적으로 URLDownloadToCacheFile 함수가 있기 때문에 나는 이유를 모른다. URLDownloadToFile은 파일을 캐시에 저장해야한다. . 리턴 코드는 무엇입니까? 마지막 인자로 콜백 인터페이스를 제공하고 있습니까? –