Come cancellare la cache quando l'applicazione ospita un controllo WebBrowser in Visual C# .NET

Il presente articolo è stato tradotto tramite il software di traduzione automatica di Microsoft e non da una persona. Microsoft offre sia articoli tradotti da persone fisiche sia articoli tradotti automaticamente da un software, in modo da rendere disponibili tutti gli articoli presenti nella nostra Knowledge Base nella lingua madre dell’utente. Tuttavia, un articolo tradotto in modo automatico non è sempre perfetto. Potrebbe contenere errori di sintassi, di grammatica o di utilizzo dei vocaboli, più o meno allo stesso modo di come una persona straniera potrebbe commettere degli errori parlando una lingua che non è la sua. Microsoft non è responsabile di alcuna imprecisione, errore o danno cagionato da qualsiasi traduzione non corretta dei contenuti o dell’utilizzo degli stessi fatto dai propri clienti. Microsoft, inoltre, aggiorna frequentemente il software di traduzione automatica.

Clicca qui per visualizzare la versione originale in inglese dell’articolo: 326201
Questo articolo è stato archiviato. L’articolo, quindi, viene offerto “così come è” e non verrà più aggiornato.
Per la una versione di Microsoft Visual Basic .NET di questo articolo, vedere 311289.

In questo articolo si riferisce la spazio dei nomi Microsoft .NET Framework Class Library riportato di seguito:
  • System.Runtime.InteropServices

Contenuto dell'attività

Sommario
In questo articolo descrive come utilizzare funzioni WinInet application programming interface (API) per cancellare la cache direttamente.

Potrebbe essere necessario cancellare la cache a livello di codice quando l'applicazione ospita un controllo WebBrowser. Tuttavia, questa funzionalità non è disponibile tramite le interfacce del controllo WebBrowser.

back to the top

Funzioni WinInet

Per cancellare la cache direttamente, è possibile utilizzare le funzioni WinInet riportate di seguito:
  • Utilizzare la funzione FindFirstURLCacheEntry per trovare la prima voce della cache.
  • Utilizzare la funzione di FindNextUrlCacheEntry per enumerare la cache.
  • Utilizzare la funzione DeleteUrlCacheEntry per eliminare ogni voce.
L'esempio di codice in questo articolo utilizza tutte queste funzioni.

Nota : le funzioni disponibili solo con Microsoft Internet Explorer 5. Di conseguenza, è necessario includere i controlli appropriati, incluso l'esempio riportato di codice in questo articolo, per evitare errori.

back to the top

Procedura per cancellare la cache in Visual C# .NET

