АСП. Проект NET Core Web API не создал заголовок запроса «Авторизация» в файле документа «swagger. json».
попробовал вывести заголовок запроса «Авторизация» в файл «swagger.json»
Информация о проекте:
Нет вывода ошибок
Я уверен, что включил генерацию документов в «MyProject. csproj»:
Истинный
Очистив решение, пересобрав и запустив приложение, вы увидите, что файл MyProject.xml выведен.
Откройте файл «MyProject.xml», и я увижу, что информация заголовка запроса была сгенерирована:
Получить информацию о пользователе Токен Модель ответаПосетите «https://localhost:12345/swagger/v1/swagger.json». Я не видел, чтобы заголовок запроса «Авторизация» создавался в файле «swagger. json»:
builder.Services.AddSwaggerGen(swagger =>
{
swagger.SwaggerDoc("v1", new OpenApiInfo { Title = "MyProject", Version = "1.0.1" });
swagger.SwaggerDoc("v2", new OpenApiInfo { Title = "MyProject", Version = "2.0" });
// Include xml file
swagger.IncludeXmlComments(AppContext.BaseDirectory + Assembly.GetEntryAssembly().GetName().Name + ".xml", true);
swagger.AddSecurityDefinition(JwtBearerDefaults.AuthenticationScheme, new()
{
In = ParameterLocation.Header,
Type = SecuritySchemeType.ApiKey,
Description = "Bearer Token",
Name = "Authorization",
BearerFormat = "JWT",
Scheme = JwtBearerDefaults.AuthenticationScheme
});
swagger.AddSecurityRequirement(new()
{
{
new OpenApiSecurityScheme()
{
Reference = new OpenApiReference()
{
Type = ReferenceType.SecurityScheme,
Id = JwtBearerDefaults.AuthenticationScheme
}
},
new string[]{ }
}
});
});
// Other Code...
if (app.Environment.IsDevelopment())
{
app.UseSwagger();
app.UseSwaggerUI(swagger =>
{
swagger.SwaggerEndpoint("/swagger/v1/swagger.json", "v1");
swagger.SwaggerEndpoint("/swagger/v2/swagger.json", "v2");
});
}
app.UseRouting();
app.UseAuthentication();
app.UseAuthorization();
app.UseMiddleware<IdentityAuthenticationMiddleware>();
app.MapControllers();
app.Run();
/// <summary>
/// UserInfo
/// </summary>
[ApiController]
[Route("api/[controller]/[action]")]
[Authorize(Roles = "User,Admin")]
public class UserInfoController(HttpRequestModel httpRequestModel) : ControllerBase
{
private readonly HttpRequestModel _httpRequest = httpRequestModel;
/// <summary>
/// GetUserInfo
/// </summary>
/// <param name = "authorization">Token</param>
/// <returns>ResponseModel</returns>
[HttpGet]
public ResponseModel GetUserInfo([Required][FromHeader(Name = "Authorization")] string authorization)
{
using (UserInfoBll userInfoBll = new())
{
return userInfoBll.GetUserInfoModel(_httpRequest.Token.UserId);
}
}
}
Да, я так и сделал, но результат все тот же: app.UseRouting(); app.UseAuthentication(); app.UseAuthorization(); app.UseMiddleware<IdentityAuthenticationMiddleware>(); app.MapControllers(); app.Run();
Я нашел ответ в официальной документации Swagger, и оказалось, что эти имена параметров нельзя использовать: https://swagger.io/docs/specification/describing-parameters/
Используете ли вы UseAuthentication и UseAuthorization? Вам необходимо разместить UseAuthentication() перед UseAuthorization(). У вас атрибут Authorize иначе не работает.