欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

.Net8?WebAPI項(xiàng)目創(chuàng)建部署的實(shí)現(xiàn)

 更新時(shí)間:2025年05月08日 09:36:46   作者:SmileGift  
本文主要介紹了.Net8?WebAPI項(xiàng)目創(chuàng)建部署的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

本著學(xué)新不學(xué)舊的原則,.Net Core會(huì)逐步替代.Net Framework,并且是開源框架,能用在什么地方懂的都懂。本文記錄了Net8框架下的Web API項(xiàng)目創(chuàng)建到部署過程。

1、創(chuàng)建項(xiàng)目

新建項(xiàng)目選擇ASP.NET Core Web API,太多了的話可以在上面篩選

如果沒有去VS Installer添加“ASP.NET 和 Web開發(fā)”模塊并安裝。

安裝

創(chuàng)建項(xiàng)目

配置項(xiàng)目

配置HTTPS:方便測試不勾選。
不使用頂級語句:勾選后是傳統(tǒng)的Program類中定義Main函數(shù)入口;不勾選直接就是指令有點(diǎn)抽象不符合C#習(xí)慣,夠不夠選看個(gè)人。
使用控制器:不勾選會(huì)在Program中寫方法,看著亂,建議勾選。

項(xiàng)目配置

2、項(xiàng)目結(jié)構(gòu)和解釋

項(xiàng)目結(jié)構(gòu)

項(xiàng)目結(jié)構(gòu)

Main函數(shù)配置解釋:

namespace WebAPI記錄
{
    public class Program
    {
        public static void Main(string[] args)
        {
            var builder = WebApplication.CreateBuilder(args);

            // Add services to the container.

            builder.Services.AddControllers();

            //注入swagger
            // Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
            builder.Services.AddEndpointsApiExplorer(); //生成文檔
            builder.Services.AddSwaggerGen();   //設(shè)置文檔內(nèi)容

            var app = builder.Build();

            // Configure the HTTP request pipeline.
            if (app.Environment.IsDevelopment())    //只有當(dāng)程序處于debug的情況才開啟swagger
            {
                //分別注入中間件和ui中間間
                app.UseSwagger();
                app.UseSwaggerUI();
            }

            app.UseAuthorization();


            app.MapControllers();

            app.Run();
        }
    }
}

Controller解釋:

using Microsoft.AspNetCore.Mvc;

namespace WebAPI記錄.Controllers
{
    [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;
        }

		// http://ip:port/WeatherForecast
        [HttpGet(Name = "GetWeatherForecast")]	// 創(chuàng)建Get請求
        public IEnumerable<WeatherForecast> Get()
        {
            return Enumerable.Range(1, 5).Select(index => new WeatherForecast
            {
                Date = DateOnly.FromDateTime(DateTime.Now.AddDays(index)),
                TemperatureC = Random.Shared.Next(-20, 55),
                Summary = Summaries[Random.Shared.Next(Summaries.Length)]
            })
            .ToArray();
        }
    }
}
.ToArray();
        }
    }
}

LaunchSettings.json配置文件:

記錄了端口配置信息等。

{
  "$schema": "http://json.schemastore.org/launchsettings.json",
  "iisSettings": {
    "windowsAuthentication": false,
    "anonymousAuthentication": true,
    "iisExpress": {
      "applicationUrl": "http://localhost:12692",
      "sslPort": 0
    }
  },
  "profiles": {
    "http": {
      "commandName": "Project",
      "dotnetRunMessages": true,
      "launchBrowser": true,
      "launchUrl": "swagger",
      "applicationUrl": "http://localhost:5053",
      "environmentVariables": {
        "ASPNETCORE_ENVIRONMENT": "Development"
      }
    },
    "IIS Express": {
      "commandName": "IISExpress",
      "launchBrowser": true,
      "launchUrl": "swagger",
      "environmentVariables": {
        "ASPNETCORE_ENVIRONMENT": "Development"
      }
    }
  }
}

3、本地運(yùn)行

可以選擇http或者IIS方式運(yùn)行,端口見上面json內(nèi)的配置

運(yùn)行方式

運(yùn)行效果

Debug模式下會(huì)進(jìn)入Swagger頁面(見上面Main函數(shù)注釋),以UI形式方便觀察測試接口和結(jié)果

Swagger

Swagger

點(diǎn)擊Execute查看請求URL和返回結(jié)果

