欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#凈化版WebApi框架的實(shí)現(xiàn)

 更新時間:2019年03月26日 15:07:12   作者:kiba518  
這篇文章主要介紹了C#凈化版WebApi框架的實(shí)現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

前言

我們都知道WebApi是依賴于Asp.Net MVC的 ,所以,想創(chuàng)建WebApi,就需要先創(chuàng)建一個Asp.Net MVC項(xiàng)目。

但用Visual Studio創(chuàng)建的MVC項(xiàng)目通常會帶很多功能,而這些功能,很多是我們并不想用的,或者我們想用其他開源控件代替它。

而這樣雜亂的起始項(xiàng)目,對于我們這種有精神潔癖的開發(fā)者而言,簡直是折磨。

所以,讓我們編寫一個簡潔版本的WebApi來凈化世界吧。

凈化版WebApi預(yù)覽

首先,我們先看下凈化版WebApi的結(jié)構(gòu)。

如上圖所示,代碼結(jié)構(gòu)很簡單,除開配置文件,整個Web項(xiàng)目只有2個文件;而需要被調(diào)用的WebApi都被封裝到了WebApi程序集中了。

接下來我們一起看下編寫這個凈化版WebApi的過程吧。

凈化版WebApi編寫

WebApiConfig

首先,引入必要的Dll,如下圖所示。

然后,我們編寫Web項(xiàng)目的寫WebApiConfig;代碼如下:

public static class WebApiConfig

{
  public static void Register(HttpConfiguration config)

  { 

    config.Filters.Add(new WebApiAttribute());

    // 解決json序列化時的循環(huán)引用問題

    config.Formatters.JsonFormatter.SerializerSettings.ReferenceLoopHandling = Newtonsoft.Json.ReferenceLoopHandling.Ignore; 

    // 對 JSON 數(shù)據(jù)使用混合大小寫。跟屬性名同樣的大小.輸出

    config.Formatters.JsonFormatter.SerializerSettings.ContractResolver = new DefaultContractResolver(); 

    // Web API 路由

    config.MapHttpAttributeRoutes();

    config.Routes.MapHttpRoute(

      name: "DefaultApi",

      routeTemplate: "webapi/{controller}/{id}",

      defaults: new { id = RouteParameter.Optional }
    ); 
  }
}

可以看到WebApiConfig是個靜態(tài)類中,我們在其中創(chuàng)建了靜態(tài)注冊方法Register,在方法內(nèi),我們主要在做一件事,那就是為HttpConfiguration對象做配置。

而在配置中,我們將WepApi的路由配置成了webapi/{controller}/{id},也就是說,我們的WebApi未來的訪問地址將為【http://localhost:5180/webapi/Login】這樣的模式。

在WebApiConfig類中,我們還用到了這樣一個類WebApiAttribute,我們在為HttpConfiguration對象的Filters屬性,添加了這個類的對象。

通過Filters屬性這個字樣,我們可以得出,這個類主要應(yīng)用應(yīng)該是過濾。

下面我們看一下這個類的代碼:

[AttributeUsage(AttributeTargets.Method | AttributeTargets.Class, Inherited = true, AllowMultiple = true)]
public class WebApiAttribute : ActionFilterAttribute

{ 

  public override void OnActionExecuting(HttpActionContext actionContext)

  { 

    //API執(zhí)行前觸發(fā)

    if (true)//當(dāng)前設(shè)置,所有API都可以被調(diào)用

    {

      base.OnActionExecuting(actionContext);

    }

    else

    {

      throw new Exception("Error");

    } 

  } 

  public override void OnActionExecuted(HttpActionExecutedContext actionExecutedContext)

  {

    //API執(zhí)行后觸發(fā) 若發(fā)生例外則不在這邊處理

    if (actionExecutedContext.Exception != null)

      return; 

    base.OnActionExecuted(actionExecutedContext);
  }
}

通過閱讀代碼,我們應(yīng)該可以發(fā)現(xiàn),這是一個AOP的過濾器。

在執(zhí)行真正WebApi之前,會先進(jìn)入這里進(jìn)行過濾,過濾通過的API,才會調(diào)用base.OnActionExecuting(actionContext)方法進(jìn)行調(diào)用和執(zhí)行。

結(jié)束調(diào)用同理,結(jié)束調(diào)用前,會在該類中進(jìn)行攔截和過濾處理。

配置文件

WebApiConfig編寫結(jié)束了,現(xiàn)在,我們需要將這個靜態(tài)類注冊到項(xiàng)目中。

打開Global.asax文件,編寫如下代碼:

[AttributeUsage(AttributeTargets.Method | AttributeTargets.Class, Inherited = true, AllowMultiple = true)]

