我已经为我的 .NET Core webApi 应用程序配置了 Swagger,这是它的配置
public void ConfigureServices(IServiceCollection services)
{
services.AddAuth();
services.AddCors(options =>
{
options.AddPolicy("CorsPolicy",
builder => builder.AllowAnyOrigin()
.AllowAnyMethod()
.AllowAnyHeader()
.AllowCredentials()
.Build());
});
services.AddMvc();
services.AddSwaggerGen(c =>
{
c.SwaggerDoc("v1",
new Info
{
Version = "v1",
Title = "XXX Synchronization API",
Description = "XXX Synchronization API",
TermsOfService = "None",
Contact = new Contact { Name = "XXX Inc.", Email = "XXXX", Url = "XXX.com" }
});
c.IncludeXmlComments(GetXmlCommentsPath());
c.DescribeAllEnumsAsStrings();
});
services.AddSingleton<IHashProvider, Pbkdf2Version1HashProvider>();
services.AddSingleton<IPasswordHasher, PasswordHasher>();
services.AddTransient<IAuthenticationService, GfdAuthenticationService>();
services.AddSingleton(new GfdSqlServerDatabase(Gfd2Configuration.Settings.GfdSqlServerConnectionString));
services.AddSingleton(new MySqlSyncDatabase(Gfd2Configuration.Settings.AwsMySqlConnectionString));
services.AddTransient<SyncRepository, AwsMySqlSyncRepository>();
services.AddHostedService<QueuedHostedService>();
services.AddSingleton<IBackgroundTaskQueue, BackgroundTaskQueue>();
services.AddSingleton<ArchivedJobProcessorBase, ArchivedJobProcessorFeatures>();
}
/// <summary>
/// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
/// </summary>
/// <param name="app"></param>
/// <param name="env"></param>
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
app.UseAuthentication();
app.UseCors("CorsPolicy");
app.UseMvc();
app.UseSwagger();
#if DEBUG
app.UseSwaggerUI(c => { c.SwaggerEndpoint("/swagger/v1/swagger.json", "XXXX Synchronization API V1"); });
#else
app.UseSwaggerUI(c => { c.SwaggerEndpoint("/sync/swagger/v1/swagger.json", "XXX Synchronization API V1"); });
#endif
}
一切正常。由于某种原因,今天早上每当我打开
/swagger
网址时,我都会收到 401 错误。
我不需要对 Swagger 文档和 UI 进行任何身份验证,所有这些都是公开的。
这会和
.NET Core 2.1.2
有关吗?
使用
Swashbuckle.AspNetCore 3.0.0
欢迎任何想法。
对于那些可能有这样问题的人来说,修复其实很简单。对于我的一个实际上需要身份验证的新 webApi 控制器,我忘记添加属性
[Route("api/[controller]")]
,因此 /swagger
url 指向该控制器,因此 401 错误。去图:)
当我添加一个错误路由的新端点时,这个问题发生在我身上。
我用过
[Route("/{id}")]
.
开头不能有正斜杠
[Route("{id}")]
最近我遇到了同样的 401 错误。决定是在 Swagger 授权页面上的值字段中的令牌值之前添加“Bearer”。