bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

詳解ASP.NETCore處理404NotFound

問題

為黃州等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及黃州網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)、黃州網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!

在沒有修改任何配置的情況下,這是用戶使用 Chrome 訪問不存在的URL時會看到的內(nèi)容:

詳解ASP.NET Core 處理 404 Not Found

幸運(yùn)的是,處理錯誤狀態(tài)代碼非常簡單,我們將在下面介紹三種技術(shù)。

解決方案

在以前的ASP.NET MVC版本中,主要在 web.config 中處理404錯誤的。

您可能記得在 <customErrors> 節(jié)點(diǎn)中配置ASP.NET管道處理404錯誤,以及在低版本的IIS中通過 <httpErrors> 節(jié)點(diǎn)處理 404錯誤。好像有點(diǎn)混亂。

在.Net Core中,情況就不同了,沒有必要使用XML配置(盡管如果您是通過IIS代理,您仍然可以在web.config中使用 httpErrors,并且您真的想這樣嗎:-))。

在處理 not-found 錯誤時,我們需要處理兩種不同的情況。

URL與任何路由不匹配的情況。在這種情況下,如果我們無法確定用戶正在訪問什么,我們需要返回一個通用的未找到的頁面。有兩種常見的處理方法,但首先我們將討論第二種情況。URL與路由匹配的情況,但是一個或多個參數(shù)無效,我們可以用自定義視圖來解決這個問題。

自定義視圖

這種情況的一個例子是具有無效或過期ID的產(chǎn)品頁面。在這里,我們知道用戶正在查看產(chǎn)品,而不是返回通用錯誤,我們可以更友好的頁面,返回自定義未找到產(chǎn)品的的頁面。這仍然需要返回404狀態(tài)代碼,但是使用不通用的頁面,同時也可以向用戶顯示類似或受歡迎的產(chǎn)品。

處理這些情況是非?,嵥椋覀冃枰龅氖窃诜祷匚覀兊淖远x視圖之前設(shè)置狀態(tài)代碼:

  public async Task<IActionResult> GetProduct(int id)
  {
    var viewModel = await _db.Get<Product,GetProductViewModel>(id);
  
    if (viewModel == null)
    {
      Response.StatusCode = 404;
      return View("ProductNotFound");
    }
  
    return View(viewModel);
  }

當(dāng)然,您可能更喜歡將其包裝成自定義ActionResult:

  public class NotFoundViewResult : ViewResult
  {
    public NotFoundViewResult(string viewName)      
    {
      ViewName = viewName;
      StatusCode = (int)HttpStatusCode.NotFound;
    }
  }

這簡化了我們的Action:

  public async Task<IActionResult> GetProduct(int id)
  {
    var viewModel = await _db.Get<Product,GetProductViewModel>(id);
  
    if (viewModel == null)
    {
      return new NotFoundViewResult("ProductNotFound");
    }
  
    return View(viewModel);
  }

這個簡單的技術(shù)涵蓋了特定的404頁,現(xiàn)在來看看通用的404錯誤,我們無法弄清楚用戶想要查看的內(nèi)容。

通配路由

在先前版本的MVC,創(chuàng)建一個通配符路由來處理,在.NET Core中,也可以使用相同的方式。這個方式是,您有一個通配符路由,它會接收任何其它路由尚未處理的URL。使用特性路由,方式如下:

  [Route("{*url}", Order = 999)]
  public IActionResult CatchAll()
  {
    Response.StatusCode = 404;
    return View();
  }

重要的是指定順序,以確保其它路由優(yōu)先。

一個通配符路由的方式非常不錯,但它不是.NET Core中的首選。雖然全部路由將處理404,但下一個方式將處理任何非成功狀態(tài)代碼,以便您可以執(zhí)行以下Action(可能在生產(chǎn)中的Action過濾器中):
 

  public async Task<IActionResult> GetProduct(int id)
  {
    ...
  
    if (RequiresThrottling())
    {
      return new StatusCodeResult(429)
    }
  
    if (!HasPermission(id))
    {
      return Forbid();
    }
  
    ...
  }

StatusCodePagesWithReExecute方法 中件間

UseStatusCodePagesWithReExecute使用了一個非常聰明的中間件(StatusCodePagesMiddleware),在未輸出響應(yīng)前,它能處理非成功狀態(tài)代碼。這意味著如果您使用上面詳細(xì)描述的自定義視圖技術(shù),則404狀態(tài)代碼將不會被中間件處理(這正是我們想要的)。

當(dāng)從內(nèi)部中間件組件返回錯誤代碼(如404)時,UseStatusCodePagesWithReExecute允許您執(zhí)行另一個控制器Action來處理狀態(tài)代碼。

您可以在startup.cs中使用一行代碼將其添加到管道中:

  app.UseStatusCodePagesWithReExecute("/error/{0}");
  ...
  app.UseMvc();

中間件定義的順序很重要,您需要確保在可能返回錯誤代碼的任何中間件(如MVC中間件)之前注冊StatusCodeWithReExecute。

您可以指定一個固定路徑來執(zhí)行或使用狀態(tài)代碼值的占位符,如上所述。

您還可以指向靜態(tài)頁面(假設(shè)您已經(jīng)具有StaticFileMiddleware中間件)和控制器Action。

在這個例子中,我們有一個單獨(dú)的Action處理404。任何其它非成功狀態(tài)代碼,使用 Error Action。

  [Route("error/404")]
  public IActionResult Error404()
  {
    return View();
  }
  
  [Route("error/{code:int}")]
  public IActionResult Error(int code)
  {
    // handle different codes or just return the default error view
    return View();
  }

顯然,您可以根據(jù)您的需要量身定制。例如,如果您正在使用上一節(jié)所示的請求限制,那么您可以返回一個解釋為什么請求失敗的429頁面。

總結(jié)

處理404頁面的具體問題最好用自定義視圖來處理,并設(shè)置狀態(tài)代碼(直接或通過自定義操作結(jié)果)。

通過使用StatusCodePagesMiddleware中間件,可以非常容易地處理通用404錯誤(或?qū)嶋H上是任何非成功狀態(tài)代碼)。一般來說,這兩種技術(shù)是在ASP.NET Core中處理非成功HTTP狀態(tài)代碼的首選方法。

原文:《Handling 404 Not Found in Asp.Net Core》

翻譯:Sweet Tang

網(wǎng)站名稱:詳解ASP.NETCore處理404NotFound
文章URL:http://vcdvsql.cn/article18/gjdddp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)、網(wǎng)站制作、響應(yīng)式網(wǎng)站面包屑導(dǎo)航、、用戶體驗(yàn)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)