public class WebApiAttribute : ActionFilterAttribute

{ 

  public override void OnActionExecuting(HttpActionContext actionContext)

  { 

    //API執(zhí)行前觸發(fā)

    if (true)//當(dāng)前設(shè)置,所有API都可以被調(diào)用

    {

      base.OnActionExecuting(actionContext);

    }

    else

    {

      throw new Exception("Error");

    } 

  } 
  public override void OnActionExecuted(HttpActionExecutedContext actionExecutedContext)

  {
    //API執(zhí)行后觸發(fā) 若發(fā)生例外則不在這邊處理

    if (actionExecutedContext.Exception != null)

      return; 
    base.OnActionExecuted(actionExecutedContext);
  }
}

可以看到,我們已通過Configure方法,將我們編寫好的WebApiConfig添加到了全局配置中了。

因?yàn)榫W(wǎng)站訪問都存在跨域問題,所以我們再向Global.asax中添加如下代碼處理:

protected void Application_BeginRequest(object sender, System.EventArgs e)
{
  var req = System.Web.HttpContext.Current.Request;
  if (req.HttpMethod == "OPTIONS")//過濾options請求,用于js跨域

  {
    Response.StatusCode = 200;
    Response.SubStatusCode = 200;
    Response.End();
  }
}

到此Web項(xiàng)目的編寫就完成了,下面我們在WebApi程序集中,編寫個簡單的WebApi,代碼如下:

public class LoginController : BaseApiController

{ 
  public BaseResult Get()

  { 
    try

    { 
      return new BaseResult() { IsSuccess=true }; 

    }
    catch (Exception ex)
    {
      throw ex;
    } 

  }<br>}
public class BaseApiController : ApiController
{  
  public string Options()
  {
    return null;
  }
}

然后我們運(yùn)行網(wǎng)站,進(jìn)行WebApi訪問。

如上圖所示,我們的WebApi訪問成功。

到此C#凈化版WebApi框架就介紹完了。

框架代碼已經(jīng)傳到Github上了,歡迎大家下載。

Github地址:https://github.com/kiba518/WebApi

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C#虛函數(shù)用法實(shí)例分析

    C#虛函數(shù)用法實(shí)例分析

    這篇文章主要介紹了C#虛函數(shù)用法,實(shí)例分析了C#中虛函數(shù)的功能與基本使用技巧,需要的朋友可以參考下
    2015-07-07
  • C#實(shí)現(xiàn)兩接口中同名方法實(shí)例分析

    C#實(shí)現(xiàn)兩接口中同名方法實(shí)例分析

    這篇文章主要介紹了C#實(shí)現(xiàn)兩接口中同名方法,涉及C#接口與方法的相關(guān)操作技巧,需要的朋友可以參考下
    2015-05-05
  • C#讀取命令行參數(shù)的方法

    C#讀取命令行參數(shù)的方法

    這篇文章主要介紹了C#讀取命令行參數(shù)的方法,可實(shí)現(xiàn)讀取程序輸入命令行的所有參數(shù),便于調(diào)試程序,比較簡單實(shí)用,需要的朋友可以參考下
    2015-04-04
  • C#調(diào)用C++ DLL bool返回值始終為true的問題

    C#調(diào)用C++ DLL bool返回值始終為true的問題

    這篇文章主要介紹了C#調(diào)用C++ DLL bool返回值始終為true的問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • c#類的使用示例

    c#類的使用示例

    這篇文章主要介紹了c#類的使用示例,還有我學(xué)習(xí)時的筆記,需要的朋友可以參考下
    2014-04-04
  • C#簡單郵件群發(fā)通用類

    C#簡單郵件群發(fā)通用類

    這篇文章主要為大家分享了簡單的C#郵件群發(fā)通用類,代碼簡單實(shí)用,感興趣的小伙伴們可以參考一下
    2016-03-03
  • C#中Array與ArrayList用法及轉(zhuǎn)換的方法

    C#中Array與ArrayList用法及轉(zhuǎn)換的方法

    C#中Array與ArrayList用法及轉(zhuǎn)換的方法,需要的朋友可以參考一下
    2013-03-03
  • unity實(shí)現(xiàn)繪畫功能

    unity實(shí)現(xiàn)繪畫功能

    這篇文章主要為大家詳細(xì)介紹了unity實(shí)現(xiàn)繪畫功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-04-04
  • C#純技術(shù)之Class寫入Json

    C#純技術(shù)之Class寫入Json

    這篇文章主要介紹了C#純技術(shù)之Class寫入Json問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • C#集合之列表的用法

    C#集合之列表的用法

    這篇文章介紹了C#集合之列表的用法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-04-04

最新評論