前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >消除图片在ie中缓存而无法更新的问题

消除图片在ie中缓存而无法更新的问题

作者头像
Java架构师必看
发布2020-10-16 10:46:54
8420
发布2020-10-16 10:46:54
举报
文章被收录于专栏:Java架构师必看Java架构师必看

程序中图片是动态显示的原先把打算把图片保存在服务器端然后显示可是由于ie的缓存问题导致图片无法实时更网络

程序中图片是动态显示的

原先把打算把图片保存在服务器端然后显示

可是由于ie的缓存问题导致图片无法实时更新显示

所以改为把图片存在session中然后再显示

需要保存的时候再保存到本地

//--------------chart.ashx.cs-------------------

using System; using System.Web.SessionState; using System.IO; using System.Web;

namespace WebApplication3 {  /// <summary>  /// chart 的摘要说明。  /// </summary>  public class ChartHandler : IHttpHandler, IReadOnlySessionState  {   public bool IsReusable   {    get { return true; }   }   public void ProcessRequest (HttpContext ctx)   {    string chartID = ctx.Request.QueryString[0];    Array arr = (Array) ctx.Session [chartID];

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

   MemoryStream memStream = new MemoryStream ((byte[])arr);    memStream.WriteTo (ctx.Response.OutputStream);    memStream.Close ();

   ctx.Response.ContentType = "image/gif";    ctx.Response.StatusCode = 400;    ctx.Response.End ();

  }  } }

   //--------------chart.ashx   只需要如下一行---------------

<% @ WebHandler language="C#" class="WebApplication3.ChartHandler" codebehind="chart.ashx.cs" %>

//WebApplication3为命名空间

//ChartHandler为chart.ashx.cs中类的名字 

//--------------调用说明-----------------

//需要把图片存到byte数组中 假设为byteArr  则

   // ------------------------------------------------------------------------    //把图片储存在session里面    // ------------------------------------------------------------------------    HttpContext     ctx = HttpContext.Current;    string          chartID = Guid.NewGuid ().ToString ();    ctx.Session [chartID] = byteArr;    Image1.ImageUrl = string.Concat ("chart.ashx?", chartID);

补充说明:

以 ashx 为扩展名的文件是HTTP handlers ,SimpleHandlerFactory 事件工厂知道如何编译该文件,并实例化IHttpHandler 接口,不需要配置web.config也不需要更新IIS的扩展名映射

本文由来源 21aspnet,由 system_mush 整理编辑,其版权均为 21aspnet 所有,文章内容系作者个人观点,不代表 Java架构师必看 对观点赞同或支持。如需转载,请注明文章来源。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档