Asp.Net Web API(四)

来源:http://www.cnblogs.com/yan7/archive/2017/11/02/7774230.html
-Advertisement-
Play Games

HttpResponseException HTTP響應異常 如果Web API控制器拋出一個未捕捉的異常,會發生什麼呢?在預設情況下,大多數異常都會轉換為一個帶有狀態碼500的內部伺服器錯誤的HTTP響應。 這個HTTPResponseException類型是一個特殊的類型。這種異常會返回你在異常 ...


HttpResponseException-----HTTP響應異常

    如果Web API控制器拋出一個未捕捉的異常,會發生什麼呢?在預設情況下,大多數異常都會轉換為一個帶有狀態碼500的內部伺服器錯誤的HTTP響應。

這個HTTPResponseException類型是一個特殊的類型。這種異常會返回你在異常構造器中指定的任何HTTP狀態碼。例如,在以下方法中,如果這個id參數無效,那麼會返回“404---未找到”

1  public Product GetProduct(int id)
2 {
3             var item = repository.Get(id);
4             if (item == null)
5                 //未找到返回一個404的狀態碼
6                 throw new HttpResponseException(HttpStatusCode.NotFound);
7             return item;
8 }

為了響應進行更多的控制,你也可以構造整個響應消息,並用HTTPResponseMessage來包含它:

 1 public Product GetProduct(int id)
 2 {
 3             var item = repository.Get(id);
 4             if (item == null)
 5             //未找到返回一個404的狀態碼
 6             {
 7                 var resp = new HttpResponseMessage(HttpStatusCode.NotFound)
 8                 {
 9                     Content = new StringContent(String.Format("No product with ID={0}", id)),
10                     ReasonPhrase = "Product ID Not Found"
11                 };
12                 throw new HttpResponseException(resp);
13             }
14             return item;
15 }

Exception Filters---異常過濾器

   通過編寫一個異常過濾器,你可以定製Web API如何處理異常。當一個控制器拋出一個未處理異常,且這個異常不是一個HttpResponseException異常時,一個異常過濾器會被執行。HttpResponseException類型是一個特殊情況,因為它是專門設計用來返回一個HTTP響應的。

   異常過濾器實現System.Web.Http.Filters.IExceptionFilter介面。編寫異常過濾器最簡單的方法是通過System.Web.Fitlers.ExceptionFilterAttribute類進行派生,並重寫OnException方法。

      註意:ASP.NET Web API中的異常過濾器與ASP.NET MVC中是及其相似的。然後,它們被聲明在不用的命名空間下,且功能也是獨立的。特別強調以下,ASP.NET MVC中使用的HandlerErrorFilterAttribute不會處理Web API控制器拋出的異常。

  以下是將NotImplementedException異常轉換成HTTP狀態碼“501 - 未實現”的過濾器:

 1 namespace WebAPIDemo.Filter
 2 {
 3     public class NotImpleExceptionFilterAttribute:ExceptionFilterAttribute
 4     {
 5         public override void OnException(HttpActionExecutedContext actionExecutedContext)
 6         {
 7             if (actionExecutedContext.Exception is NotImplementedException)
 8                 actionExecutedContext.Response = new System.Net.Http.HttpResponseMessage(System.Net.HttpStatusCode.NotImplemented);
 9         }
10     }
11 }

   HttpActionExecutedContext對象的Response屬性含有發送到客戶端的HTTP響應消息

Registering  Exception Filters --- 註冊異常過濾器

   以下是註冊Web API異常過濾器的幾種方式

       1.通過Action註冊

       2.通過Controller註冊

       3.通過全局註冊

   要把過濾器應用特定的Action,在Action中添加過濾器的註解屬性

 1 [NotImpleExceptionFilter]
 2 public Product GetProduct(int id)
 3  {
 4           var item = repository.Get(id);
 5            if (item == null)
 6             //未找到返回一個404的狀態碼
 7             {
 8                 var resp = new HttpResponseMessage(HttpStatusCode.NotFound)
 9                 {
10                     Content = new StringContent(String.Format("No product with ID={0}", id)),
11                     ReasonPhrase = "Product ID Not Found"
12                 };
13                 throw new HttpResponseException(resp);
14             }
15            return item;
16 }

要把過濾器應用於一個控制器的所有Action,可以在Controller上添加過濾器的註解屬性

[NotImpleExceptionFilter]
public class ProductController : ApiController
{
   
}

要全局性的把過濾器運用於所有的Web API控制器將該過濾器的一個實例添加GlobalConfiguration.Configuration.Filter集合。這個集合中的所有異常過濾器會應用於任何Web API控制器Action

public class WebApiApplication : System.Web.HttpApplication
{
        protected void Application_Start()
        {
            //註冊全局異常過濾器
            GlobalConfiguration.Configuration.Filters.Add(new NotImpleExceptionFilterAttribute());
        }
 }

HttpError----HTTP錯誤

HttpError對象為在響應正文中返回錯誤消息提供了響應的方法。以下實例演示瞭如何用HttpError在響應中返回HTTP狀態碼“404--未找到”:

1 public HttpResponseMessage GetProduct(int id)
2 {
3             var item = repository.Get(id);
4             if (item != null)
5                 return Request.CreateResponse(HttpStatusCode.OK, item);
6             var message = string.Format("Product with id = {0} not found", id);
7             HttpError httpError = new HttpError(message);
8             return Request.CreateResponse(HttpStatusCode.NotFound, httpError);
9 }

