本文整理匯總了C#中System.Web.Mvc.ActionExecutedContext.GetExecuteFunction方法的典型用法代碼示例。如果您正苦於以下問題:C# ActionExecutedContext.GetExecuteFunction方法的具體用法?C# ActionExecutedContext.GetExecuteFunction怎麽用?C# ActionExecutedContext.GetExecuteFunction使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類System.Web.Mvc.ActionExecutedContext
的用法示例。
在下文中一共展示了ActionExecutedContext.GetExecuteFunction方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: OnActionExecuted
/// <summary>
/// Called after the action method executes.
/// </summary>
/// <param name="filterContext">The filter context.</param>
public override void OnActionExecuted(ActionExecutedContext filterContext)
{
IFunction function = filterContext.GetExecuteFunction(ServiceProvider);
if (function == null || !function.OperateLogEnabled)
{
return;
}
Operator @operator = new Operator()
{
Ip = filterContext.HttpContext.Request.GetIpAddress(),
};
if (filterContext.HttpContext.Request.IsAuthenticated)
{
ClaimsIdentity identity = filterContext.HttpContext.User.Identity as ClaimsIdentity;
if (identity != null)
{
@operator.UserId = identity.GetClaimValue(ClaimTypes.NameIdentifier);
@operator.UserName = identity.GetClaimValue(ClaimTypes.Name);
}
}
OperateLog operateLog = new OperateLog()
{
FunctionName = function.Name,
Operator = @operator
};
if (function.DataLogEnabled)
{
foreach (DataLog dataLog in DataLogCache.DataLogs)
{
operateLog.DataLogs.Add(dataLog);
}
}
OperateLogWriter.Write(operateLog);
}