想做一个统一的验证机制,当调用方法的时候进行身份验证,再去执行对应的方法。
那么就想到使用过滤器,C#有面向切面的属性,直接在方法上使用一个属性即可。
1、使用过滤器。
public class ValidateFilterAttribute : ActionFilterAttribute
{
public override void OnActionExecuting(ActionExecutingContext filterContext)
{
base.OnActionExecuting(filterContext);
}
public override void OnActionExecuted(ActionExecutedContext filterContext)
{
base.OnActionExecuted(filterContext);
}
}
2、在进入方法前进行验证。
public override void OnActionExecuting(ActionExecutingContext filterContext)
{
IDictionary<string, object> parameters = filterContext.ActionParameters;
bool result = ValidateSign(parameters);
if (!result)
{
JsonResult jresult = new JsonResult
{
Data = new { Result = false, Message = "安全验证失败!" }
};
jresult.JsonRequestBehavior = JsonRequestBehavior.AllowGet;
filterContext.Result = jresult;
}
else
base.OnActionExecuting(filterContext);
}
3、当失败后,进行自定义的跳转,正常则继续。
JsonResult jresult = new JsonResult
{
Data = new { Result = false, Message = "安全验证失败!" }
};
jresult.JsonRequestBehavior = JsonRequestBehavior.AllowGet;
filterContext.Result = jresult;
失败后返回指定的json信息。
原文地址:http://blog.csdn.net/qijunming1208/article/details/39959333