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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...