当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > 用ashx动态生成文件

ASP.NET
asp.net Linq TO Sql 分页方法
asp.net 用XML生成放便扩展的自定义树
asp.ent下合并两个结构相同的DataTable
asp.net 遍历repeater中的控件的几种方式
asp.net 处理原文件中过长的viewstate代码
asp.net下遍历页面中所有的指定控件的代码
获取创建Membership的数据库创建脚本
asp.net AJAX注册类
asp.net 处理F5刷新页面重复提交页面的一个思路
ASP.NET 缓存分析和实践浅析提高运行效率
asp.net 读取并显示excel数据的实现代码
ASP.NET中常用的用来输出JS脚本的类
ASP.NET中内嵌页面代码的一个问题
asp.net(C#)操作excel(上路篇)
一个基于Asp.Net MVC的权限方案
ASP.NET实例教程:51job网站地区选择功能
ASP.NET教程:友好的Html和JS适合SEO
ASP.NET教程:使用.ashx文件去除重复内容
ASP.NET做SEO:制作架构清晰和更新及时的网站地图
ASP.NET优化:Sql注入和Html注入的黑帽SEO

ASP.NET 中的 用ashx动态生成文件


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 78 ::
收藏到网摘: n/a

大概去年九月的时候,做一个功能就是生成图片,当然有很多方法,生成图片放在服务器的某个目录下面,隔一段时间就删除,图还得自己画,嫌麻烦,结果找着这样一段代码,今天看到使用.ashx文件处理IHttpHandler实现发送文本及二进制数据的方法。突然发现这种用法讨论的很好,也许是没怎么详细介绍它的官方中文文档吧,并且推荐另外一种方法代替。

//----------------------------------------
//Pickyourfavoriteimageformat
//------------------------------
byte[]byteArr=(byte[])oChartSpace.GetPicture("png",500,500);
//----------------------------------------
//StorethechartimageinSessiontobepickedupbyanHttpHandlerlater
//---------------------------------------
HttpContextctx=HttpContext.Current;
stringchartID=Guid.NewGuid().ToString();

ctx.Session[chartID]=byteArr;
imgHondaLineup.ImageUrl=string.Concat("chart.ashx?",chartID);

chart.ashx里面就下面一句话

<%@WebHandlerlanguage="C#"class="AspNetResources.Owc.ChartHandler"codebehind="chart.ashx.cs"%>

其实也可以用这个代替

在web.config里面的<system.web>里面加上

<httpHandlers>
<addverb="*"path="*.ashx"type="AspNetResources.Owc,ChartHandler"validate="false"/>/*ChartHandler是那个ashx.cs编译后生成的代码Assembly*/

<!--Sincewearegrabbingallrequestsafterthis,makesureError.aspxdoesnotrelyon.Text-->
<addverb="*"path="Error.aspx"type="System.Web.UI.PageHandlerFactory"/>

</httpHandlers>

具体使用哪个都无所谓,后一种配置好了就方便一些,不用管路径了,其实这个思想的应用比较知名的在.text里面就已经有了,只不过应用的方向不同。

ashx.cs文件的代码

usingSystem;
usingSystem.Web.SessionState;
usingSystem.IO;
usingSystem.Web;

namespaceAspNetResources.Owc
{
publicclassChartHandler:IHttpHandler,IReadOnlySessionState
{
publicboolIsReusable
{
get{returntrue;}
}

publicvoidProcessRequest(HttpContextctx)
{
stringchartID=ctx.Request.QueryString[0];
Arrayarr=(Array)ctx.Session[chartID];

ctx.ClearError();
ctx.Response.Expires=0;
ctx.Response.Buffer=true;
ctx.Response.Clear();

MemoryStreammemStream=newMemoryStream((byte[])arr);
memStream.WriteTo(ctx.Response.OutputStream);
memStream.Close();

ctx.Response.ContentType="image/png";
ctx.Response.StatusCode=200;
ctx.Response.End();

}
}
}