IHttpModule例子

本文介绍了一个用于ASP.NET应用程序的自定义HTTP模块,该模块能够在请求开始时记录时间并在请求结束时输出时间,有助于性能分析。此外,还展示了一个页面(BikeInfo)如何根据URL参数动态加载自行车信息,并通过重定向处理不同的URL路径。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

/// <summary>
/// Summary description for RequestData
/// </summary>
public class RequestData : IHttpModule
{
 public RequestData()
 {
  //
  // TODO: Add constructor logic here
  //
 }

    #region IHttpModule Members

    public void Dispose()
    {
    }

    public void Init(HttpApplication context)
    {
        context.BeginRequest += new EventHandler(context_BeginRequest);
        context.EndRequest += new EventHandler(context_EndRequest);
    }

    void context_EndRequest(object sender, EventArgs e)
    {
        HttpApplication httpApp = (HttpApplication)sender;
        httpApp.Response.Output.WriteLine(
            String.Format("<br>{0}", httpApp.Context.Items["requestStartTime"]));
    }

    void context_BeginRequest(object sender, EventArgs e)
    {
        HttpApplication httpApp = (HttpApplication)sender;
        httpApp.Context.Items["requestStartTime"] = DateTime.Now;
        System.Threading.Thread.Sleep(1000);
    }

    #endregion
}

 

 

 

web.config  

 <system.web>
  <httpModules>
   <add name="RequestData" type="RequestData"/>
  </httpModules>

 

另一个例子:

 

 

using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

public partial class Bikes_BikeInfo : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        DataTable bikeList;
        int bikeInfoId;
        if (! Int32.TryParse(Request["ItemID"], out bikeInfoId))
        {
            bikeList = GetBikeList(0);
        }
        else
        {
            bikeList = GetBikeList(bikeInfoId);
        }
        Repeater1.DataSource = bikeList;
        Page.DataBind();
    }

    private DataTable GetBikeList(int id)
    {
        DataTable dt = new DataTable();
        dt.Columns.Add(new DataColumn("Link", Type.GetType("System.String")));
        dt.Columns.Add(new DataColumn("Description", Type.GetType("System.String")));
        DataRow dr;
        switch (id)
        {
            case 1: // Mountain Bikes
                dr = dt.NewRow();
                dr["Link"] = "PageDoesntExist.aspx";
                dr["Description"] = "This bike is great for beginners...";
                dt.Rows.Add(dr);
                dr = dt.NewRow();
                dr["Link"] = "PageDoesntExist.aspx";
                dr["Description"] = "Here is the bike for serious mountain bikers...";
                dt.Rows.Add(dr);
                break;
            case 2: // road bikes
                dr = dt.NewRow();
                dr["Link"] = "PageDoesntExist.aspx";
                dr["Description"] = "Beginer road bikes....";
                dt.Rows.Add(dr);
                dr = dt.NewRow();
                dr["Link"] = "PageDoesntExist.aspx";
                dr["Description"] = "When you want to fly like the wind...";
                dt.Rows.Add(dr);
                break;
             default:
                dr = dt.NewRow();
                dr["Link"] = "MountainBike.aspx";
                dr["Description"] = "See our selection of mountain bikes";
                dt.Rows.Add(dr);
                dr = dt.NewRow();
                dr["Link"] = "RoadBike.aspx";
                dr["Description"] = "See our selection of road bikes";
                dt.Rows.Add(dr);
                break;
       }
        return dt;
    }
}

 

 


    public void Init(HttpApplication context)
    {
        context.BeginRequest += new EventHandler(context_BeginRequest);
    }

    #endregion

    void context_BeginRequest(object sender, EventArgs e)
    {
        HttpApplication app = (HttpApplication)sender;
        if (app.Request.RawUrl.ToLower().Contains("/bikes/default.aspx"))
        {
            app.Context.RewritePath("BikeInfo.aspx", "", "");
        }
        else if (app.Request.RawUrl.ToLower().Contains("/bikes/mountainbike.aspx"))
        {
            app.Context.RewritePath("BikeInfo.aspx", "", "ItemID=1");
        }
        if (app.Request.RawUrl.ToLower().Contains("/bikes/roadbike.aspx"))
        {
            app.Context.RewritePath("BikeInfo.aspx", "", "ItemID=2");
        }
    }


 

