ASP.NET Web API模型验证以及异常处理方式

ASP.NET Web API的模型验证与ASP.NET MVC一样,都使用System.ComponentModel.DataAnnotations。

具体来说,比如有:
[Required(ErrorMessage="")]
[Range(0, 999)]
[Bind(Exclude="")]
[DisplayName("")]
[StringLength(1024)]
...

验证扩展可以看这里:http://dataannotationsextensions.org/

在controller中如何验证模型呢?

通常是通过ModelState.IsValid.

public HttpResponseMessage Post(Product product)
{
if(ModelState.IsValid){
//
return new HttpResponseMessage(HttpStatusCode.OK);
}
else
{
return Request.CreateErrorResponse(HttpStatusCode.BadRequest, ModelState);
}
}

还可以通过"面向切面"的方式,自定义一个模型验证的特性ActionFilterAttibute特性。

public class ValidateModelAttribute:ActionFilterAttibute
{
public override void OnActionExecuting(HttpActionContext actionContext)
{
if(actionContext.ModelState.IsValid == false)
{
actionContext.Response = actionContext.Request.CreateErrorResponse(HttpStatusCode.BadRequest, actionContext.ModelState);
}
}
}

然后需要把自定义的过滤器特性注册到默认的过滤器集合中去。

public static class WebApiConfig
{
public static void Register(HttpConfiguraiotn config)
{
config.Filters.Add(new ValidateModelAttribute());
}
}

如果不在全局注册过滤器,我们还可以把过滤器特性打到控制器或控制器方法上去。

[ValidateModel]
public HttpResponseMessage Post(Product product)
{ }
上一篇:浏览器中输入URL发生了什么


下一篇:Lambda动态创建