简体   繁体   English

ASP.NET 核心,.NET6 添加一个 Controller 到 Swagger

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM