[英]ASP.NET Core, .NET6 Adding a Controller to Swagger
I found it hard to integrate API to Swagger - there is only the default controller (WeatherForecast):我发现很难将 API 集成到 Swagger - 只有默认值 controller(WeatherForecast):
using Business.Repository.IRepository;
using Microsoft.AspNetCore.Mvc;
namespace HiddenVilla_API.Controllers
{
[Route("api/[controller]")]
[ApiController]
public class HotelRoomController : Controller
{
private readonly IHotelRoomRepository _hotelRoomRepository;
public HotelRoomController(IHotelRoomRepository hotelRoomRepository)
{
_hotelRoomRepository = hotelRoomRepository;
}
/// <summary>
/// Gets All hotel rooms
/// </summary>
/// <returns></returns>
[HttpGet]
private async Task<IActionResult> GetHotelRooms()
{
var allRooms = await _hotelRoomRepository.GetAllHotelRoom();
return Ok(allRooms);
}
}
}
using Business.Repository;
using Business.Repository.IRepository;
using DataAcess.Data;
using Microsoft.AspNetCore.Identity;
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.PlatformAbstractions;
using Microsoft.OpenApi.Models;
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddDbContext<ApplicationDbContext>(options =>
options.UseSqlServer(builder.Configuration.GetConnectionString("DefaultConnection")));
builder.Services.AddIdentity<IdentityUser, IdentityRole>().AddEntityFrameworkStores<ApplicationDbContext>().AddDefaultTokenProviders();
builder.Services.AddAutoMapper(AppDomain.CurrentDomain.GetAssemblies());
builder.Services.AddScoped<IHotelRoomRepository, HotelRoomRepository>();
builder.Services.AddScoped<IHotelAmenityRepository, HotelAmenityRepository>();
builder.Services.AddScoped<IHotelImagesRepository, HotelImagesRepository>();
builder.Services.AddRouting(option => option.LowercaseUrls = true);
builder.Services.AddControllers();
// Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen(c =>
{
c.SwaggerDoc("v1", new OpenApiInfo { Title = "HiddenVilla_Api", Version = "v1" });
});
builder.Services.AddMvc();
//builder.Services.AddMvcCore().AddApiExplorer();
var app = builder.Build();
// Configure the HTTP request pipeline.
if (app.Environment.IsDevelopment())
{
app.UseSwagger(options => options.SerializeAsV2 = true);
app.UseSwaggerUI(c => c.SwaggerEndpoint("/swagger/v1/swagger.json", "HiddenVilla_Api v1"));
}
app.UseHttpsRedirection();
app.UseRouting();
app.UseAuthorization();
app.MapControllers();
app.Run();
I think that maybe I'm missing something.我想也许我错过了什么。 The idea is for the controller to take the method from HotelRoolRepository.
这个想法是让 controller 从 HotelRoolRepository 中获取方法。 I have installed Swashbuckle.AspNetCore.Swagger, Swashbuckle.AspNetCore.SwaggerGen, Swashbuckle.AspNetCore.SwaggerUI
我已经安装了 Swashbuckle.AspNetCore.Swagger、Swashbuckle.AspNetCore.SwaggerGen、Swashbuckle.AspNetCore.SwaggerUI
It's probably the fact that your action method is private
.这可能是您的操作方法是
private
的事实。 You should make it public
.你应该把它
public
。
Change this改变这个
private async Task<IActionResult> GetHotelRooms();
to至
public async Task<IActionResult> GetHotelRooms();
Make method public instead of private.使方法公开而不是私有。 Add Attribute [HttpGet("GetHotelRooms")] this way.
以这种方式添加属性 [HttpGet("GetHotelRooms")]。
[HttpGet("GetHotelRooms")]
public async Task<IActionResult> GetHotelRooms()
{
var allRooms = await _hotelRoomRepository.GetAllHotelRoom();
return Ok(allRooms);
}
It is because of routing problem.这是因为路由问题。
1- Define HttpGet or HttpPost,... 1- 定义 HttpGet 或 HttpPost,...
if there are some action with same method(GET,POST,...), defining method route is required.如果有一些动作具有相同的方法(GET、POST、...),则需要定义方法路由。
2- Define Route path 2-定义路由路径
3- Define access modifier into public. 3- 将访问修饰符定义为 public。
Private modifier does not throw any exception for swagger, private actions are not shown in swagger api list though.私有修饰符不会为 swagger 抛出任何异常,但私有操作不会显示在 swagger api 列表中。
[HttpGet]
[Route("GetPersonInfo")]
public async Task<IActionResult> GetPersonInfo([FromBody] PersonInfoSearchItem searchItem)
{
return Ok(new
{
errorNumber = 2,
message = "data is fetched successfully",
Object= new Person()
});
}
[HttpGet]
[Route("SavePerson")]
private async Task<IActionResult> SavePerson([FromBody] PersonInfoSearchItem searchItem)
{
return Ok(new
{
errorNumber = 0,
message = "everything is Ok"
});
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.