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

ASP.NET
asp.net css注释的影响
ASP.NET与数据库相关技巧
关于HtmlForm控件
三色交替的下拉列表框
精通ASP.NET中弹出窗口技术
ASP.NET Forums与现有系统整合方案示例
ASP.NET操作IIS中的虚拟目录
DataGrid与SQL Server 2000数据绑定
如何让Web应用程序在Client端实现导出报表功能
如何保证web app中的Send Email线程稳定性
关于用ASP.Net识别远程主机服务器种类
ASP.NET中上传下载文件
提高ASP.NET性能的方法
asp.net StreamReader 创建文件
asp.net如何生成图片验证码(简单)
一个.net 压缩位图至JPEG的代码
简单的SQL Server数据库数据读取与数据操作
获取网站的RSS聚合到自己的网页
.Net程序中整站通用的防SQL注入函数
asp.net生成缩略图及给原始图加水印的函数

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 63 ::
收藏到网摘: 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();

}
}
}