是的,ASP.NET Core 3.1 Web API 可以作为 Windows 服务进行自托管,并使用类似 IIS 的 HTTPS 和证书。下面是一个示例解决方法:
首先,确保你的 ASP.NET Core 3.1 Web API 项目已经创建并可以在本地运行。
接下来,我们需要编写一个自定义的 Program.cs
文件来作为 Windows 服务的入口点。
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Hosting;
namespace YourWebApiNamespace
{
public class Program
{
public static void Main(string[] args)
{
CreateHostBuilder(args).Build().Run();
}
public static IHostBuilder CreateHostBuilder(string[] args) =>
Host.CreateDefaultBuilder(args)
.UseWindowsService()
.ConfigureWebHostDefaults(webBuilder =>
{
webBuilder.UseStartup();
});
}
}
然后,在 Startup.cs
文件中,我们需要配置 HTTPS 和证书。
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
namespace YourWebApiNamespace
{
public class Startup
{
private readonly IConfiguration _configuration;
public Startup(IConfiguration configuration)
{
_configuration = configuration;
}
public void ConfigureServices(IServiceCollection services)
{
// 添加 HTTPS 支持
services.AddHttpsRedirection(options =>
{
options.RedirectStatusCode = StatusCodes.Status307TemporaryRedirect;
options.HttpsPort = 443;
});
// 添加证书
services.Configure(_configuration.GetSection("Kestrel"));
}
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
app.UseHttpsRedirection();
app.UseRouting();
app.UseEndpoints(endpoints =>
{
endpoints.MapControllers();
});
}
}
}
最后,在项目的根目录下创建一个名为 appsettings.json
的配置文件,用于存储证书的相关信息。
{
"Kestrel": {
"Endpoints": {
"Https": {
"Url": "https://localhost:443",
"Certificate": {
"Path": "path/to/your/certificate.pfx",
"Password": "your_certificate_password"
}
}
}
}
}
将 "path/to/your/certificate.pfx"
替换为你的证书文件的路径,将 "your_certificate_password"
替换为你的证书密码。
现在,你可以将项目发布为自包含的可执行文件,并将其安装为 Windows 服务。
dotnet publish --configuration Release --output ./publish --self-contained true --runtime win-x64
sc create YourServiceName binPath= "C:\path\to\your\project\publish\YourProjectName.exe"
将 "YourServiceName"
替换为你希望为服务指定的名称,将 "C:\path\to\your\project\publish\YourProjectName.exe"
替换为你的项目的可执行文件路径。
现在,你可以在 Windows 服务中找到并启动你的 ASP.NET Core 3.1 Web API 服务,并通过 HTTPS 访问它。
请注意,为了使用自签名证书,你需要在客户端信任该证书,否则将会收到证书错误。在生产环境中,建议使用受信任的证书颁发机构(CA)颁