我正在构建一个连接到Application_EndRequest / Application_BeginRequest的简单性能记录器
我想将操作和控制器的名称作为某种密钥发送给我的记录器。
我怎样才能访问这些信息?(如果我必须先截取它,并将它保存在上下文中,请不要介意)
发布于 2010-10-27 01:11:03
不确定你能不能。
我浏览了一下HttpContext.Current,发现在第二个(和随后的请求)中,HttpContext.Current.Items集合包含一个System.Web.Routing.UrlRoutingModule.RequestData类的实例。不幸的是,这个类是私有的,所以您无法访问它的数据。但是,在调试器中,它似乎包含您要查找的信息(但不确定为什么在第一个请求中不存在该信息)。
或者,您是否可以使用动作筛选器并将其添加到所有控制器派生的BaseController类中?类似于:
public class LoggingActionAttribute : ActionFilterAttribute
{
public override void OnActionExecuting(ActionExecutingContext filterContext)
{
base.OnActionExecuting(filterContext);
var controllerName = filterContext.Controller.ControllerContext.RouteData.Values["controller"];
var actionName = filterContext.Controller.ControllerContext.RouteData.Values["action"];
}
}然后使用以下属性创建一个基本控制器类:
[LoggingAction]
public abstract class BaseController : Controller
{
}发布于 2012-02-22 22:05:04
我知道这是一个老问题,但您可以使用以下方法访问所请求的信息:
HttpContext.Current.Request.RequestContext.RouteData.Values("controller")
HttpContext.Current.Request.RequestContext.RouteData.Values("action")发布于 2019-06-03 10:15:59
这是行之有效的:
protected void Application_BeginRequest(object sender, EventArgs e)
{
var context = new HttpContextWrapper(HttpContext.Current);
var rd = RouteTable.Routes.GetRouteData(context);
// use rd
}https://stackoverflow.com/questions/4028669
复制相似问题