Nota
L'accesso a questa pagina richiede l'autorizzazione. È possibile provare ad accedere o modificare le directory.
L'accesso a questa pagina richiede l'autorizzazione. È possibile provare a modificare le directory.
Rappresenta il metodo che gestirà un GlobalCustomNotification evento, che si verifica quando un modulo genera una notifica definita dall'utente.
Sintassi
virtual GLOBAL_NOTIFICATION_STATUS OnGlobalCustomNotification(
IN ICustomNotificationProvider* pProvider
);
Parametri
pProvider
[IN] Puntatore a un'interfaccia ICustomNotificationProvider .
Valore restituito
Valore GLOBAL_NOTIFICATION_STATUS .
Commenti
Quando un modulo globale è stato registrato per la notifica dell'evento GL_CUSTOM_NOTIFICATION , IIS chiamerà il metodo del OnGlobalCustomNotification modulo se viene generata una notifica personalizzata globale, ad esempio se un modulo chiama IHttpServer::NotifyCustomNotification.
Nota
I moduli globali possono registrarsi per la GlobalCustomNotification notifica dell'evento registrando per GL_CUSTOM_NOTIFICATION la funzione RegisterModule del modulo.
Esempio
Nell'esempio di codice seguente viene illustrato come creare un modulo HTTP che esegue le attività seguenti:
Registra per il GL_PRE_BEGIN_REQUEST e
GL_CUSTOM_NOTIFICATIONle notifiche.Crea una classe CGlobalModule contenente metodi OnGlobalPreBeginRequest e OnGlobalCustomNotification .
Il
OnGlobalPreBeginRequestmetodo scrive un evento nella Visualizzatore eventi che specifica la notifica corrente. Il metodo crea quindi un'istanza di un'interfacciaICustomNotificationProvidere genera la notifica personalizzata usando ilNotifyCustomNotificationmetodo .Il
OnGlobalCustomNotificationmetodo usa il metodo ICustomNotificationProvider::QueryNotificationType per recuperare l'identificatore univoco per la notifica personalizzata. Se l'identificatore univoco corrisponde, ilOnGlobalCustomNotificationmetodo scrive un evento nel Visualizzatore eventi che specifica che è stata generata la notifica personalizzata.
Rimuove la
CGlobalModuleclasse dalla memoria e quindi chiude.
#define _WINSOCKAPI_
#include <windows.h>
#include <sal.h>
#include <httpserv.h>
// Define the unique notification indentifier.
#define MY_CUSTOM_NOTIFICATION L"MyCustomNotification"
// Create a pointer for the global server interface.
IHttpServer * g_pHttpServer = NULL;
// Create the custom notification class.
class MyCustomProvider : public ICustomNotificationProvider
{
public:
// Create the method that will identify the custom notification.
PCWSTR QueryNotificationType(VOID)
{
// Return the unique identifier string for the custom notification.
return MY_CUSTOM_NOTIFICATION;
}
// Create the method that will process errors.
VOID SetErrorStatus(HRESULT hrError)
{
return;
}
};
// Create the module's global class.
class MyGlobalModule : public CGlobalModule
{
private:
// Create a handle for the Event Viewer.
HANDLE m_hEventLog;
// Create a pointer for the custom notification.
MyCustomProvider * m_pCustomProvider;
public:
MyGlobalModule()
{
// Open the global handle to the Event Viewer.
m_hEventLog = RegisterEventSource( NULL,"IISADMIN" );
// Initialize the pointer for the custom notification to NULL.
m_pCustomProvider = NULL;
}
~MyGlobalModule()
{
// Test whether the handle for the Event Viewer is open.
if (NULL != m_hEventLog)
{
// Close the handle to the event viewer.
DeregisterEventSource( m_hEventLog );
m_hEventLog = NULL;
}
// Test whether the pointer for the custom notification is valid.
if (NULL != m_pCustomProvider)
{
// Remove the custom notification from memory.
delete m_pCustomProvider;
m_pCustomProvider = NULL;
}
}
GLOBAL_NOTIFICATION_STATUS
OnGlobalPreBeginRequest(
IN IPreBeginRequestProvider * pProvider
)
{
// Create an array of strings.
LPCSTR szBuffer[2] = {"MyGlobalModule","OnGlobalPreBeginRequest"};
// Write the strings to the Event Viewer.
WriteEventViewerLog(szBuffer,2);
// Create the custom notification provider class.
MyCustomProvider * m_pCustomProvider = new MyCustomProvider;
// Test if the server and notification pointers are valid.
if ((NULL != m_pCustomProvider) && (NULL != g_pHttpServer))
{
// Raise the custom notification.
BOOL fCompletionExpected = TRUE;
g_pHttpServer->NotifyCustomNotification(m_pCustomProvider);
}
// Return processing to the pipeline.
return GL_NOTIFICATION_CONTINUE;
}
GLOBAL_NOTIFICATION_STATUS
OnGlobalCustomNotification(
IN ICustomNotificationProvider * pProvider
)
{
// Retrieve the custom notification type;
PCWSTR pNotificationType = pProvider->QueryNotificationType();
// Test if the custom notification is correct.
if (0 == wcscmp(pNotificationType,MY_CUSTOM_NOTIFICATION))
{
// Create an array of strings.
LPCSTR szBuffer[2] = {"MyGlobalModule","OnGlobalCustomNotification"};
// Write the strings to the Event Viewer.
WriteEventViewerLog(szBuffer,2);
}
// Return processing to the pipeline.
return GL_NOTIFICATION_CONTINUE;
}
VOID Terminate()
{
// Remove the class from memory.
delete this;
}
private:
// Create a method that writes to the Event Viewer.
BOOL WriteEventViewerLog(LPCSTR szBuffer[], WORD wNumStrings)
{
// Test whether the handle for the Event Viewer is open.
if (NULL != m_hEventLog)
{
// Write any strings to the Event Viewer and return.
return ReportEvent(
m_hEventLog,
EVENTLOG_INFORMATION_TYPE,
0, 0, NULL, wNumStrings,
0, szBuffer, NULL );
}
return FALSE;
}
};
// Create the module's exported registration function.
HRESULT
__stdcall
RegisterModule(
DWORD dwServerVersion,
IHttpModuleRegistrationInfo * pModuleInfo,
IHttpServer * pGlobalInfo
)
{
UNREFERENCED_PARAMETER( dwServerVersion );
UNREFERENCED_PARAMETER( pGlobalInfo );
// Create an HRESULT to receive return values from methods.
HRESULT hr;
// Store the pointer for the global server interface.
g_pHttpServer = pGlobalInfo;
// Create an instance of the global module class.
MyGlobalModule * pGlobalModule = new MyGlobalModule;
// Test for an error.
if (NULL == pGlobalModule)
{
return HRESULT_FROM_WIN32(ERROR_NOT_ENOUGH_MEMORY);
}
// Set the global notifications.
hr = pModuleInfo->SetGlobalNotifications(
pGlobalModule, GL_PRE_BEGIN_REQUEST | GL_CUSTOM_NOTIFICATION );
// Test for an error and exit if necessary.
if (FAILED(hr))
{
return hr;
}
// Return a success status;
return S_OK;
}
Il modulo deve esportare la funzione RegisterModule . È possibile esportare questa funzione creando un file di definizione del modulo (con estensione def) per il progetto oppure è possibile compilare il modulo usando l'opzione /EXPORT:RegisterModule . Per altre informazioni, vedere Procedura dettagliata: Creazione di un modulo HTTP Global-Level tramite codice nativo.
Facoltativamente, è possibile compilare il codice usando la __stdcall (/Gz) convenzione chiamante anziché dichiarare esplicitamente la convenzione chiamante per ogni funzione.
Requisiti
| Tipo | Descrizione |
|---|---|
| Client | - IIS 7.0 in Windows Vista - IIS 7.5 in Windows 7 - IIS 8.0 in Windows 8 - IIS 10.0 in Windows 10 |
| Server | - IIS 7.0 in Windows Server 2008 - IIS 7.5 in Windows Server 2008 R2 - IIS 8.0 in Windows Server 2012 - IIS 8.5 in Windows Server 2012 R2 - IIS 10.0 in Windows Server 2016 |
| Prodotto | - IIS 7.0, IIS 7.5, IIS 8.0, IIS 8.5, IIS 10.0 - IIS Express 7,5, IIS Express 8.0, IIS Express 10.0 |
| Intestazione | Httpserv.h |
Vedere anche
Classe CGlobalModule
Metodo IHttpServer::NotifyCustomNotification