CommitUrlCacheEntryW 함수(wininet.h)

지정된 파일의 데이터를 인터넷 캐시에 저장하고 지정된 URL에 연결합니다.

구문

BOOL CommitUrlCacheEntryW(
  [in] LPCWSTR  lpszUrlName,
  [in] LPCWSTR  lpszLocalFileName,
  [in] FILETIME ExpireTime,
  [in] FILETIME LastModifiedTime,
  [in] DWORD    CacheEntryType,
  [in] LPWSTR   lpszHeaderInfo,
  [in] DWORD    cchHeaderInfo,
  [in] LPCWSTR  lpszFileExtension,
  [in] LPCWSTR  lpszOriginalUrl
);

매개 변수

[in] lpszUrlName

캐시 항목의 원본 이름을 포함하는 문자열 변수에 대한 포인터입니다. 이름 문자열은 고유해야 하며 이스케이프 문자를 포함하지 않아야 합니다.

[in] lpszLocalFileName

캐시되는 로컬 파일의 이름을 포함하는 문자열 변수에 대한 포인터입니다. CreateUrlCacheEntryW에서 반환한 이름과 같아야 합니다.

[in] ExpireTime

캐시되는 파일의 만료 날짜 및 시간(그리니치 평균 시간)을 포함하는 FILETIME 구조체입니다. 만료 날짜 및 시간을 알 수 없는 경우 이 매개 변수를 0으로 설정합니다.

[in] LastModifiedTime

캐시되는 URL의 마지막으로 수정된 날짜 및 시간(그리니치 평균 시간)을 포함하는 FILETIME 구조체입니다. 마지막으로 수정한 날짜와 시간을 알 수 없는 경우 이 매개 변수를 0으로 설정합니다.

[in] CacheEntryType

캐시 항목의 형식과 해당 속성을 나타내는 비트 마스크입니다. 캐시 항목 유형에는 기록 항목(URLHISTORY_CACHE_ENTRY), 쿠키 항목(COOKIE_CACHE_ENTRY) 및 일반 캐시된 콘텐츠(NORMAL_CACHE_ENTRY)가 포함됩니다.

이 매개 변수는 아래 나열된 다음 속성 플래그 및 캐시 형식 플래그 중 0개 이상일 수 있습니다.

의미
COOKIE_CACHE_ENTRY
쿠키 캐시 항목입니다.
EDITED_CACHE_ENTRY
외부에서 편집된 캐시 항목 파일입니다. 이 캐시 항목 유형은 청소에서 제외됩니다.
NORMAL_CACHE_ENTRY
기본 캐시 항목입니다. 새 항목을 위한 공간을 확보하기 위해 삭제할 수 있습니다.
SPARSE_CACHE_ENTRY
부분 응답 캐시 항목입니다.
STICKY_CACHE_ENTRY
고정 캐시 항목입니다. 청소에서 제외됩니다.
TRACK_OFFLINE_CACHE_ENTRY
현재 구현되지 않습니다.
TRACK_ONLINE_CACHE_ENTRY
현재 구현되지 않습니다.
URLHISTORY_CACHE_ENTRY
방문한 링크 캐시 항목입니다.

[in] lpszHeaderInfo

헤더 정보를 포함하는 버퍼에 대한 포인터입니다. 이 매개 변수가 NULL이 아닌 경우 헤더 정보는 INTERNET_CACHE_ENTRY_INFO 구조체의 lpHeaderInfo 멤버에 반환되는 URL의 확장 특성으로 처리됩니다.

[in] cchHeaderInfo

헤더 정보의 크기( TCHAR)입니다. lpHeaderInfoNULL이 아닌 경우 이 값은 헤더 정보를 저장하는 버퍼의 크기를 나타내는 것으로 간주됩니다. 애플리케이션은 데이터의 일부로 헤더를 유지하고 lpHeaderInfo 에 대한 NULL 값과 함께 cchHeaderInfo를 제공할 수 있습니다.

[in] lpszFileExtension

이 매개 변수는 예약되어 있으며 NULL이어야 합니다.

[in] lpszOriginalUrl

리디렉션이 발생한 경우 원래 URL이 포함된 문자열에 대한 포인터입니다.

반환 값

성공하면 TRUE를 반환하고 그렇지 않으면 FALSE를 반환합니다. 확장 오류 정보를 가져오려면 GetLastError를 호출합니다. 가능한 오류 값은 다음과 같습니다.

반환 코드 설명
ERROR_DISK_FULL
캐시 스토리지가 가득 찼습니다.
ERROR_FILE_NOT_FOUND
지정된 로컬 파일을 찾을 수 없습니다.

설명

STICKY_CACHE_ENTRY 형식은 캐시 항목을 청소에서 제외하는 데 사용됩니다. CommitUrlCacheEntryW를 사용하여 설정된 항목의 기본 제외 시간은 10분입니다. SetUrlCacheEntryInfo 함수 호출의 INTERNET_CACHE_ENTRY_INFO 구조에서 만료 시간 매개 변수를 설정하여 제외 시간을 변경할 수 있습니다.

캐시 스토리지가 가득 차면 CommitUrlCacheEntryW 는 캐시 정리를 호출하여 이 새 파일에 대한 공간을 만듭니다. 캐시 항목이 이미 있는 경우 함수는 사용하지 않는 경우 항목을 덮어씁니다. 항목은 RetrieveUrlCacheEntryStream 또는 RetrieveUrlCacheEntryFile과 함께 검색될 때 사용 중입니다.

캐시에 항목을 추가하는 클라이언트는 헤더를 "HTTP/1.0 200 OK\r\n\r\n" 이상으로 설정해야 합니다. 그렇지 않으면 Microsoft 인터넷 Explorer 및 기타 클라이언트 애플리케이션은 항목을 무시해야 합니다.

CreateUrlCacheEntryW를 호출하는 예제 코드는 캐싱을 참조하세요.

WinINet API의 다른 모든 측면과 마찬가지로 이 함수는 DllMain 내에서 또는 전역 개체의 생성자 및 소멸자에서 안전하게 호출할 수 없습니다.

참고 WinINet은 서버 구현을 지원하지 않습니다. 또한 서비스에서 사용하지 않아야 합니다. 서버 구현 또는 서비스의 경우 WinHTTP(Microsoft Windows HTTP 서비스)를 사용합니다.
 

참고

wininet.h 헤더는 COMMITUrlCacheEntry를 유니코드 전처리기 상수의 정의에 따라 이 함수의 ANSI 또는 유니코드 버전을 자동으로 선택하는 별칭으로 정의합니다. 인코딩 중립 별칭을 인코딩 중립이 아닌 코드와 혼합하면 컴파일 또는 런타임 오류가 발생하는 불일치가 발생할 수 있습니다. 자세한 내용은 함수 프로토타입에 대한 규칙을 참조하세요.

요구 사항

   
지원되는 최소 클라이언트 Windows 2000 Professional[데스크톱 앱만]
지원되는 최소 서버 Windows 2000 Server[데스크톱 앱만]
대상 플랫폼 Windows
헤더 wininet.h
라이브러리 Wininet.lib
DLL Wininet.dll

추가 정보

캐싱

WinINet 함수