ASP.NET笔记之 Httphandler的操作详解
1、httphandler

实例1:通过生成一张动态图片输出客户端的IP地址、操作系统类型、浏览器类型
<%@ WebHandler Language="C#" Class="visitor" %>
using System;
using System.Web;
public class visitor : IHttpHandler {
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "image/JPEG";
using (System.Drawing.Bitmap bitImage = new System.Drawing.Bitmap(330, 300))
{
//设置画布
using (System.Drawing.Graphics g = System.Drawing.Graphics.FromImage(bitImage))
{
//IP
g.DrawString("IP:" + context.Request.UserHostAddress, new System.Drawing.Font("宋体", 20), System.Drawing.Brushes.Red, new System.Drawing.PointF(0, 0));
//操作系统
g.DrawString("操作系统:" + context.Request.Browser.Platform, new System.Drawing.Font("宋体", 20), System.Drawing.Brushes.Red, new System.Drawing.PointF(0, 50));
//浏览器
g.DrawString("浏览器:" + context.Request.Browser.Type, new System.Drawing.Font("宋体", 20), System.Drawing.Brushes.Red, new System.Drawing.PointF(0, 100));
}
//保存到输出流中
bitImage.Save(context.Response.OutputStream, System.Drawing.Imaging.ImageFormat.Jpeg);
}
}
public bool IsReusable {
get {
return false;
}
}
}
实例2:通过“下载”连接,弹出用户附件保存
html代码:<a href="dowload.ashx">下载</a>
<%@ WebHandler Language="C#" Class="dowload" %>
using System;
using System.Web;
public class dowload : IHttpHandler {
public void ProcessRequest(HttpContext context)
{
string fileName = HttpUtility.UrlEncode("悲剧.jpg");
context.Response.ContentType = "image/JPEG";
//打开附件对话框 报文头header和设置它的值
context.Response.AddHeader("Content-Disposition", "attachment:filename=" + fileName);
context.Response.WriteFile("苹果.jpg");
}
public bool IsReusable {
get {
return false;
}
}
}
相关文章
ASP.NET Core读取Request.Body的正确方法
相信大家在使用ASP.NET Core进行开发的时候,肯定会涉及到读取Request.Body的场景,毕竟我们大部分的POST请求都是将数据存放到Http的Body当中,本文就介绍一下ASP.NET Core读取Request.Body,感兴趣的可以了解一下2021-05-05
关于.NET Framework中的设计模式--应用策略模式为List排序
本篇文章,小编将为大家介绍关于.NET Framework中的设计模式--应用策略模式为List排序,有需要的朋友可以参考一下2013-04-04
利用Asp.Net Core的MiddleWare思想如何处理复杂业务流程详解
这篇文章主要给大家介绍了关于利用Asp.Net Core的MiddleWare思想如何处理复杂业务流程的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起看看吧2018-08-08


最新评论