Net Core Web Api項目與在NginX下發(fā)布的方法
前言
本文將介紹Net Core的一些基礎(chǔ)知識和如何NginX下發(fā)布Net Core的WebApi項目。
測試環(huán)境
- 操作系統(tǒng):windows 10
- 開發(fā)工具:visualstudio 2019
- 框架:Net Core 3
Net Core WebApi項目創(chuàng)建
首先創(chuàng)建一個Net Core WebApi項目——CorePublishForNginX。
首先選擇Asp.Net Core Web應(yīng)用程序,如下圖:
然后修改項目名稱,如下圖:
然后選擇Api選項,如下圖:
項目創(chuàng)建完成,如下圖:
代碼介紹
Controller
項目創(chuàng)建完成后,我們可以看到,里面內(nèi)置了一個Api Controller——WeatherForecastController,代碼如下:
[ApiController] [Route("[controller]")] public class WeatherForecastController : ControllerBase { private static readonly string[] Summaries = new[] { "Freezing", "Bracing", "Chilly", "Cool", "Mild", "Warm", "Balmy", "Hot", "Sweltering", "Scorching" }; private readonly ILogger<WeatherForecastController> _logger; public WeatherForecastController(ILogger<WeatherForecastController> logger) { _logger = logger; } [HttpGet] public IEnumerable<WeatherForecast> Get() { var rng = new Random(); return Enumerable.Range(1, 5).Select(index => new WeatherForecast { Date = DateTime.Now.AddDays(index), TemperatureC = rng.Next(-20, 55), Summary = Summaries[rng.Next(Summaries.Length)] }) .ToArray(); } }
如上述代碼所示,首先我們看到該Controller繼承的類是ControllerBase。(在NetFramework里繼承的WebApi繼承的是ApiController,Mvc繼承的是Controller)
然后,我們發(fā)現(xiàn)Controller有一個構(gòu)造函數(shù),并且還有一個入?yún)?;我們知道Controller的調(diào)用是框架的內(nèi)部機制,也就是說,框架在調(diào)用Controller時會給他一個入?yún)ⅰ?/p>
通過名稱我們可以發(fā)現(xiàn),這個是一個日志入?yún)?,即,Core調(diào)用Controller時,為我們內(nèi)置了一個日志記錄對象。
這里我們不需要使用日志,所以可以先把這個構(gòu)造函數(shù)刪除。
接下來,我們看到了Api請求實現(xiàn)的主體,Get請求。
主體現(xiàn)的很簡單,就是方法名用Get,然后方法頭上加HttpGet特性。(Get方法名是可以修改的,因為一個WebApi里只支持一個Get請求,所以只要方法加了HttpGet特性,就會被視為默認的Get方法)
Get請求里實現(xiàn)了一個實體集合的組件,即請求該Controller會得到一個實體集合的數(shù)組。
Program
學(xué)習完Controller,我們進入Program.cs文件,我們做下簡單的修改,設(shè)置一下Kestrel的啟動端口。
修改CreateHostBuilder代碼如下:
public static IHostBuilder CreateHostBuilder(string[] args) { return Host.CreateDefaultBuilder(args).ConfigureWebHostDefaults( webBuilder => { //設(shè)置項目的啟動文件 webBuilder.UseStartup<Startup>(); //Kestrel的默認監(jiān)聽端口是http5000、https5001。 webBuilder.ConfigureKestrel(options => { options.ListenAnyIP(5180);//監(jiān)聽本機任意ip的5180端口,相當于設(shè)置ip0.0.0.0 //options.Listen(new IPEndPoint(IPAddress.Parse("127.0.0.1"), 5180));//監(jiān)聽指定ip的指定端口 }); ; }); }
Startup
Startup的調(diào)用順序如下:
Startup構(gòu)造函數(shù)——ConfigureServices配置服務(wù)函數(shù)——Configure請求配置
Startup構(gòu)造函數(shù):
這里做了簡單配置信息對象提取,實戰(zhàn)中,像啟動日志這樣的操作也可以集中放在這里。
ConfigureServices配置服務(wù)函數(shù):
這里只添加了一個控制器服務(wù),實戰(zhàn)中,還可以添加更多服務(wù),比如使用services.AddCors添加跨域服務(wù)。
Configure請求配置:
這里做了一些請求配置,如:
app.UseDeveloperExceptionPage()——設(shè)置請求異常時的顯示內(nèi)容為內(nèi)置異常錯誤界面(在Mvc模式下,還可以指定請求異常時的顯示界面,如:app.UseExceptionHandler("/Home/Error");)
app.UseHttpsRedirection()——Https請求重定向,將Http請求轉(zhuǎn)換成Https,增加一些安全性。(還可以追加app.UseHsts(),要求瀏覽器只發(fā)送https,實現(xiàn)安全雙保險)
app.UseRouting()——配置endpointRouteBuilder。
app.UseEndpoints——使用endpointRouteBuilder。UseRouting與UseEndpoints組合實現(xiàn)路由。
app.UseAuthorization()——請求的授權(quán)處理,因為沒有沒有添加授權(quán)服務(wù)services.AddAuthorization,所以這里它是無效的。
----------------------------------------------------------------------------------------------------
到此,我們對Net Core Web Api項目已經(jīng)有了初步的理解,現(xiàn)在我們調(diào)試一下,項目正常啟動并運行,如下圖:
可以看到,圖中的請求端口44317,并不是我們設(shè)置的5180,這因為,調(diào)試時使用的是快速IIS來啟動項目,等到發(fā)布后,就自然使用5180端口了。
依賴注入
這里簡單介紹一下NetCore提供的依賴注入。
上文中提到的,框架調(diào)用Controller時,提供了一個入?yún)ⅰ狪Logger對象,這種行為就是依賴注入。
而這種為Controller提供的入?yún)⑿袨?,在NetCore中是可以自定義增加;現(xiàn)在我們簡單的增加一個對象。
首先創(chuàng)建一個Kiba類和一個IKiba接口,如下:
public interface IKiba { string GetName(); } public class Kiba: IKiba { public string GetName() { return "Kiba518"; } }
然后在Startup的ConfigureServices里注入這個對象;代碼如下:
public void ConfigureServices(IServiceCollection services) { services.AddControllers(); services.AddTransient<IKiba,Kiba>(); //依賴注入 }
然后在Controller的構(gòu)造函數(shù)中,增加IKiba類型參數(shù),代碼如下:
public WeatherForecastController(IKiba _kiba) { string name = _kiba.GetName(); }
這樣,就完成了依賴注入,我們運行代碼,在構(gòu)造函數(shù)里打斷點,測試一下,是否可以獲取到值。
如上圖所示,我們得到了剛剛注入的依賴。
發(fā)布
Net Core Web Api創(chuàng)建完成了,現(xiàn)在我們進行項目發(fā)布。
右鍵項目,選擇發(fā)布,如下圖:
點擊后,彈出選取發(fā)布目標界面,如下圖:
在界面中選擇文件夾,然后在選擇文件夾文本框中輸入發(fā)布路徑。
然后點擊高級,彈出高級配置界面,如下圖:
修改配置中的部署模式為【獨立】,目標運行時為【win-x64】(因為我的測試機是X64的)。
然后點擊保存,頁面返回上一級,然后點擊創(chuàng)建配置文件。
然后系統(tǒng)進入發(fā)布界面,如下圖:
點擊發(fā)布按鈕進行發(fā)布,然后耐心等待。
如上圖,項目發(fā)布成功,現(xiàn)在進入發(fā)布的文件夾,會看到很多文件,我們在其中找到CorePublishForNginX.exe;然后雙擊運行,測試一下是否可以訪問。
雙擊后運行結(jié)果如下圖所示:
WebApi項目啟動成功,現(xiàn)在我們訪問下http://127.0.0.1:5180/weatherforecast。
如上圖所示,訪問成功。
PS:這里需要注意,CMD窗口不能關(guān)閉,一旦關(guān)閉,網(wǎng)站會停止運行,因為CMD窗口是網(wǎng)站的宿主進程。
NginX下發(fā)布Net Core Web Api
現(xiàn)在我們使用NginX的反向代理,將客戶的請求發(fā)送到NetCoreWebApi項目中。
首先進入官網(wǎng)下載NginX,點擊nginx/windows-1.17.8,下載Windows版本的NginX,如下圖所示。官網(wǎng)地址:http://nginx.org/en/download.html
下載完成后,解壓縮到一個英文目錄下,內(nèi)容如下圖所示。
conf文件夾為配置,我們雙擊進入conf文件夾,如下圖所示。
在文件夾內(nèi)找到配置文件nginx.conf,用記事本將其打開,然后在這里進行相應(yīng)的配置。
上文中,我們的WebApi項目監(jiān)聽的是5180端口,而NginX啟動后默認監(jiān)聽的是80端口;也就是說,我們需要在NginX的配置文件中,將80端口監(jiān)聽到的消息,轉(zhuǎn)發(fā)到5180端口上。
打開nginx.conf文件,修改內(nèi)容如下圖所示:
修改完成后,返回上級目錄,運行NginX.exe;這里需要注意,NginX是沒有前臺界面的,所以,是否運行成功,要去任務(wù)管理中查看,看是否有NginX.exe的進程。
運行完NginX.exe,我們訪問下http://127.0.0.1/weatherforecast,看看是否將80端口的消息發(fā)送到了5180端口。
運行結(jié)果如上圖所示,消息成功的被發(fā)送到了5180端口。
PS:在nginx.conf里,注釋符號為#。location后面有個斜杠“/”,斜杠代表根目錄,想指向子目錄,只需在斜杠后加目錄名,如/admin。
----------------------------------------------------------------------------------------------------
到此詳解Net Core Web Api項目與在NginX下發(fā)布就講解完了。
代碼已經(jīng)傳到Github上了,歡迎大家下載。
Github地址:https://github.com/kiba518/CorePublishForNginX
到此這篇關(guān)于Net Core Web Api項目與在NginX下發(fā)布的方法的文章就介紹到這了,更多相關(guān)Net Core Web Api NginX下發(fā)布內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
作者:kiba518
https://www.cnblogs.com/kiba/p/12286225.html
- .Net Core WebApi部署在Linux服務(wù)器上的方法
- .Net Core WebApi部署到Windows服務(wù)器上的步驟
- .net Core 3.0 WebApi 創(chuàng)建Linux守護進程的方法
- .Net Core3.0 WEB API中使用FluentValidation驗證(批量注入)
- .net core webapi通過中間件獲取請求和響應(yīng)內(nèi)容的方法
- .Net Core WebApi的簡單創(chuàng)建以及使用方法
- ASP.NET Core MVC/WebApi基礎(chǔ)系列2
- ASP.NET Core MVC/WebApi基礎(chǔ)系列1
- .Net Core2.1 WebAPI新增Swagger插件詳解
相關(guān)文章
解決Asp.net Mvc返回JsonResult中DateTime類型數(shù)據(jù)格式問題的方法
這篇文章主要介紹了解決Asp.net Mvc返回JsonResult中DateTime類型數(shù)據(jù)格式問題的方法,需要的朋友可以參考下2016-06-06詳解ASP.NET Core 中基于工廠的中間件激活的實現(xiàn)方法
這篇文章主要介紹了ASP.NET Core 中基于工廠的中間件激活的實現(xiàn)方法,本文給大家介紹的非常詳細,對大家的學(xué)習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-11-11asp.net中執(zhí)行存儲數(shù)據(jù)操作時數(shù)據(jù)被自動截取的一種情況
asp.net中執(zhí)行存儲數(shù)據(jù)操作時數(shù)據(jù)被自動截取的一種情況...2006-09-09jQuery AJax調(diào)用asp.net webservers的實現(xiàn)代碼
代碼是轉(zhuǎn)載來的 本來今天寫的 但是到現(xiàn)在還沒搞懂,慚愧啊2009-12-12