本地測試

至此本地測試完成

4、生成項(xiàng)目

選擇菜單欄中的 生成 -> 發(fā)布。

目標(biāo)可以選文件夾,簡單一點(diǎn)

發(fā)布

默認(rèn)路徑是生成文件夾下的publish目錄

發(fā)布

點(diǎn)擊發(fā)布編譯生成項(xiàng)目

發(fā)布

編譯

生成成功后可以直接到生成目錄下:

生成

5、服務(wù)器遠(yuǎn)程部署(Windows)

部署環(huán)境:Window Server 2016

(1)安裝IIS

這邊簡單寫了,詳細(xì)自行查詢

服務(wù)器管理器 -> 添加功能 -> 安裝IIS

(2)安裝NetCore運(yùn)行時(shí)

進(jìn)入微軟官網(wǎng)下載運(yùn)行時(shí)Download .NET 8.0 (Linux, macOS, and Windows),選擇HostBundle包即可。

NETCore

安裝完后,右鍵找到IIS管理器:

IIS

在模塊下出現(xiàn)AspNetCoreModuleV2表示安裝成功:

在這里插入圖片描述

在這里插入圖片描述

(3)配置IIS

添加應(yīng)用程序池:

應(yīng)用程序池

輸入名稱,選擇”無托管代碼“:

應(yīng)用程序池

將發(fā)布生成的文件夾傳到服務(wù)器上去,過程略。

IIS添加網(wǎng)站:

應(yīng)用程序池選擇剛才創(chuàng)建的
物理路徑選擇剛才上傳的文件夾
綁定的端口選擇空端口(不用和項(xiàng)目中json配置的一樣)

添加網(wǎng)站

編輯權(quán)限中創(chuàng)建一個(gè)完全控制權(quán)限的賬戶

創(chuàng)建用戶權(quán)限

點(diǎn)擊”啟動(dòng)“運(yùn)行,發(fā)現(xiàn)什么都沒有。別忘記我們做的是API不是網(wǎng)站,地址換成接口URL就有了

測試結(jié)果

測試結(jié)果

Postman遠(yuǎn)程測試也沒有問題:

POSTMAN測試

6、新增自定義接口

Controllers文件夾添加控制器

新增控制器

新增控制器

命名方式注意以Controller結(jié)尾

新增控制器

創(chuàng)建好后代碼自動(dòng)繼承Controller。

[Route(“[controller]”)]表示URL以類名MyAPI為路由地址,希望其他地址直接改字符串就行。

列舉了4個(gè)請求的例子:

using Microsoft.AspNetCore.Mvc;

namespace WebAPI記錄.Controllers
{
    [ApiController]
    [Route("[controller]")]
    public class MyAPIController : Controller
    {
        // http://ip:port
        [HttpGet]
        public string GetString()
        {
            return "Hello";
        }

        // http://ip:port/myapi/id
        [HttpGet("id")]
        public string GetStringByID([FromHeader]int id) // FromHeader屬性表示從請求頭獲得參數(shù)
        {
            return "Hello " + id.ToString();
        }

        // http://ip:port/myapi/result
        [HttpGet("result")]
        public IActionResult GetStringResult()
        {
            var data = new { Message = "Hello" };
            return Ok(data);    // Ok返回包含請求數(shù)據(jù)的HTTP 200
        }

        // http://ip:port/postdata
        [HttpPost("postdata")]
        public IActionResult PostData([FromBody] DataModel data)    // FromBody屬性表示從請求的Body中讀取并轉(zhuǎn)為DataModel類
        {
            // 在這里處理接收到的數(shù)據(jù)
            return CreatedAtAction(nameof(PostData), null, new { Message = data }); // CreatedAtAction返回包含創(chuàng)建資源的 URL 的 HTTP 201 響應(yīng)
        }
    }
}

DataModel類:

namespace WebAPI記錄
{
    public class DataModel
    {
        public string Name { get; set; }
        public int Value { get; set; }
    }
}

運(yùn)行后已經(jīng)可以訪問結(jié)果了

運(yùn)行結(jié)果

測試結(jié)果:

測試結(jié)果

測試結(jié)果

測試結(jié)果

到此這篇關(guān)于.Net8 WebAPI項(xiàng)目創(chuàng)建部署的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān).Net8 WebAPI創(chuàng)建部署內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家! 

相關(guān)文章

最新評論