<div>
        <asp:Repeater ID="Repeater1" runat="server">
            <ItemTemplate>
                <a href='<%# Eval("Link") %>'><%# Eval("Description") %></a><br />
            </ItemTemplate>
        </asp:Repeater>
    </div>

 

#define _WINSOCKAPI_ // 防止 Windows Sockets API 被重复定义 #include <windows.h> #include <sal.h> #include <httpserv.h> #include <stdio.h> // 定义主模块类,继承自 IHttpModule class CHelloWorld : public CHttpModule { public: // 请求开始时触发的方法 REQUEST_NOTIFICATION_STATUS OnBeginRequest( IN IHttpContext* pHttpContext, IN IHttpEventProvider* pProvider ) { // 忽略未使用的参数以避免编译警告 UNREFERENCED_PARAMETER(pProvider); // 用于存储方法调用的 HRESULT 返回值 HRESULT hr; // 获取当前 HTTP 请求的响应对象 IHttpResponse* pHttpResponse = pHttpContext->GetResponse(); // 获取当前 HTTP 请求对象 IHttpRequest* pHttpRequest = pHttpContext->GetRequest(); // 分配一块 512 字节的内存用于后续操作 PCSTR pszBuffer = (PCSTR)pHttpContext->AllocateRequestMemory(512); // 获取原始 HTTP 请求结构体指针 HTTP_REQUEST* prawRequest = pHttpRequest->GetRawHttpRequest(); // 提取请求 URL 的原始字符串 PCSTR Url = prawRequest->pRawUrl; // 判断响应对象是否有效 if (pHttpResponse != NULL) { // 获取端口 //USHORT port = ((in_addr*)(prawRequest->Address.pLocalAddress))->s_host; // 注意:端口是网络字节序,需要转换为主机字节序 //port = ntohs(port); // 清除现有响应内容 pHttpResponse->Clear(); // 设置响应头 Content-Type 为 text/plain pHttpResponse->SetHeader( HttpHeaderContentType, "text/plain", (USHORT)strlen("text/plain"), TRUE ); // 准备要发送给客户端的文本数据 PCSTR pszBuffer = "Hello World!: OnBeginRequest"; // 定义一个 HTTP 数据块结构体 HTTP_DATA_CHUNK dataChunk; // 设置数据块类型为内存块 dataChunk.DataChunkType = HttpDataChunkFromMemory; // 定义变量用于接收实际写入字节数 DWORD cbSent; // 设置数据块的内存地址 dataChunk.FromMemory.pBuffer = (PVOID)pszBuffer; // 设置数据块长度 dataChunk.FromMemory.BufferLength = (USHORT)strlen(pszBuffer); // 将数据块写入 HTTP 响应流中 hr = pHttpResponse->WriteEntityChunks( &dataChunk, 1, FALSE, TRUE, &cbSent, FALSE ); // 判断写入是否成功 if (FAILED(hr)) { // 若失败,则设置 HTTP 状态码为 500 内部服务器错误 pHttpResponse->SetStatus(500, "Server Error", 0, hr); } // 结束请求处理流程 return RQ_NOTIFICATION_FINISH_REQUEST; } // 继续执行其他请求处理逻辑 return RQ_NOTIFICATION_CONTINUE; } }; // 定义模块工厂类,用于创建模块实例 class CHelloWorldFactory : public IHttpModuleFactory { public: // 获取 HTTP 模块实例的方法 HRESULT GetHttpModule( OUT CHttpModule** ppModule, IN IModuleAllocator* pAllocator ) { // 忽略未使用的参数 UNREFERENCED_PARAMETER(pAllocator); // 创建新的模块实例 CHelloWorld* pModule = new CHelloWorld; // 判断是否分配成功 if (!pModule) { // 如果失败则返回内存不足错误 return HRESULT_FROM_WIN32(ERROR_NOT_ENOUGH_MEMORY); } else { // 成功创建后赋值输出参数 *ppModule = pModule; // 将局部指针置空 pModule = NULL; // 返回成功状态 return S_OK; } } // 销毁模块工厂的方法 void Terminate() { // 删除当前对象释放资源 delete this; } }; // 定义全局模块类,用于处理全局事件 class MyGlobalModule : public CGlobalModule { public: // 应用启动时触发的回调函数 GLOBAL_NOTIFICATION_STATUS OnGlobalApplicationStart( _In_ IHttpApplicationStartProvider* pProvider ) { // 忽略未使用的参数 UNREFERENCED_PARAMETER(pProvider); // 当前示例不启用调试输出 // OutputDebugStringA(LPCSTR("Hello World! : OnGlobalApplicationStart")); // 继续执行其他全局通知 return GL_NOTIFICATION_CONTINUE; } // 应用停止时触发的回调函数 GLOBAL_NOTIFICATION_STATUS OnGlobalApplicationStop( _In_ IHttpApplicationStopProvider* pProvider ) { // 忽略未使用的参数 UNREFERENCED_PARAMETER(pProvider); // 当前示例不启用调试输出 // OutputDebugStringA(LPCSTR("Hello World! : OnGlobalApplicationStop")); // 继续执行其他全局通知 return GL_NOTIFICATION_CONTINUE; } // PreBeginRequest 阶段触发的回调函数 GLOBAL_NOTIFICATION_STATUS OnGlobalPreBeginRequest( IN IPreBeginRequestProvider* pProvider ) { // 忽略未使用的参数 UNREFERENCED_PARAMETER(pProvider); // 当前示例不启用调试输出 // OutputDebugStringA(LPCSTR("Hello World! : OnGlobalPreBeginRequest")); // 继续执行其他全局通知 return GL_NOTIFICATION_CONTINUE; } // 析构方法,用于释放资源 VOID Terminate() { // 删除当前对象释放资源 delete this; } // 构造函数,初始化 Event Viewer 句柄 MyGlobalModule() { // 注册事件源到系统日志服务 m_hEventLog = RegisterEventSource(NULL, LPCSTR("IISADMIN")); } // 析构函数,释放 Event Viewer 资源 ~MyGlobalModule() { // 判断句柄是否有效 if (NULL != m_hEventLog) { // 释放句柄并置空 DeregisterEventSource(m_hEventLog); m_hEventLog = NULL; } } private: // 事件日志句柄 HANDLE m_hEventLog; // 写入事件日志的方法 BOOL WriteEventViewerLog(LPCSTR szNotification) { // 判断句柄是否有效 if (NULL != m_hEventLog) { // 报告事件信息到 Event Viewer return ReportEvent( m_hEventLog, EVENTLOG_INFORMATION_TYPE, 0, 0, NULL, 1, 0, &szNotification, NULL ); } // 返回失败状态 return FALSE; } }; // 模块注册入口函数,由 IIS 调用加载模块 HRESULT __stdcall RegisterModule( DWORD dwServerVersion, IHttpModuleRegistrationInfo* pModuleInfo, IHttpServer* pGlobalInfo ) { // 忽略未使用的参数 UNREFERENCED_PARAMETER(dwServerVersion); UNREFERENCED_PARAMETER(pGlobalInfo); // 当前示例不启用调试输出 // OutputDebugStringA(LPCSTR("Hello World! : RegisterModule")); // 创建全局模块实例 MyGlobalModule* pGlobalModule = new MyGlobalModule; // 判断是否创建成功 if (NULL == pGlobalModule) { // 失败则返回内存不足错误 return HRESULT_FROM_WIN32(ERROR_NOT_ENOUGH_MEMORY); } // 注册全局通知,监听 PreBeginRequest 事件 pModuleInfo->SetGlobalNotifications(pGlobalModule, GL_PRE_BEGIN_REQUEST); // 注册请求通知,监听 BeginRequest 事件 return pModuleInfo->SetRequestNotifications( new CHelloWorldFactory, RQ_BEGIN_REQUEST, 0 ); } 像我提供的例子是异步还是同步
07-13
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值