添加链接
link之家
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接

上次,我们讨论了如何通过配置或代码方式修改启动地址:《 ASP.NET Core启动地址配置方法及优先级顺序 》。不过是基于 .NET 5 版本的。

由于 .NET 6 使用了最小 WEB API, 配置方式已经部分发生了变化。

1. applicationUrl 属性

launchSettings.json 文件中的 applicationUrl 属性,但是仅在本地开发计算机上使用:

"profiles": {
    "WebApplication1": {
        "applicationUrl": "http://localhost:5100",
 

2.环境变量

环境变量 ASPNETCORE_URLS,有多个设置位置,下面演示的是使用 launchSettings.json 文件:

"profiles": {
    "WebApplication1": {
        "environmentVariables": {
            "ASPNETCORE_URLS": "http://localhost:5200"
 

3.命令行参数

命令行参数 --urls,有多个设置位置,下面演示的是使用 launchSettings.json 文件:

"profiles": {
    "WebApplication1": {
        "commandLineArgs": "--urls http://localhost:5300",
 

4. UseUrls 方法

.NET 5 版本

修改 ConfigureWebHostDefaults 方法:

public static IHostBuilder CreateHostBuilder(string[] args) =>
    Host.CreateDefaultBuilder(args)
        .ConfigureWebHostDefaults(webBuilder =>
            webBuilder.UseStartup<Startup>();
            webBuilder.UseUrls("http://localhost:5400");
 

.NET 6 版本

对应的方法为 WebApplicationBuilder.WebHost.UseUrls:

var builder = WebApplication.CreateBuilder(args);
builder.WebHost.UseUrls("http://localhost:5400");

但是,运行后不起作用。

结果发现这是 .NET 6 的 BUG (Builder.WebHost.UseUrls does not seem to override default url),并将在 6.0.3 中修复:https://github.com/dotnet/aspnetcore/issues/38185

5. UseKestrel 方法

.NET 5 版本

修改ConfigureWebHostDefaults方法:

public static IHostBuilder CreateHostBuilder(string[] args) =>
    Host.CreateDefaultBuilder(args)
        .ConfigureWebHostDefaults(webBuilder =>
            webBuilder.UseStartup<Startup>();
            webBuilder.UseKestrel(options=> options.ListenLocalhost(5500, opts => opts.Protocols = HttpProtocols.Http1));
 

.NET 6 版本

对应的方法为 WebApplicationBuilder.WebHost.ConfigureKestrel:

var builder = WebApplication.CreateBuilder(args);
builder.WebHost.ConfigureKestrel(options => options.ListenLocalhost(5500, opts => opts.Protocols = HttpProtocols.Http1));

6. WebApplication.Urls.Add 方法

.NET 6 版本

这是 .NET 6 下增加的新方法:

var app = builder.Build();
app.Urls.Add("http://localhost:5600");

7. appsettings.json 文件

可以在 appsettings.json 文件中设置 Kestrel 端口:

  "Kestrel": {     "Endpoints": {       "Https": {         "Url": "https://*:5701"       "Http": {         "Url": "http://*:5700"

通过将上述设置方式进行组合,发现优先级顺序如下:

  • WebApplicationBuilder.WebHost.ConfigureKestrel 方法 / appsettings.json 文件 (2者可同时起作用)

  • WebApplication.Urls.Add 方法

  • 命令行参数 --urls

  • 环境变量 ASPNETCORE_URLS

  • applicationUrl 属性

  • 默认值

如果在同一台机器上运行多个 ASP.NET Core 实例,使用默认值肯定不合适。

由于 WebApplicationBuilder.WebHost.ConfigureKestrel/WebApplication.Urls.Add 方法不能被覆盖,而环境变量 ASPNETCORE_URLS 容易造成全局影响。

建议:始终使用 appsettings.json 文件配置启动地址。

如果你觉得这篇文章对你有所启发,请关注我的个人公众号”My IO“

前言上次,我们讨论了如何通过配置或代码方式修改启动地址:《ASP.NET Core启动地址配置方法及优先级顺序》。不过是基于 .NET 5 版本的。由于 .NET 6 使用了最小 WEB ... 二、appsettings.{Environment}.json 三、用户机密(secrets.json) 四、环境变量(launchSettings.json,此文件仅用于开发环境) 五、命令行参数(dotnet run x = "xxx") 从前致后按顺序读取。 如果在多个配置源中具有密钥名称相同的配置设置(简单来说就是重名了),则后面的配置源会覆盖先前的配置源。
此文是在官方文档的基础上做的个人笔记,一些简单的内容就没用再列出来了,参考官方文档:https://docs.microsoft.com/zh-cn/aspnet/core/fundamentals/configuration/?view=aspnetcore-5.0 配置是使用一个或多个配置提供程序进行配置的。这个程序从如下的配置源中读取键值对,键不区分大小写: 配置文件,如appsettings.json,MySettings.json等(见读取自定义配置文件章节) Azure Key .
在我们实际开发过程中一般分为开发环境和生产环境, 这两个环境一般配置会有不一样, 例如数据库连接字符串. .net core 框架中提供三个值, Development(开发), Staging(分阶段), Production(生产环境). 我们可以根据这个来配置不同的环境. 创建appsettings文件 在创建项目的时候系统会默认创建一个appsettings.json 和 appsettings.Development.json文件. 其中appsettings.Development.js
ASP.NET Core MVC 是一种基于 .NET Core 的 web 框架,它不仅支持常见的 web 应用程序模式,如 MVC (Model-View-Controller) 和 API (Application Programming Interface),还提供了一系列集成工具和插件,方便开发人员进行 web 应用程序的快速开发。 在 ASP.NET Core MVC 中,图片上传方法可以通过将表单中的文件数据流存储在服务器上来实现。可以使用 IFormFile 接口和相应的绑定器来读取表单中的文件数据流。以下是一个示例代码片段,演示了如何上传并处理单个图片: public async Task<IActionResult> UploadImage(List<IFormFile> files) long size = files.Sum(f => f.Length); foreach (var formFile in files) if (formFile.Length > 0) var fileName = ContentDispositionHeaderValue.Parse (formFile.ContentDisposition).FileName.Trim('"'); var filePath = @"C:\temp\uploads\" + fileName; using (var stream = new FileStream(filePath, FileMode.Create)) await formFile.CopyToAsync(stream); return Ok(new { count = files.Count, size }); 代码中,我们首先将上传的文件存储在指定的目录中,然后返回一个包含上传的文件数量和总文件大小的 JSON 数据。这个过程可以通过简单的编辑和适当的修改快速适用于你的图片上传需求。 总的来说,ASP.NET Core MVC 提供了强大的功能和灵活性,使得开发人员能够轻松地构建和维护复杂的 web 应用程序。针对图片上传,使用 IFormFile 接口和相应的处理器,可以方便地实现图片上传的功能。