在asp.net核心API中配置ssl证书时出现问题



我有以下证书证书

我想配置我的asp.net核心web API使用这些证书,以便使用https重定向。我正在使用Kestrel进行应用程序设置。

{
"Kestrel": {
"EndPoints": {
"Https": {
"Url": "https://jj.com:5002"
}
}
}
}

我试着自己做这件事,同时阅读一些网上帖子,但没有结果。这是我在Startup.cs文件中的Configure方法。

public void Configure(IApplicationBuilder app, IWebHostEnvironment env, ILoggerManager logger)
{
app.UseSwagger();
app.UseSwaggerUI(c =>
{
c.SwaggerEndpoint("/swagger/v1/swagger.json", "General API");
c.SupportedSubmitMethods();
});
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
else
{
// The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
app.UseHsts();
}

app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseRouting();
app.UseAuthentication();
app.UseAuthorization();
app.UseEndpoints(endpoints =>
{
endpoints.MapControllerRoute(
name: "default",
pattern: "{controller}/{action}");
});
}

这是我的Program.cs文件内容:

public class Program
{
public static void Main(string[] args)
{
CreateHostBuilder(args).Build().Run();
}
public static IHostBuilder CreateHostBuilder(string[] args) =>
Host.CreateDefaultBuilder(args)
.ConfigureServices((context, services) =>
{
services.Configure<KestrelServerOptions>(
context.Configuration.GetSection("Kestrel"));

}).ConfigureWebHostDefaults(webBuilder =>
{
webBuilder.UseStartup<Startup>();
webBuilder.UseSetting("https_port", "443");
webBuilder.ConfigureKestrel(o =>
{
o.ConfigureHttpsDefaults(o =>
o.ClientCertificateMode =
ClientCertificateMode.RequireCertificate);
});
}).UseWindowsService();
}

任何帮助都将不胜感激!

如果我正确理解你的问题,你只想在kestrel上有https。您可以在appsetting.json 上添加以下设置

"HTTPS_PORT": "5151", "Kestrel": { "EndpointDefaults": { "Protocols": "Http1" }, "Certificates": { "Default": { "Path": "server_cert.pfx", "Password": "password" } } },

对于该线路o.ClientCertificateMode = ClientCertificateMode.RequireCertificate);只有当您想使用客户端证书时才使用它。

最新更新