Предупреждение: это было написано в 2009 году для MVC .NET RC1 и может больше не быть синтаксически правильным.
Атрибуты фильтра действий идеально подходят для этого, просто вызовите [YourAttributeName]
в верхней части вашего контроллера (или если у вас есть контроллер приложений, от которого наследуются другие контроллеры, он вам нужен только один раз в вашем приложении).
Например:
namespace the_name_space
{
[Log]
public class ApplicationController : Controller
{
С этого момента этот атрибут будет вызываться до того, как каждое действие будет запущено в вашем контроллере (ах), вы также можете указать это только для действия, вызвав [Log]
непосредственно перед ним тем же способом.
Чтобы получить необходимую вам функцию ведения журнала, вы, скорее всего, захотите переопределить OnResultExecuting
и OnResultExecuted
, оба из которых довольно понятны.
Например:
public class LogAttribute : ActionFilterAttribute
{
protected DateTime start_time;
public override void OnActionExecuting(ActionExecutingContext filterContext)
{
start_time = DateTime.Now;
}
public override void OnResultExecuted(ResultExecutedContext filterContext)
{
RouteData route_data = filterContext.RouteData;
TimeSpan duration = (DateTime.Now - start_time);
string controller = (string)route_data.Values["controller"];
string action = (string)route_data.Values["action"];
DateTime created_at = DateTime.Now;
//Save all your required values, including user id and whatnot here.
//The duration variable will allow you to see expensive page loads on the controller, this can be useful when clients complain about something being slow.
}
}