asp.net-web-api – 返回Web API中的错误
我正在使用ASP.NET Web API开发一个全新的REST API.来自WCF背景,我觉得为我的API创建“错误合同”.
在这种情况下,我不是在向客户端返回未处理的异常.相反,我专注于客户端不当使用API??的错误,特别是那些客户端可以自动创建这些错误并重新提交请求的错误. 我发现的大多数例子都是返回一个字符串,通常是通过抛出一个HttpResponseException,或者至少做一些事情,使得构建一个更加自动化的信息错误字符串的过程:Return custom error objects in Web API 我正在考虑创建一个HttpResponseException,传递一个HttpResponseMessage,其内容设置为我的特定错误合同类型. 尽管如此,我的API也在大量使用自动模型验证,并且这些模型验证错误返回到完全不同的结构. 那么我应该强制我的“错误”与模型验证响应相同的格式?这里最好的做法是什么? 最后,我的API将公开json,xml和协议缓冲区的格式化选项.因此,我真的需要确保我的策略与格式化器无关. 解决方法
我写了一篇关于Web API如何处理错误的博文:
http://blogs.msdn.com/b/youssefm/archive/2012/06/28/error-handling-in-asp-net-webapi.aspx 它应该有助于回答你的问题.本质上,您有两个选择: >定义你自己的类的错误响应.在这种情况下,您希望确保您的类可以序列化为XML,JSON等.然后可以使用Request.CreateResponse(statusCode,myErrorInstance)发回您的自定义错误.您可能还需要一种将无效模型状态转换为特定错误类型的方法.>使用Web API的错误响应类型:HttpError. HttpError本质上是一个字典< string,object>您可以在HttpError中添加自己的密钥和值.优点很多 – 您的错误会像Web API错误一样,您知道它与所有格式化程序一起使用,您可以避免必须从异常和无效模型状态定义转换的工作.使用HttpError最简单的方法是调用Request.CreateErrorResponse(). (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- asp.net web api定义案例一
- 实体框架 – Unity Lifetime Managers和EF Data Context –
- SignalR的简单实现消息广播
- ASP.Net MVC 2中的多个环境
- 排序 – sortdir没有在MVC 3 WebGird中使用枚举数据类型
- asp.net-mvc – 将参数传递给Azure Active Directory身份验
- asp.net-mvc – MVC 4忽略DefaultModelBinder.ResourceClas
- ASP.Net 3.5 / 4.0 CodeBehind还是CodeFile?
- asp.net-mvc-4 – 为什么ResolveBundleUrl不能用于自定义文
- 引领从经典ASP到ASP.NET的跳跃,有什么建议吗?