在這個例子中,如果該方法成功,它會在HTTP響應中返回產品。但如果所請求的產品未找到,則HTTP響應會在請求體中包含一個HttpError。該響應看起來大致像這樣

1 HTTP/1.1 404 Not Found
2 Content-Type: application/json; charset=utf-8
3 Date: Thu, 09 Aug 2012 23:27:18 GMT
4 Content-Length: 51
5 
6 {
7   "Message": "Product with id = 12 not found"
8 }

  註意。在這個例子中,HttpError會被序列化成JSON。使用HttpError的一個好處是,與其它強類型模型一樣,會進行同樣的“content-negotiation”(暫未實現)和序列過程

  直接替代創建HttpError對象的一種方法是:你可以使用CreateErrorResponse方法:

1 public HttpResponseMessage GetProduct(int id)
2 {
3             var item = repository.Get(id);
4             if (item != null)
5                 return Request.CreateResponse(HttpStatusCode.OK, item);
6             var message = string.Format("Product with id = {0} not found", id);
7             return Request.CreateErrorResponse(HttpStatusCode.NotFound, message);
8 }

  CreateErrorResponseSystem.Net.Http.HttpRequsetMessageExtensions類中被定義的一個擴展方法。本質上,CreateErrorResponse會創建一個HttpError實例,然後創建一個包含該HttpError的HttpResponseMessage

  Adding Custom Key-Values to HttpError 把自定義的鍵值添加到HttpError

  HttpError類實際上是個鍵--值集合,(派生與於Dictionary<String,Object>),因此你可以添加自己的鍵--值對

 1 public HttpResponseMessage GetProduct(int id)
 2 {
 3             var item = repository.Get(id);
 4             if (item != null)
 5                 return Request.CreateResponse(HttpStatusCode.OK, item);
 6             var message = string.Format("Product with id = {0} not found", id);
 7             var err = new HttpError(message);
 8             err["error_sub_code"] = 42;
 9             return Request.CreateErrorResponse(HttpStatusCode.NotFound, err);
10 }

 

Using HttpError with HttpResponseExceptionHttpResponseException的方式來使用HttpError

前面的例子是從Action返回一個HttpResponseMessage消息,但你也可以使用HttpResponseException來返回一個HttpError。這讓你能夠在正常成功情況下返回強類型模型,而在錯誤時,仍返回HttpError

1 public Product GetProduct(int id)
2 {
3             var item = repository.Get(id);
4             if (item != null)
5                 return item;
6             var message = string.Format("Product with id = {0} not found", id);
7             throw new HttpResponseException(Request.CreateErrorResponse(HttpStatusCode.NotFound, message));
8 }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • //TransmitFile實現下載 protected void Button1_Click(object sender, EventArgs e) { /* 微軟為Response對象提供了一個新的方法TransmitFile來解決使用Response.BinaryWrite 下載超過400mb ...
  • 在對業務層進行單元測試時,因為業務層調用到數據處理層,所以要用Moq去模擬DbContext,這個很容易做到,但如果操作DbContext下的DbSet和DbSet下的擴展方法時,就會拋出一個System.NotSupportedException異常。這是因為我們沒辦法Mock DbSet,並助D... ...
  • 在前面介紹了框架中工作流的幾個開發過程,本篇隨筆重點介紹一下日常審批環節中的具體處理過程,從開始創建表單,以及各個審批、會簽過程的流轉過程,希望大家對其中流程的處理有一個大概的印象。 ...
  • 本文實例講述了C#對圖片文件的壓縮、裁剪操作方法,在C#項目開發中非常有實用價值。分享給大家供大家參考。具體如下: 一般在做項目時,對圖片的處理,以前都採用在上傳時,限制其大小的方式,這樣帶來諸多不便。畢竟網站運維人員不一定會對圖片做處理,經常超出大小限制,即使會使用圖片處理軟體的,也由於個人水平方 ...
  • 劇情介紹 在傳統的信息系統(比如小規模的ERP\MES系統),往往只是進行簡單的應用伺服器和資料庫伺服器的分散式部署,以此來提高應用系統的負載能力,而伴隨著訪問的增大,應用伺服器層面除了做硬體和網路的擴容,很難應對【套路式開頭】。 當然現在開源技術很多,不就是分散式麽,應用伺服器分散式、資料庫讀寫分 ...
  • 在現代Web應用程式中,通常會使用Web, WebApp, NativeApp等多種呈現方式,而後端也由以前的Razor渲染HTML,轉變為Stateless的RESTFulAPI,因此,我們需要一種標準的,通用的,無狀態的,與語言無關的認證方式,也就是本文要介紹的 JwtBearer 認證。 目錄 ...
  • 從java培訓出來,進了一家企業,需要.net開發,就開始了一無所知的net世界!從oracle開始著手,一步步接觸,發現和java有不少類似的知識點。波瀾不驚的渡過了一個月,問題來了,讓小菜開始學習企業框架了。直接丟過來一個框架項目,好奇心突起,想對浩瀚的知識海洋進行探究,探究到後來,發覺懵逼了! ...
  • is檢查對象是否相容與指定類型,返回Boolean值true或者false,值得註意的是,在使用is進行類型轉換的時候是永遠不會拋出異常的,例如: object o=new Object(); Boolean a=(o is object); //返回a=true Boolean b=(o is E ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...