在ASP.NET Core中,如果在Kestrel中想使用HTTPS对站点进行加密传输,可以按照如下方式
申请证书
这一步就不详细说了,有免费的和收费的,申请完成之后会给你一个*.pfx结尾的文件。
添加NuGet包
nuget中查找然后再程序中添加引用Microsoft.AspNetCore.Server.Kestrel.Https
配置
把*.pfx结尾的文件拷贝的程序的Web根目录,然后修改Programs.cs文件:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
public class Program
{
public static void Main( string [] args) {
var config = new ConfigurationBuilder().AddCommandLine(args).AddEnvironmentVariables( "ASPNETCORE_" ).Build();
var host =
new WebHostBuilder().UseConfiguration(config).UseKestrel(ConfigHttps()).UseContentRoot(
Directory.GetCurrentDirectory()).UseIISIntegration().UseStartup<Startup>().Build();
host.Run();
}
private static Action<KestrelServerOptions> ConfigHttps() {
return x => {
var pfxFile = Path.Combine(Directory.GetCurrentDirectory(), "*.pfx" );
//password 填写申请的密钥
var certificate = new X509Certificate2(pfxFile, "password" );
x.UseHttps(certificate);
};
}
}
|
然后命令行窗口运行dotnet xxx.dll --server.urls https://www.example.com:port即可。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://www.cnblogs.com/savorboard/p/aspnetcore-kestrel-https.html