次の方法で共有


RetrieveUrlCacheEntryFileW 関数 (wininet.h)

指定した URL に関連付けられているキャッシュ エントリ ファイルをロックします。

構文

BOOL RetrieveUrlCacheEntryFileW(
  [in]      LPCWSTR                      lpszUrlName,
  [out]     LPINTERNET_CACHE_ENTRY_INFOW lpCacheEntryInfo,
  [in, out] LPDWORD                      lpcbCacheEntryInfo,
  [in]      DWORD                        dwReserved
);

パラメーター

[in] lpszUrlName

キャッシュ エントリに関連付けられているリソースの URL を含む文字列へのポインター。 これは一意の名前である必要があります。 名前文字列にはエスケープ文字を含めないようにしてください。

[out] lpCacheEntryInfo

キャッシュ エントリ情報バッファーへのポインター。 バッファーが十分でない場合、この関数はERROR_INSUFFICIENT_BUFFERを返し、lpdwCacheEntryInfoBufferSize 必要なバイト数に設定します。

[in, out] lpcbCacheEntryInfo

lpCacheEntryInfo バッファーのサイズをバイト単位で指定する符号なし長整数変数へのポインター。 関数が戻るときに、変数には、使用される実際のバッファーのサイズ (バイト単位) またはキャッシュ エントリ ファイルの取得に必要なバイト数が含まれます。 呼び出し元は、このパラメーターの戻り値を確認する必要があります。 戻り値のサイズが渡されたサイズ以下の場合は、関連するすべてのデータが返されます。

[in] dwReserved

このパラメーターは予約済みであり、0 である必要があります。

戻り値

成功した場合 TRUE を返し、それ以外の場合は FALSE 返します。 拡張エラー情報を取得するには、GetLastError呼び出します。 考えられるエラー値は次のとおりです。

リターン コード 形容
ERROR_FILE_NOT_FOUND
ソース名で指定されたキャッシュ エントリがキャッシュ ストレージに見つかりません。
ERROR_INSUFFICIENT_BUFFER
lpdwCacheEntryInfoBufferSize で指定されている lpCacheEntryInfo バッファーのサイズが、すべての情報を含むのに十分ではありません。 lpdwCacheEntryInfoBufferSize で返される値は、すべての情報を取得するために必要なバッファー サイズを示します。

備考

RetrieveUrlCacheEntryFile は URL 解析を行わないので、リソースがキャッシュされている場合でも、アンカー (#) を含む URL はキャッシュに見つかりません。 たとえば、URL http://adatum.com/example.htm#sample が渡された場合、http://adatum.com/example.htm がキャッシュ内にある場合でも、関数はERROR_FILE_NOT_FOUNDを返します。

ファイルは、取得時に呼び出し元に対してロックされます。呼び出し元は、呼び出し元がファイルで完了した後、ファイルのロックを解除する必要があります。 キャッシュ マネージャーは、一定の間隔後にファイルのロックを自動的に解除します。 ファイルがロックされている間、キャッシュ マネージャーはキャッシュからファイルを削除しません。 キャッシュの内部実装によっては、この関数が効率的に実行される場合と実行されない場合があることに注意してください。 たとえば、URL データが他の URL のデータを含むパック されたファイルに格納されている場合、キャッシュはキャッシュによって管理されている一時ディレクトリ内のファイルにデータのコピーを作成します。 キャッシュは最終的にコピーを削除します。 この関数は、アプリケーションを起動するためにファイル名が必要な場合にのみ使用することをお勧めします。 RetrieveUrlCacheEntryStream および関連するストリーム関数は、ほとんどの場合に使用する必要があります。

WinINet API の他のすべての側面と同様に、この関数は DllMain またはグローバル オブジェクトのコンストラクターとデストラクターから安全に呼び出すことはできません。

注意 WinINet では、サーバーの実装はサポートされていません。 また、サービスから使用しないでください。 サーバーの実装またはサービスの場合は、Microsoft Windows HTTP Services (WinHTTP)を使用します。
 

手記

wininet.h ヘッダーは、Unicode プリプロセッサ定数の定義に基づいて、この関数の ANSI または Unicode バージョンを自動的に選択するエイリアスとして RetrieveUrlCacheEntryFile を定義します。 エンコードに依存しないエイリアスをエンコードに依存しないコードと組み合わせて使用すると、コンパイルエラーやランタイム エラーが発生する不一致が発生する可能性があります。 詳細については、「関数プロトタイプの 規則」を参照してください。

必要条件

要件 価値
サポートされる最小クライアント Windows 2000 Professional [デスクトップ アプリのみ]
サポートされる最小サーバー Windows 2000 Server [デスクトップ アプリのみ]
ターゲット プラットフォーム の ウィンドウズ
ヘッダー wininet.h
ライブラリ Wininet.lib
DLL Wininet.dll

関連項目

キャッシュ

WinINet Functions の