.Net Core WebApi的簡單創(chuàng)建以及使用方法
前言
按照目前的軟件開發(fā)發(fā)展趨勢(shì)中,不管是前后端分離還是提供數(shù)據(jù)服務(wù),WebApi使用的越來越廣泛,而且.NET Core也是我們.NET開發(fā)人員未來發(fā)展的趨勢(shì),所以說學(xué)會(huì)使用.NET Core Api是非常有必要的。
本人作為一個(gè).NET菜鳥,正在慢慢的學(xué)習(xí)中,將學(xué)到的一步一步記錄下來。
一、創(chuàng)建項(xiàng)目
打開VS2019,新建一個(gè)ASP.NET Core Web 應(yīng)用程序。
輸入項(xiàng)目名、選擇路徑創(chuàng)建。
選擇.NET Core 我這里用的是.NET Core 2.2版本,選中API,把右邊的選中取消。
創(chuàng)建的項(xiàng)目目錄內(nèi)容如下。
二、編輯控制器
打開Controllers文件夾,這里我直接使用默認(rèn)創(chuàng)建的ValuesController控制器。(其實(shí)是因?yàn)檫@是個(gè)例子我懶的再建了( ̄. ̄))
ValuesController控制器默認(rèn)內(nèi)容如下。共有四個(gè)HTTP方法,分別為 Get、Post、Put 和 Delete。
把該控制器的內(nèi)容重新寫一下,將路由設(shè)置為api/控制器/方法(api/[controller]/[action])。按照常用Get 和 Post兩個(gè)請(qǐng)求,寫了兩個(gè)Get方法和一個(gè)Post方法,一個(gè)參數(shù)類。
using System; using System.Collections.Generic; using System.Linq; using System.Threading.Tasks; using Microsoft.AspNetCore.Mvc; namespace FirstApi.Controllers { //路由設(shè)置 [Route("api/[controller]/[action]")] [ApiController] public class ValuesController : ControllerBase { /// <summary> /// 獲取文本 /// </summary> /// <returns></returns> [HttpGet] public ActionResult<string> Get() { return "Hello World!"; } /// <summary> /// 兩數(shù)相加 /// </summary> /// <param name="num1">第一個(gè)數(shù)</param> /// <param name="num2">第二個(gè)數(shù)</param> /// <returns></returns> [HttpGet] public ActionResult<int> Sum(int num1,int num2) { return num1 + num2; } /// <summary> /// 兩數(shù)相減 /// </summary> /// <param name="param">參數(shù)</param> /// <returns></returns> [HttpPost] public ActionResult<int> Subtract(Param param) { int result = param.num1 - param.num2; return result; } } /// <summary> /// 參數(shù) /// </summary> public class Param { /// <summary> /// 第一個(gè)數(shù) /// </summary> public int num1 { get; set; } /// <summary> /// 第二個(gè)數(shù) /// </summary> public int num2 { get; set; } } }
然后右鍵項(xiàng)目→屬性→調(diào)試,將啟動(dòng)瀏覽器默認(rèn)指向?yàn)榈谝粋€(gè)Get方法。
調(diào)試運(yùn)行,訪問第一個(gè)方法,返回結(jié)果。
訪問第二個(gè)方法加上參數(shù),得到結(jié)果。
第三個(gè)方法是Post請(qǐng)求,無法直接輸入,可以用其他方式實(shí)現(xiàn)。
三、搭建Swagger
這樣WebApi 就簡單實(shí)現(xiàn)了,不過這樣不容易管理。為了更好的管理和測試我們的接口,我這里使用了Swagger框架。
Swagger是什么?Swagger 是一個(gè)規(guī)范和完整的框架,用于生成、描述、調(diào)用和可視化RESTful風(fēng)格的 Web 服務(wù)。
右鍵項(xiàng)目,點(diǎn)擊管理NuGet程序包。
切換到瀏覽,搜索“Swashbuckle.AspNetCore”,安裝。
安裝完成之后,編輯Startup.cs文件。
引用下面三個(gè)命名空間。
using System; using System.Collections.Generic; using System.Linq; using System.Threading.Tasks; using Microsoft.AspNetCore.Mvc; namespace FirstApi.Controllers { //路由設(shè)置 [Route("api/[controller]/[action]")] [ApiController] public class ValuesController : ControllerBase { /// <summary> /// 獲取文本 /// </summary> /// <returns></returns> [HttpGet] public ActionResult<string> Get() { return "Hello World!"; } /// <summary> /// 兩數(shù)相加 /// </summary> /// <param name="num1">第一個(gè)數(shù)</param> /// <param name="num2">第二個(gè)數(shù)</param> /// <returns></returns> [HttpGet] public ActionResult<int> Sum(int num1,int num2) { return num1 + num2; } /// <summary> /// 兩數(shù)相減 /// </summary> /// <param name="param">參數(shù)</param> /// <returns></returns> [HttpPost] public ActionResult<int> Subtract(Param param) { int result = param.num1 - param.num2; return result; } } /// <summary> /// 參數(shù) /// </summary> public class Param { /// <summary> /// 第一個(gè)數(shù) /// </summary> public int num1 { get; set; } /// <summary> /// 第二個(gè)數(shù) /// </summary> public int num2 { get; set; } } }
在ConfigureServices方法里加入下面的代碼,注冊(cè)Swagger生成器,定義一個(gè)文檔,設(shè)置xml文檔的注釋路徑,。
//配置Swagger //注冊(cè)Swagger生成器,定義一個(gè)Swagger 文檔 services.AddSwaggerGen(c => { c.SwaggerDoc("v1", new Info { Version = "v1", Title = "接口文檔", Description = "RESTful API" }); // 為 Swagger 設(shè)置xml文檔注釋路徑 var xmlFile = $"{Assembly.GetExecutingAssembly().GetName().Name}.xml"; var xmlPath = Path.Combine(AppContext.BaseDirectory, xmlFile); c.IncludeXmlComments(xmlPath); });
在Configure方法里加入下面的代碼,啟用中間件服務(wù)使用生成Swagger和SwaggerUI,將SwaggerUI中的RoutePrefix設(shè)為空字符串,這樣就能在根節(jié)點(diǎn)(http://localhost:port)直接顯示SwaggerUI界面。
//啟用中間件服務(wù)生成Swagger app.UseSwagger(); //啟用中間件服務(wù)生成SwaggerUI,指定Swagger JSON終結(jié)點(diǎn) app.UseSwaggerUI(c => { c.SwaggerEndpoint("/swagger/v1/swagger.json", "Web App V1"); c.RoutePrefix = string.Empty;//設(shè)置根節(jié)點(diǎn)訪問 });
編輯后Startup.cs完整代碼如下。
using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Reflection; using System.Threading.Tasks; using Microsoft.AspNetCore.Builder; using Microsoft.AspNetCore.Hosting; using Microsoft.AspNetCore.Mvc; using Microsoft.Extensions.Configuration; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Logging; using Microsoft.Extensions.Options; using Swashbuckle.AspNetCore.Swagger; namespace FirstApi { public class Startup { public Startup(IConfiguration configuration) { Configuration = configuration; } public IConfiguration Configuration { get; } // This method gets called by the runtime. Use this method to add services to the container. public void ConfigureServices(IServiceCollection services) { services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2); //配置Swagger //注冊(cè)Swagger生成器,定義一個(gè)Swagger 文檔 services.AddSwaggerGen(c => { c.SwaggerDoc("v1", new Info { Version = "v1", Title = "接口文檔", Description = "RESTful API" }); // 為 Swagger 設(shè)置xml文檔注釋路徑 var xmlFile = $"{Assembly.GetExecutingAssembly().GetName().Name}.xml"; var xmlPath = Path.Combine(AppContext.BaseDirectory, xmlFile); c.IncludeXmlComments(xmlPath); }); } // This method gets called by the runtime. Use this method to configure the HTTP request pipeline. public void Configure(IApplicationBuilder app, IHostingEnvironment env) { if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); } //啟用中間件服務(wù)生成Swagger app.UseSwagger(); //啟用中間件服務(wù)生成Swagger,指定Swagger JSON終結(jié)點(diǎn) app.UseSwaggerUI(c => { c.SwaggerEndpoint("/swagger/v1/swagger.json", "Web App V1"); c.RoutePrefix = string.Empty;//設(shè)置根節(jié)點(diǎn)訪問 }); app.UseMvc(); } } }
然后,右鍵項(xiàng)目,點(diǎn)擊屬性。
選擇生成,選擇我們的Debug路徑。
勾選XML文檔文件,自動(dòng)填充,然后會(huì)出現(xiàn)警告(非強(qiáng)迫癥可以忽略警告)
想要去掉警告,就在上面的取消顯示警告中加入上面顯示的1591,Ctrl+S保存一下,警告就沒了。
然后點(diǎn)擊調(diào)試,將啟動(dòng)瀏覽器后面url去掉。
完成后,直接運(yùn)行VS,就會(huì)進(jìn)入文檔UI頁面了。
四、使用Swagger
我們打開第一個(gè)方法,點(diǎn)擊Try it out按鈕。
這個(gè)是無參的方法,直接點(diǎn)擊Execute執(zhí)行。
執(zhí)行后可以看到Response body返回的內(nèi)容。
點(diǎn)擊第二個(gè)方法,給出兩個(gè)參數(shù),輸入執(zhí)行,得到返回結(jié)果。
第三個(gè)方法的參數(shù)是model,要傳遞json格式的,默認(rèn)已經(jīng)生成好了,我們只需要編輯改一下值,再執(zhí)行就行了。
五、總結(jié)
到這里.NET Core Api的簡單搭建和使用就告一段落了,此篇學(xué)到了如何創(chuàng)建.NET Core Api項(xiàng)目與怎么搭建Swagger生成文檔及使用,接下來我會(huì)繼續(xù)學(xué)習(xí)和運(yùn)用.NET Core Api,并將其過程記錄下來。本來想在這篇標(biāo)題加個(gè)(一),但是想了想最近有可能更不了,等以后更了再加上吧。ㄟ( ▔, ▔ )ㄏ
好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
ASP.NET用DataSet導(dǎo)出到Excel的方法
ASP.NET用DataSet導(dǎo)出到Excel的方法,需要的朋友可以參考一下2013-03-03asp.net richTextBox中高亮顯示選中字符串或文本
最近開發(fā)程序需要對(duì)一段文本中的某個(gè)字符串進(jìn)行高亮顯示,網(wǎng)上找了下資料2011-11-11asp.net 模擬提交有文件上傳的表單(通過http模擬上傳文件)
通過HTTP模擬GET或POST請(qǐng)求,提交數(shù)據(jù)到服務(wù)端獲取響應(yīng),比較常見些;但如上傳文件到服務(wù)端,使用html form當(dāng)然簡單了,而因環(huán)境所限有時(shí)需要使用模擬方法去提交有附件(文件上傳)的表單。2010-02-02Asp.Net Couchbase Memcached圖文安裝調(diào)用開發(fā)
本文主要是是如何安裝CouchBase服務(wù)端,以及客戶端如何進(jìn)行調(diào)用。圖文詳解,大家參考吧2013-11-11ASP.NET MVC運(yùn)行出現(xiàn)Uncaught TypeError: Cannot set property __MVC
同一相站點(diǎn),有些頁面的客戶端驗(yàn)證能工作,而有些死活不行。打開頁面就出現(xiàn)Uncaught TypeError: Cannot set property __MVC_FormValidation of null錯(cuò)誤2010-04-04Entity Framework Core對(duì)Web項(xiàng)目生成數(shù)據(jù)庫表
這篇文章介紹了Entity Framework Core對(duì)Web項(xiàng)目生成數(shù)據(jù)庫表的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03