目前,我有以下操作从我的数据库返回文件(图像,PDF等):
// // GET: /FileManager/GetFile/ID [OutputCache(Duration = 600,varyByParam = "ID")] public ActionResult GetFile(int ID) { FileService svc = new FileService(new sqlFileRepository(base.ConnectionString)); KsisOnline.Data.File result = svc.GetFileByID(ID); return File(result.Data,result.MimeType,result.UploadFileName); }
我正在使用OutputCache属性,但我不知道我是否正确使用它或如何为此目的优化它.
正如代码所示,我似乎在Firefox(3)中获得了缓存功能,但不是IE(7).出于某种原因,IE每次都要从DB请求图像(这显然是杀手很糟糕),我不知道如何修复它.当然IE不能正确支持标准,但我可能仍然没有遵循一些首选的缓存约定.我真的很感激一些帮助,所以我得到最小的数据库命中和缓存支持跨浏览器.
解决方法
您需要使用
Fiddler来查看IE和您的应用程序发送的HTTP标头与Firefox的标头有何不同.您必须拥有的是使浏览器发送If-Modified-Since标头(可能还有ETag)标头,您的应用程序应响应HTTP 302状态.
原文地址:https://www.jb51.cc/aspnet/247163.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。