C#凈化版WebApi框架的實現(xiàn)
前言
我們都知道WebApi是依賴于Asp.Net MVC的 ,所以,想創(chuàng)建WebApi,就需要先創(chuàng)建一個Asp.Net MVC項目。
但用Visual Studio創(chuàng)建的MVC項目通常會帶很多功能,而這些功能,很多是我們并不想用的,或者我們想用其他開源控件代替它。
而這樣雜亂的起始項目,對于我們這種有精神潔癖的開發(fā)者而言,簡直是折磨。
所以,讓我們編寫一個簡潔版本的WebApi來凈化世界吧。
凈化版WebApi預(yù)覽
首先,我們先看下凈化版WebApi的結(jié)構(gòu)。

如上圖所示,代碼結(jié)構(gòu)很簡單,除開配置文件,整個Web項目只有2個文件;而需要被調(diào)用的WebApi都被封裝到了WebApi程序集中了。
接下來我們一起看下編寫這個凈化版WebApi的過程吧。
凈化版WebApi編寫
WebApiConfig
首先,引入必要的Dll,如下圖所示。

然后,我們編寫Web項目的寫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)類注冊到項目中。
打開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添加到了全局配置中了。
因為網(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項目的編寫就完成了,下面我們在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#中BitmapImage與BitmapSource接口的區(qū)別對比小結(jié)
BitmapImage和BitmapSource都可以用于表示和顯示圖像,本文就來介紹一下C#中BitmapImage與BitmapSource接口的區(qū)別對比,具有一定的參考價值,感興趣的可以了解一下2024-03-03
C#連接操作 MySQL 數(shù)據(jù)庫實例(使用官方驅(qū)動)
這篇文章主要介紹了C#連接操作 MySQL 數(shù)據(jù)庫實例(使用官方驅(qū)動),本文講解了C#中的Mysql連接方法和SQL操作方法,需要的朋友可以參考下2015-02-02
C#使用OleDb操作Excel和數(shù)據(jù)庫的策略
在C#編程中,使用OleDb可以方便地實現(xiàn)對Excel文件和數(shù)據(jù)庫的操作,本文探討了在C#中使用OleDb技術(shù)操作Excel和數(shù)據(jù)庫的策略,文章詳述了OleDb的定義、配置環(huán)境的步驟,并通過實際代碼示例演示了如何高效讀寫Excel文件和交互數(shù)據(jù)庫,需要的朋友可以參考下2024-05-05
C#實現(xiàn)字符串轉(zhuǎn)換成字節(jié)數(shù)組的簡單實現(xiàn)方法
這篇文章主要介紹了C#實現(xiàn)字符串轉(zhuǎn)換成字節(jié)數(shù)組的簡單實現(xiàn)方法,僅一行代碼即可搞定,非常簡單實用,需要的朋友可以參考下2015-05-05

