我的自定义RouteBase
实施和[OutputCache]
存在问题。
我们有一个CMS,其中URL被映射到某些内容页面。每种类型的内容页面由不同的控制器(和不同的视图)处理。网址是完全免费的,我们需要不同的控制器,因此“catchall”路由不可用。因此,我们构建了一个自定义RouteBase实现,该实现调用数据库来查找所有URL。数据库知道要使用哪个Controller和Action(基于内容页面类型)。
这很有用。
但是,将此与[OutputCache]属性相结合,输出缓存不起作用(页面仍然有效)。我们确保[OutputCache]适用于我们的“普通”路由。
调试输出缓存是非常困难的,属性就在那里我们使用它,它不起作用...如何正确处理这个想法会非常受欢迎,正确答案也是如此!
控制器如下所示:
public class TextPageController : BaseController
{
private readonly ITextPageController textPageController;
public TextPageController(ITextPageController textPageController)
{
this.textPageController = textPageController;
}
[OutputCache(Duration = 300)]
public ActionResult TextPage(string pageid)
{
var model = textPageController.GetPage(pageid);
return View(model);
}
}
自定义路线如下所示:
public class CmsPageRoute : RouteBase
{
private IRouteService _routeService;
private Dictionary<string, RouteData> _urlsToRouteData;
public CmsPageRoute(IRouteService routeService)
{
this._routeService = routeService;
this.SetCmsRoutes();
}
public void SetCmsRoutes()
{
var urlsToRouteData = new Dictionary<string, RouteData>();
foreach (var route in this._routeService.GetRoutes()) // gets RouteData for CMS pages from database
{
urlsToRouteData.Add(route.Url, PrepareRouteData(route));
}
Interlocked.Exchange(ref _urlsToRouteData, urlsToRouteData);
}
public override RouteData GetRouteData(System.Web.HttpContextBase httpContext)
{
RouteData routeData;
if (_urlsToRouteData.TryGetValue(httpContext.Request.Path, out routeData))
return routeData;
else
return null;
}
public override VirtualPathData GetVirtualPath(RequestContext requestContext, RouteValueDictionary values)
{
return null;
}
private RouteData PrepareRouteData(ContentRouteData contentRoute)
{
var routeData = new RouteData(this, new MvcRouteHandler());
routeData.Values.Add("controller", contentRoute.Controller);
routeData.Values.Add("action", contentRoute.Action);
routeData.Values.Add("area", contentRoute.Area);
routeData.Values.Add("pageid", contentRoute.Constraints["pageid"]); // variable for identifying page id in controller method
routeData.DataTokens.Add("Namespaces", new[] { contentRoute.Namespace });
routeData.DataTokens.Add("area", contentRoute.Area);
return routeData;
}
// routes get periodically updated
public void UpdateRoutes()
{
SetCmsRoutes();
}
}
感谢您阅读直至结束!
答案 0 :(得分:1)
最后我们将其追踪到
的调用 ... data-role="@this.FirstVisit" ...
在我们的_Layout.cshtml
这在我们的自定义视图页面上调用了一个属性,该属性又调用了一个始终设置cookie的服务。 ( Yikes在服务中设置Cookie!,我们知道!)
如果不是星期五,在冲刺结束时我们可能已经注意到缓存破坏了
Cache-Control: no-cache="Set-Cookie":
Http Header。
我仍然不明白为什么这只会破坏我们自定义RouteBase
实现的缓存而不是所有页面。所有页面都使用相同的_Layout.cshtml
。
答案 1 :(得分:0)
如果有帮助,您可以尝试以下代码
[OutputCache(Duration = 300, VaryByParam="*")]
public ActionResult TextPage(string pageid)
{
var model = textPageController.GetPage(pageid);
return View(model);
}
答案 2 :(得分:0)
您可以在这里查看自定义缓存:
另外,请检查缓存位置。