1. 程式人生 > 程式設計 >Net Core Web Api專案與在NginX下發布的方法

Net Core Web Api專案與在NginX下發布的方法

前言

本文將介紹Net Core的一些基礎知識和如何NginX下發布Net Core的WebApi專案。

測試環境

  • 作業系統:windows 10
  • 開發工具:visualstudio 2019
  • 框架:Net Core 3

Net Core WebApi專案建立

首先建立一個Net Core WebApi專案——CorePublishForNginX。

首先選擇Asp.Net Core Web應用程式,如下圖:

Net Core Web Api專案與在NginX下發布的方法

然後修改專案名稱,如下圖:

Net Core Web Api專案與在NginX下發布的方法

然後選擇Api選項,如下圖:

Net Core Web Api專案與在NginX下發布的方法

專案建立完成,如下圖:

Net Core Web Api專案與在NginX下發布的方法

程式碼介紹

Controller

專案建立完成後,我們可以看到,裡面內建了一個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)

然後,我們發現Controller有一個建構函式,並且還有一個入參;我們知道Controller的呼叫是框架的內部機制,也就是說,框架在呼叫Controller時會給他一個入參。

通過名稱我們可以發現,這個是一個日誌入參,即,Core呼叫Controller時,為我們內建了一個日誌記錄物件。

這裡我們不需要使用日誌,所以可以先把這個建構函式刪除。

接下來,我們看到了Api請求實現的主體,Get請求。

主體現的很簡單,就是方法名用Get,然後方法頭上加HttpGet特性。(Get方法名是可以修改的,因為一個WebApi裡只支援一個Get請求,所以只要方法加了HttpGet特性,就會被視為預設的Get方法)

Get請求裡實現了一個實體集合的元件,即請求該Controller會得到一個實體集合的陣列。

Program

學習完Controller,我們進入Program.cs檔案,我們做下簡單的修改,設定一下Kestrel的啟動埠。

修改CreateHostBuilder程式碼如下:

public static IHostBuilder CreateHostBuilder(string[] args)
{
  return Host.CreateDefaultBuilder(args).ConfigureWebHostDefaults(
     webBuilder =>
     {
       //設定專案的啟動檔案
       webBuilder.UseStartup<Startup>();
       //Kestrel的預設監聽埠是http5000、https5001。
       webBuilder.ConfigureKestrel(options =>
       {
         options.ListenAnyIP(5180);//監聽本機任意ip的5180埠,相當於設定ip0.0.0.0
                      //options.Listen(new IPEndPoint(IPAddress.Parse("127.0.0.1"),5180));//監聽指定ip的指定埠
       }); ;
     });
}

Startup

Startup的呼叫順序如下:

Startup建構函式——ConfigureServices配置服務函式——Configure請求配置

Startup建構函式:

這裡做了簡單配置資訊物件提取,實戰中,像啟動日誌這樣的操作也可以集中放在這裡。

ConfigureServices配置服務函式:

這裡只添加了一個控制器服務,實戰中,還可以新增更多服務,比如使用services.AddCors新增跨域服務。

Configure請求配置:

這裡做了一些請求配置,如:

app.UseDeveloperExceptionPage()——設定請求異常時的顯示內容為內建異常錯誤介面(在Mvc模式下,還可以指定請求異常時的顯示介面,如:app.UseExceptionHandler("/Home/Error");)

app.UseHttpsRedirection()——Https請求重定向,將Http請求轉換成Https,增加一些安全性。(還可以追加app.UseHsts(),要求瀏覽器只發送https,實現安全雙保險)

app.UseRouting()——配置endpointRouteBuilder。

app.UseEndpoints——使用endpointRouteBuilder。UseRouting與UseEndpoints組合實現路由。

app.UseAuthorization()——請求的授權處理,因為沒有沒有新增授權服務services.AddAuthorization,所以這裡它是無效的。

----------------------------------------------------------------------------------------------------

到此,我們對Net Core Web Api專案已經有了初步的理解,現在我們除錯一下,專案正常啟動並執行,如下圖:

Net Core Web Api專案與在NginX下發布的方法

可以看到,圖中的請求埠44317,並不是我們設定的5180,這因為,除錯時使用的是快速IIS來啟動專案,等到釋出後,就自然使用5180埠了。

依賴注入

這裡簡單介紹一下NetCore提供的依賴注入。

