如何在启动类

时间:2017-01-06 21:56:23

标签: asp.net-core kestrel-http-server

我正在尝试找出修改kestrel从Startup类构造函数 监听的URL的正确方法。

更新:除了下面的答案,我已经明白启动课程并不像我想象的那样配置Kestrel。我原以为Startup会创建一个单独的应用程序范围的配置对象,它可以通过约定来定位,但事实并非如此。正如@Tseng所指出的,应用程序和托管的配置是另外一个问题。链接的答案和接受的答案提供了工作示例。

我在Vagrant中创建了一个全新的Ubuntu 14盒子,并根据Microsoft当前的说明安装了ASP.NET Core 1.1:https://www.microsoft.com/net/core#linuxubuntu

我跑了:

  • dotnet new -t web
  • dotnet restore
  • dotnet run

默认情况下会侦听http://localhost:5000。在Program.cs中,我可以调用app.UseUrls(" http:// *:5001),这可以改变URL和端口。

我真正想要的是通过在Startup类中添加一个新的JSON设置文件来按照惯例更改URL,所以我按照示例创建了一个hosting.JSON文件(注意:我已经尝试过&# 34; server.urls"和" urls"作为密钥)。

{
  urls: "http://*:5001"
}

在Startup.cs下面添加appsettings.json文件的默认行我添加.AddJsonFile(" hosting.json",optional:false); (可选:false以确保它正在拾取文件)

public Startup(IHostingEnvironment env)
{
  var builder = new ConfigurationBuilder()
  .SetBasePath(env.ContentRootPath)
  .AddJsonFile("appsettings.json", optional: true, reloadOnChange: true)
  .AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true)
  .AddJsonFile("hosting.json", optional: false);
  if (env.IsDevelopment())
  {
    // For more details on using the user secret store see https://go.microsoft.com/fwlink/?LinkID=532709
    builder.AddUserSecrets();
  }

  builder.AddEnvironmentVariables();
  Configuration = builder.Build();
}

我已经验证配置构建后设置是否存在,但是当在Program.cs中构建主机时,它没有被选中或使用

public class Program
{
  public static void Main(string[] args)
  {
    var host = new WebHostBuilder()
    .UseKestrel()
    .UseContentRoot(Directory.GetCurrentDirectory())
    .UseIISIntegration()
    .UseStartup<Startup>()
    .Build();

    host.Run();
  }
}

并且应用程序仍然开始侦听localhost:5000。我的(可能是不正确的)理解是,通过使用正确的密钥正确命名设置,WebHostBuidler应该选择并使用它。

我已经看到其他基本上摆脱了启动类并在Program.cs中创建配置的示例,然后可以将其传递给UseConfiguration调用,但我的理解是使用Startup类应按惯例执行此操作。

基本上 我希望将启动和程序分开 ,将host.JSON文件添加到包含URL的配置中,并将其拾取并使用无需调用UseUrls,UseConfiguration等

我是否遗漏了一些明显的东西,或者试图做一些实际上不正确的事情?

根据我的评论解释为什么这不重复:

  • 该帖子明确说明&#34; launcherSettings适用于Visual Studio F5&#34;。我在Linux机器上使用命令行。与VS没什么关系。

  • 该帖子中提供的解决方案将配置构建移动到main方法中。我特别声明我想在Startup类中构建我的配置,就像默认的&#34; dotnet new -t web&#34;项目

我不认为这是重复的,我仍然在查看ASP.NET Core源代码,看看是否可行。

关于正确的密钥:

https://github.com/aspnet/Hosting/blob/b6da89f54cff11474f17486cdc55c2f21f2bbd6b/src/Microsoft.AspNetCore.Hosting.Abstractions/WebHostDefaults.cs

namespace Microsoft.AspNetCore.Hosting
{
  public static class WebHostDefaults
  {
    public static readonly string ApplicationKey = "applicationName";
    public static readonly string StartupAssemblyKey = "startupAssembly";
    public static readonly string DetailedErrorsKey = "detailedErrors";
    public static readonly string EnvironmentKey = "environment";
    public static readonly string WebRootKey = "webroot";
    public static readonly string CaptureStartupErrorsKey = "captureStartupErrors";
    public static readonly string ServerUrlsKey = "urls";
    public static readonly string ContentRootKey = "contentRoot";
  }
}

https://github.com/aspnet/Hosting/blob/80ae7f056c08b740820ee42a7df9eae34541e49e/src/Microsoft.AspNetCore.Hosting/Internal/WebHost.cs

public class WebHost : IWebHost
{
  private static readonly string DeprecatedServerUrlsKey = "server.urls";

1 个答案:

答案 0 :(得分:5)

在您的hosting.json文件中,您应该使用server.urls而不是urls。而hosting.json文件需要在program.cs中添加(在main方法中)而不是在启动时。

这是我的hosting.json文件。

public static void Main(string[] args)
{
    var config = new ConfigurationBuilder()
        .SetBasePath(Directory.GetCurrentDirectory())
        .AddCommandLine(args)
        .AddEnvironmentVariables(prefix: "ASPNETCORE_")
        .AddJsonFile("hosting.json", optional: true)
        .Build();

    var host = new WebHostBuilder()
        .UseConfiguration(config)
        .UseKestrel()
        .UseContentRoot(Directory.GetCurrentDirectory())
        .UseIISIntegration()
        .UseStartup<Startup>()
        .Build();

    host.Run();
}

这是Main方法。

Public Declare Function Shell_NotifyIcon Lib "shell32" _
      Alias "Shell_NotifyIconA" _
      (ByVal dwMessage As Long, pnid As NOTIFYICONDATA) As Boolean

这是截图。

Screenshot of ASP.NET Core app running