目前我有以下操作从我的数据库返回文件(图像,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不能正确支持标准,但我可能仍然没有遵循一些首选的缓存约定。我真的很感激一些帮助,所以我得到最小的数据库命中和缓存支持跨浏览器。
修改 要查看上面的代码或使用浏览器/工具自行配置代码,请参阅this link。
答案 0 :(得分:4)
尝试使用ServerAndClient位置:
[OutputCache(Duration = 600,VaryByParam =“ID”,Location = OutputCacheLocation.ServerAndClient)]
答案 1 :(得分:2)
您需要使用Fiddler来查看IE和您的应用程序发送的HTTP标头与Firefox的标头有何不同。您必须拥有的是让浏览器发送If-Modified-Since
标头(可能还有ETag
)标头,您的应用应以HTTP 302状态响应。
答案 2 :(得分:0)
ControllerContext.HttpContext.Response.ClearHeaders()