建立HttpHandler并在web应用程序中注册
Posted on | 一月 3, 2010 | No Comments
(1)建立自己的HttpHandler
创建一个继承了System.Web.IHttpHandler接口的类,在System.Web.IHttpHandler接口只有两个成员
1 IsReusable 属性,其返回一个值代表其他http请求是否可以使用当前继承了 System.Web.IHttpHander接口的类的实例。
2 ProcessRequest(System.Web.HttpContext context) 方法,除了用户自定义中被要求处理的特殊的http请求。
其中的参数 System.Web.HttpContext 类的实例装入了一个http请求中http协议中要求的所有信息。其中System.Web.HttpContext 类中包含有属性 Request 使得从客户端发送过来的http请求信息的值可以被方便地读取;属性Response ,其中封装了需要返回给客户端的信息和操作。当然还有许多常用的属性和方法,在此就不详述了,我们这里只用到这两个属性。
(2)web应用程序中注册自定义的HttpHandler
在 Web.config这个网络应用程序配置文件中加入注册信息
<httpHandlers>
<add verb = ” path = “*.jpg” type = “自定义handler的类的名称,网络应用程序名称” />
</httpHandlers>
4 那么我们看看在ProcessRequest(System.Web.HttpContext context)方法是如何对请求图片文件的http请求进行处理的。
public void ProcessRequest(System.Web.HttpContext context)
{
if(context.Request.UrlReferrer.Host == “www.frontfree.net”)//判断是否是本地引用,如果是则返回给客户端正确的图片,这里的判断就是用到了前面所述的http请求中所记路的参考页信息
{
context.Response.Expires = 0;//设置客户端缓冲中文件过期时间为0,即立即过期。
context.Response.Clear();//清空服务器端为此会话开辟的输出缓存
context.Response.ContentType = getContentType(context.Request.PhysicalPath); //获得文件类型
context.Response.WriteFile(context.Request.PhysicalPath);//将请求文件写入到服务器端为此会话开辟的输出缓存中
context.Response.End();//将服务器端为此会话开辟的输出缓存中的信息传送到客户端
}
Else //如果不是本地引用,则属于盗链引用,返回给客户端错误的图片
{
context.Response.Expires = 0; //设置客户端缓冲中文件过期时间为0,即立即过期。
context.Response.Clear();//清空服务器端为此会话开辟的输出缓存
context.Response.ContentType = getContentType(“error.jpg”); //获得文件类型
context.Response.WriteFile(“error.jpg”);//将特殊的报告错误的图片文件写入到服务器端为此会话开辟的输出缓存中
context.Response.End();//将服务器端为此会话开辟的输出缓存中的信息传送到客户端
}
}
相关文章:
- ASP.NET的SEO使用.ashx文件——排除重复内容[zz]
- ASP.NET的sitemap和RSS
- 一级域名和二级域名跨域的解决方案
- 大文件上传 进度条显示
- HttpModule,HttpHandler,HttpHandlerFactory简单使用
评论|Comments
留言|Leave a Reply


![如果您自认为是一位忠实的Silverlight-Fans,那么请将此标志放到您的博客中成为一名真正的[银光使者]](http://images.cnblogs.com/cnblogs_com/alamiye010/Silverlighter1.jpg)