詳解Net Core Web Api項目與在NginX下發佈

来源:https://www.cnblogs.com/kiba/archive/2020/02/25/12286225.html
-Advertisement-
Play Games

前言 本文將介紹Net Core的一些基礎知識和如何NginX下發佈Net Core的WebApi項目。 測試環境 操作系統:windows 10 開發工具:visual studio 2019 框架:Net Core 3 Net Core Web Api項目創建 首先創建一個Net Core We ...


前言

本文將介紹Net Core的一些基礎知識和如何NginX下發佈Net Core的WebApi項目。

測試環境

操作系統:windows 10

開發工具:visual studio 2019

框架:Net Core 3

Net Core Web Api項目創建

首先創建一個Net Core Web Api項目——CorePublishForNginX。

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

然後修改項目名稱,如下圖:

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

項目創建完成,如下圖:

代碼介紹

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項目已經有了初步的理解,現在我們調試一下,項目正常啟動並運行,如下圖:

可以看到,圖中的請求埠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創建完成了,現在我們進行項目發佈。

右鍵項目,選擇發佈,如下圖:

點擊後,彈出選取發佈目標界面,如下圖:

在界面中選擇文件夾,然後在選擇文件夾文本框中輸入發佈路徑。

然後點擊高級,彈出高級配置界面,如下圖:

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

然後點擊保存,頁面返回上一級,然後點擊創建配置文件。

然後系統進入發佈界面,如下圖:

點擊發佈按鈕進行發佈,然後耐心等待。

如上圖,項目發佈成功,現在進入發佈的文件夾,會看到很多文件,我們在其中找到CorePublishForNginX.exe;然後雙擊運行,測試一下是否可以訪問。

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

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

 如上圖所示,訪問成功。

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

NginX下發佈Net Core Web Api

現在我們使用NginX的反向代理,將客戶的請求發送到NetCoreWebApi項目中。

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

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

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

在文件夾內找到配置文件nginx.conf,用記事本將其打開,然後在這裡進行相應的配置。

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

打開nginx.conf文件,修改內容如下圖所示:

修改完成後,返回上級目錄,運行NginX.exe;這裡需要註意,NginX是沒有前臺界面的,所以,是否運行成功,要去任務管理中查看,看是否有NginX.exe的進程。

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

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

PS:在nginx.conf 里,註釋符號為 #。

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

到此詳解Net Core Web Api項目與在NginX下發佈就講解完了。

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

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

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

註:此文章為原創,任何形式的轉載都請聯繫作者獲得授權並註明出處!
若您覺得這篇文章還不錯,請點擊下方的推薦】,非常感謝!

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

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 使用Aspose組件導出 Aspose有Aspose.Slides.dll,可以無需安裝office,進行讀寫PPT文件。 Aspose可能通過Aspose.Slides.NET安裝 簡單的導出圖片demo,如下: 1 internal class PptToImagesConverter 2 { ...
  • 作為初學者來說,在C#中使用API確是一件令人頭疼的問題。 在使用API之前你必須知道如何在C#中使用結構、類型轉換、安全/不安全代碼,可控/不可控代碼等許多知識。 在.Net Framework SDK文檔中,關於調用Windows API的指示比較零散,並且其中稍全面一點的是針對Visual B ...
  • 一、前言 接上一篇《asp.net core 3.x 授權中的概念》,本篇看看asp.net core預設授權的流程。從兩個方面來看整個授權系統是怎麼運行的:啟動階段的配置、請求階段中間件的處理流程。 由於asp.net core 3.x目前使用終結點路由,因此授權框架可以用於所有asp.net w ...
  • 前言 本章將介紹客戶端緩存將介紹瀏覽器緩存和服務端緩存,使用瀏覽器緩存將減少對web伺服器的請求次數,同時可以提升性能,避免重覆的運算浪費。 ASP.NET Core對於HTTP緩存分為兩種: 客戶端(瀏覽器緩存) 服務端緩存 客戶端緩存 通過設置HTTP的響應頭 Cache Control 來完成 ...
  • 今天在iis伺服器配置asp.net網站,遇到一個問題,記錄一下: 問題:由於擴展配置問題而無法提供您請求的頁面。如果該頁面是腳本,請添加處理程式。如果應下載文件,請添加 MIME 映射。 WindowServer2012伺服器,添加角色安裝完.netframework和iis之後,運行aspx頁面 ...
  • 下載個推SDK,找到這兩個dll直接引用。 using引用 using com.gexin.rp.sdk.dto; using com.igetui.api.openservice; using com.igetui.api.openservice.igetui; using com.igetui. ...
  • using System; using System.Collections.Generic; using System.Diagnostics; using System.IO; using System.Threading; using Newtonsoft.Json; using System ...
  • 一.介紹 Redis is an open source (BSD licensed), in-memory data structure store, used as a database, cache and message broker. It supports data structures ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...