ASP.NET Core 2 - develop using custom domain names and ssl using IISExpress

坚强是说给别人听的谎言 提交于 2019-12-07 08:44:52

问题


I want to be able to develop locally using a custom domain and ssl rather than localhost.

How can I setup a custom domain + ssl in VS Solution instead of localhost?


回答1:


Simple Setup - Using Server URLs

If you want to associate your server to use all the IP addresses assigned to the server/web host then you can do this:

var host = new WebHostBuilder()
    .UseUrls("http://*:80", "http://localhost")
    .UseKestrel()
    .UseIISIntegration()
    .Build();

Note: If you don't want all IP addresses, then you can change from http://* to a specific IP address such as http://111.111.111.111. Also, the port is not a requirement, but I have used it for completeness of the answer. It's also important to note that SSL won't work with UseUrls

There is a great amount of additional detail that you can find over at the official Microsoft Docs about Server URLs here.


Binding SSL Certifications (Kestrel Only) -- Endpoint Configuration

Please note that hosting over a public endpoint via Kestrel (even with SSL) is not recommended and you should use a reverse proxy like Nginx or IIS. You can read more about it from the official Microsoft Docs here.

You didn't mention if you were using Kestrel or not, but I will assume you are... In which case, you can configure an SSL certificate easily by binding sockets using the options.

Here is an example of using TCP sockets using the Listen method:

public static void Main(string[] args)
{
    BuildWebHost(args).Run();
}

public static IWebHost BuildWebHost(string[] args) =>
    WebHost.CreateDefaultBuilder(args)
        .UseStartup<Startup>()
        .UseKestrel(options =>
        {
            options.Listen(IPAddress.Loopback, 5000);
            options.Listen(IPAddress.Loopback, 5001, listenOptions =>
            {
                listenOptions.UseHttps("testCert.pfx", "testPassword");
            });
        })
        .UseIISIntegration() // <-- don't forget you will need this for IIS!
        .Build();

Note: That if you use both the Listen method and UseUrls, the Listen endpoints override the UseUrls endpoints.

You can find more info here at the official Microsoft Docs.


Configuring IISExpress

Using the GUI
You can right-click the project and click [Properties].

Using launchSettings.json.
You have to configure this using the launchSettings.json which you can find here:

"iisSettings": {
  "windowsAuthentication": false,
  "anonymousAuthentication": true,
  "iisExpress": {
    "applicationUrl": "http://localhost:61471/",
    "sslPort": 44360
  }
},
"profiles": {
  "IIS Express": {
  "commandName": "IISExpress",
  "launchBrowser": true,
  "launchUrl": "https://localhost:44360",
  "environmentVariables": {
    "ASPNETCORE_ENVIRONMENT": "Development"
  }
}

Configuring IIS Endpoints

If you use IIS, the URL bindings for IIS override any bindings that you set by calling either Listen or UseUrls. For more information, see Introduction to ASP.NET Core Module.




回答2:


If you're fine with the certificate validation error in your browser (or whatever client you use), you can put an entry in your hosts file:

www.yourcustomdomain.com 127.0.0.1 (or ::1 if you're on IPv6)

and then use the custom domain to reach your web site locally.

In Windows the hosts file is usually located at C:\Windows\System32\drivers\etc.




回答3:


For .net core, to setup a custom domain:

1) Add domain to the hosts file, something like www.yourapp.local

2) find the solution /.vs/applicationhost.config Add binding e.g.:

<binding protocol="http" bindingInformation="*:51791:www.yourapp.local" />

3) In the web project properties > Debug add the App Url to "http://www.yourapp.local"51791/"

(replace port number as required)

For SSL, I assume you can set the above bindings and settings to https and in the web app properties > Debug tick the "Enable SSL" checkbox.

also see this answer: How to enable SSL for IIS Express in VS2015




回答4:


First, add an entry in the client's C:\Windows\System32\drivers\etc\hosts text file. Follow instructions in the hosts file itself.

By "develop locally" do you mean on the local machine or local network? If the latter, you must complete the following tasks (in any order).

  • Generate as described here and configure as described here a certificate on the server, and install it on the client.
  • Configure the firewall to allow access to your web API as described here.
  • Bind your web API to a non-localhost URL as described here and here.

I'm not sure off hand, but to get it working with IIS Express you might also need to run netsh http add urlacl as described here and here.

Some of the above links are specific to IIS Express since that's what you asked about. If using Kestrel, then vary the above tasks as follows.

To configure your certificate on the server, add this to appsettings.json:

"Kestrel": {
    "Certificates": {
        "Default": {
            "Subject": "api.mycustomdomain.com",
            "Store": "My",
            "AllowInvalid": true
        }
    }
}

To bind your web API to a non-localhost URL, in launchSettings.json's Kestrel profile, replace the localhost part of applicationUrl's value with 0.0.0.0.



来源:https://stackoverflow.com/questions/46618360/asp-net-core-2-develop-using-custom-domain-names-and-ssl-using-iisexpress

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!