Per utilizzare le funzioni WinInet in Visual C# .NET per cancellare tutti i file nella cache, attenersi alla seguente procedura:
  1. Avviare Microsoft Visual Studio .NET.
  2. Scegliere Nuovo dal menu file , quindi progetto .
  3. Nella finestra di dialogo Nuovo progetto , fare clic su Progetti di Visual C# in Tipi progetto e scegliere Applicazione Console in modelli .
  4. Aggiungere il codice riportato di seguito alla classe Class1.cs:
    using System;using System.Runtime.InteropServices;// Visual C# version of Q326201namespace Q326201CS{    // Class for deleting the cache.    class DeleteCache    {        // For PInvoke: Contains information about an entry in the Internet cache        [StructLayout(LayoutKind.Explicit, Size=80)]        public struct INTERNET_CACHE_ENTRY_INFOA        {            [FieldOffset(0)]  public uint dwStructSize;            [FieldOffset(4)]  public IntPtr lpszSourceUrlName;            [FieldOffset(8)]  public IntPtr lpszLocalFileName;            [FieldOffset(12)] public uint CacheEntryType;            [FieldOffset(16)] public uint dwUseCount;            [FieldOffset(20)] public uint dwHitRate;            [FieldOffset(24)] public uint dwSizeLow;            [FieldOffset(28)] public uint dwSizeHigh;            [FieldOffset(32)] public FILETIME LastModifiedTime;            [FieldOffset(40)] public FILETIME ExpireTime;            [FieldOffset(48)] public FILETIME LastAccessTime;            [FieldOffset(56)] public FILETIME LastSyncTime;            [FieldOffset(64)] public IntPtr lpHeaderInfo;            [FieldOffset(68)] public uint dwHeaderInfoSize;            [FieldOffset(72)] public IntPtr lpszFileExtension;            [FieldOffset(76)] public uint dwReserved;            [FieldOffset(76)] public uint dwExemptDelta;        }        // For PInvoke: Initiates the enumeration of the cache groups in the Internet cache        [DllImport(@"wininet",            SetLastError=true,            CharSet=CharSet.Auto,            EntryPoint="FindFirstUrlCacheGroup",            CallingConvention=CallingConvention.StdCall)]        public static extern IntPtr FindFirstUrlCacheGroup(            int dwFlags,            int dwFilter,            IntPtr lpSearchCondition,            int dwSearchCondition,            ref long lpGroupId,            IntPtr lpReserved);        // For PInvoke: Retrieves the next cache group in a cache group enumeration        [DllImport(@"wininet",            SetLastError=true,            CharSet=CharSet.Auto,            EntryPoint="FindNextUrlCacheGroup",            CallingConvention=CallingConvention.StdCall)]        public static extern bool FindNextUrlCacheGroup(            IntPtr hFind,            ref long lpGroupId,            IntPtr lpReserved);        // For PInvoke: Releases the specified GROUPID and any associated state in the cache index file        [DllImport(@"wininet",             SetLastError=true,             CharSet=CharSet.Auto,             EntryPoint="DeleteUrlCacheGroup",             CallingConvention=CallingConvention.StdCall)]        public static extern bool DeleteUrlCacheGroup(            long GroupId,            int dwFlags,            IntPtr lpReserved);        // For PInvoke: Begins the enumeration of the Internet cache        [DllImport(@"wininet",            SetLastError=true,            CharSet=CharSet.Auto,            EntryPoint="FindFirstUrlCacheEntryA",            CallingConvention=CallingConvention.StdCall)]        public static extern IntPtr FindFirstUrlCacheEntry(            [MarshalAs(UnmanagedType.LPTStr)] string lpszUrlSearchPattern,            IntPtr lpFirstCacheEntryInfo,            ref int lpdwFirstCacheEntryInfoBufferSize);        // For PInvoke: Retrieves the next entry in the Internet cache        [DllImport(@"wininet",            SetLastError=true,            CharSet=CharSet.Auto,            EntryPoint="FindNextUrlCacheEntryA",            CallingConvention=CallingConvention.StdCall)]        public static extern bool FindNextUrlCacheEntry(            IntPtr hFind,            IntPtr lpNextCacheEntryInfo,            ref int lpdwNextCacheEntryInfoBufferSize);        // For PInvoke: Removes the file that is associated with the source name from the cache, if the file exists        [DllImport(@"wininet",            SetLastError=true,            CharSet=CharSet.Auto,            EntryPoint="DeleteUrlCacheEntryA",            CallingConvention=CallingConvention.StdCall)]        public static extern bool DeleteUrlCacheEntry(            IntPtr lpszUrlName);        [STAThread]        static void Main(string[] args)        {            // Indicates that all of the cache groups in the user's system should be enumerated            const int CACHEGROUP_SEARCH_ALL = 0x0;            // Indicates that all the cache entries that are associated with the cache group            // should be deleted, unless the entry belongs to another cache group.            const int CACHEGROUP_FLAG_FLUSHURL_ONDELETE = 0x2;            // File not found.            const int ERROR_FILE_NOT_FOUND = 0x2;            // No more items have been found.            const int ERROR_NO_MORE_ITEMS = 259;            // Pointer to a GROUPID variable            long groupId = 0;            // Local variables            int cacheEntryInfoBufferSizeInitial = 0;            int cacheEntryInfoBufferSize = 0;            IntPtr cacheEntryInfoBuffer = IntPtr.Zero;            INTERNET_CACHE_ENTRY_INFOA internetCacheEntry;            IntPtr enumHandle = IntPtr.Zero;            bool returnValue = false;            // Delete the groups first.            // Groups may not always exist on the system.            // For more information, visit the following Microsoft Web site:            // http://msdn.microsoft.com/library/?url=/workshop/networking/wininet/overview/cache.asp			            // By default, a URL does not belong to any group. Therefore, that cache may become            // empty even when the CacheGroup APIs are not used because the existing URL does not belong to any group.			            enumHandle = FindFirstUrlCacheGroup(0, CACHEGROUP_SEARCH_ALL, IntPtr.Zero, 0, ref groupId, IntPtr.Zero);            // If there are no items in the Cache, you are finished.            if (enumHandle != IntPtr.Zero && ERROR_NO_MORE_ITEMS == Marshal.GetLastWin32Error())                return;            // Loop through Cache Group, and then delete entries.            while(true)            {                // Delete a particular Cache Group.                returnValue = DeleteUrlCacheGroup(groupId, CACHEGROUP_FLAG_FLUSHURL_ONDELETE, IntPtr.Zero);                if (!returnValue && ERROR_FILE_NOT_FOUND == Marshal.GetLastWin32Error())                {	                    returnValue = FindNextUrlCacheGroup(enumHandle, ref groupId, IntPtr.Zero);                }                if (!returnValue && (ERROR_NO_MORE_ITEMS == Marshal.GetLastWin32Error() || ERROR_FILE_NOT_FOUND == Marshal.GetLastWin32Error()))                    break;            }            // Start to delete URLs that do not belong to any group.            enumHandle = FindFirstUrlCacheEntry(null, IntPtr.Zero, ref cacheEntryInfoBufferSizeInitial);            if (enumHandle == IntPtr.Zero && ERROR_NO_MORE_ITEMS == Marshal.GetLastWin32Error())                return;            cacheEntryInfoBufferSize = cacheEntryInfoBufferSizeInitial;            cacheEntryInfoBuffer = Marshal.AllocHGlobal(cacheEntryInfoBufferSize);            enumHandle = FindFirstUrlCacheEntry(null, cacheEntryInfoBuffer, ref cacheEntryInfoBufferSizeInitial);            while(true)            {                internetCacheEntry = (INTERNET_CACHE_ENTRY_INFOA)Marshal.PtrToStructure(cacheEntryInfoBuffer, typeof(INTERNET_CACHE_ENTRY_INFOA));		                cacheEntryInfoBufferSizeInitial = cacheEntryInfoBufferSize;                returnValue = DeleteUrlCacheEntry(internetCacheEntry.lpszSourceUrlName);				                if (!returnValue)                {	                    returnValue = FindNextUrlCacheEntry(enumHandle, cacheEntryInfoBuffer, ref cacheEntryInfoBufferSizeInitial);                }                if (!returnValue && ERROR_NO_MORE_ITEMS == Marshal.GetLastWin32Error())                {                    break;                }			                if (!returnValue && cacheEntryInfoBufferSizeInitial > cacheEntryInfoBufferSize)                {                    cacheEntryInfoBufferSize = cacheEntryInfoBufferSizeInitial;                    cacheEntryInfoBuffer = Marshal.ReAllocHGlobal(cacheEntryInfoBuffer, (IntPtr) cacheEntryInfoBufferSize);                    returnValue = FindNextUrlCacheEntry(enumHandle, cacheEntryInfoBuffer, ref cacheEntryInfoBufferSizeInitial);					                }            }            Marshal.FreeHGlobal(cacheEntryInfoBuffer);		        }    }}					
  5. Compilare ed eseguire quindi il progetto.
  6. Per verificare che siano stati eliminati i file temporanei Internet nella cache, attenersi alla seguente procedura in Microsoft Internet Explorer:
    1. Dal menu Strumenti scegliere Opzioni Internet .
    2. Nell'area file temporanei Internet nella scheda Generale , fare clic su Impostazioni .
    3. Fare clic su Visualizza file . Si noti che sono stati eliminati tutti i file nella cache di Internet Explorer.