上文中提到的,框架呼叫Controller時,提供了一個入參—ILogger物件,這種行為就是依賴注入。

而這種為Controller提供的入參行為,在NetCore中是可以自定義增加;現在我們簡單的增加一個物件。

首先建立一個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的建構函式中,增加IKiba型別引數,程式碼如下:

public WeatherForecastController(IKiba _kiba)
{ 
  string name = _kiba.GetName(); 
}

這樣,就完成了依賴注入,我們執行程式碼,在建構函式裡打斷點,測試一下,是否可以獲取到值。

Net Core Web Api專案與在NginX下發布的方法

如上圖所示,我們得到了剛剛注入的依賴。

釋出

Net Core Web Api建立完成了,現在我們進行專案釋出。

右鍵專案,選擇釋出,如下圖:

Net Core Web Api專案與在NginX下發布的方法

點選後,彈出選取釋出目標介面,如下圖:

Net Core Web Api專案與在NginX下發布的方法

在介面中選擇資料夾,然後在選擇資料夾文字框中輸入釋出路徑。

然後點選高階,彈出高階配置介面,如下圖:

Net Core Web Api專案與在NginX下發布的方法

修改配置中的部署模式為【獨立】,目標執行時為【win-x64】(因為我的測試機是X64的)。

然後點選儲存,頁面返回上一級,然後點選建立配置檔案。

然後系統進入釋出介面,如下圖:

Net Core Web Api專案與在NginX下發布的方法

點擊發布按鈕進行釋出,然後耐心等待。

Net Core Web Api專案與在NginX下發布的方法

如上圖,專案釋出成功,現在進入釋出的資料夾,會看到很多檔案,我們在其中找到CorePublishForNginX.exe;然後雙擊執行,測試一下是否可以訪問。

Net Core Web Api專案與在NginX下發布的方法

雙擊後執行結果如下圖所示:

Net Core Web Api專案與在NginX下發布的方法

WebApi專案啟動成功,現在我們訪問下http://127.0.0.1:5180/weatherforecast。

Net Core Web Api專案與在NginX下發布的方法

如上圖所示,訪問成功。

PS:這裡需要注意,CMD視窗不能關閉,一旦關閉,網站會停止執行,因為CMD視窗是網站的宿主程序。

NginX下發布Net Core Web Api

現在我們使用NginX的反向代理,將客戶的請求傳送到NetCoreWebApi專案中。

首先進入官網下載NginX,點選nginx/windows-1.17.8,下載Windows版本的NginX,如下圖所示。官網地址:http://nginx.org/en/download.html

Net Core Web Api專案與在NginX下發布的方法

下載完成後,解壓縮到一個英文目錄下,內容如下圖所示。

Net Core Web Api專案與在NginX下發布的方法

conf資料夾為配置,我們雙擊進入conf資料夾,如下圖所示。

Net Core Web Api專案與在NginX下發布的方法

在資料夾內找到配置檔案nginx.conf,用記事本將其開啟,然後在這裡進行相應的配置。

上文中,我們的WebApi專案監聽的是5180埠,而NginX啟動後預設監聽的是80埠;也就是說,我們需要在NginX的配置檔案中,將80埠監聽到的訊息,轉發到5180埠上。

開啟nginx.conf檔案,修改內容如下圖所示:

Net Core Web Api專案與在NginX下發布的方法

修改完成後,返回上級目錄,執行NginX.exe;這裡需要注意,NginX是沒有前臺介面的,所以,是否執行成功,要去任務管理中檢視,看是否有NginX.exe的程序。

執行完NginX.exe,我們訪問下http://127.0.0.1/weatherforecast,看看是否將80埠的訊息傳送到了5180埠。

Net Core Web Api專案與在NginX下發布的方法

執行結果如上圖所示,訊息成功的被髮送到了5180埠。

PS:在nginx.conf裡,註釋符號為#。location後面有個斜槓“/”,斜槓代表根目錄,想指向子目錄,只需在斜槓後加目錄名,如/admin。

----------------------------------------------------------------------------------------------------

到此詳解Net Core Web Api專案與在NginX下發布就講解完了。

程式碼已經傳到Github上了,歡迎大家下載。

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

到此這篇關於Net Core Web Api專案與在NginX下發布的方法的文章就介紹到這了,更多相關Net Core Web Api NginX下發布內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!

作者:kiba518

https://www.cnblogs.com/kiba/p/12286225.html