目前,我有以下操作从我的数据库返回文件(图像,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状态.