back to the top
Riferimenti
L'esempio di codice in questo articolo viene utilizzato spazio dei nomi interoperabilità che fa parte il runtime di Visual Studio .NET. Per ulteriori informazioni, visitare il seguente sito Web MSDN (informazioni in lingua inglese): Per informazioni sullo sviluppo di Microsoft. NET, visitare il seguente sito Web MSDN: Per ulteriori informazioni sulla sintassi delle funzioni di memorizzazione nella cache di WinInet, visitare il seguente sito Web MSDN: Per ulteriori informazioni, fare clic sul numero dell'articolo della Microsoft Knowledge Base riportato di seguito riportato:
262110Come cancellare la cache quando l'applicazione ospita un controllo WebBrowser
Per ulteriori informazioni sullo sviluppo di soluzioni basate sul Web per Internet Explorer, visitare i seguenti siti Web (informazioni in lingua inglese):back to the top

Avviso: questo articolo è stato tradotto automaticamente

Proprietà

ID articolo: 326201 - Ultima revisione: 12/07/2015 11:48:34 - Revisione: 4.0

Microsoft Visual C# .NET 2002 Standard Edition

  • kbnosurvey kbarchive kbmt kbcaching kbcominterop kbhowto kbhowtomaster kbwebbrowser kbwininet KB326201 KbMtit
Feedback