Customizing Swagger UI in Asp.Net Core Web API for Programmers
Swagger UI is an open source interactive documentation tool for developers to understand the API endpoints of an application. It makes the process of documenting and testing an API easier and faster. It is essential for developers to understand the API endpoints to access the web service. In Asp.Net Core Web API, you can customize the Swagger UI interface to suit your project needs.
Steps to customize Swagger UI
Step 1: Install the Swashbuckle package
First you will need to install the Swashbuckle package. This will allow you to customize the Swagger UI. To do this, open the NuGet package manager and search for “Swashbuckle.AspNetCore”. Install the latest stable version and restart the project.
Step 2: Add Swagger middleware in the startup class
Once you have installed the Swashbuckle package, you will need to add the middleware in the startup class. This will register the Swagger generator to the application. To do this, open the Startup.cs class and add the following code:
public void ConfigureServices(IServiceCollection services)
{
services.AddSwaggerGen(c =>
{
c.SwaggerDoc("v1", new OpenApiInfo { Title = "My API", Version = "v1" });
});
}
The above code will register the Swagger generator, and generate the API documentation for version “V1”.
Step 3: Enable the Swagger middleware
Once you have registered the Swagger generator, you will need to enable the Swagger middleware. To do this, add the following code to the Configure method in the Startup.cs class:
app.UseSwagger();
app.UseSwaggerUI(c =>
{
c.SwaggerEndpoint("/swagger/v1/swagger.json", "My API V1");
});
This will enable the Swagger middleware and generate the JSON document for the API.
Step 4: Customize the Swagger UI
Once you have enabled the Swagger middleware, you can customize the Swagger UI. To do this, add the following code to the Configure method in the Startup.cs class:
services.AddSwaggerGen(c =>
{
c.SwaggerDoc("v1", new OpenApiInfo
{
Title = "My API",
Version = "v1",
Description = "A simple example ASP.NET Core Web API",
Contact = new OpenApiContact
{
Name = "John Doe",
Email = string.Empty,
Url = new Uri("https://example.com/"),
},
License = new OpenApiLicense
{
Name = "Use under LICX",
Url = new Uri("https://example.com/license"),
}
});
});
This will allow you to customize the Swagger UI, such as adding a title, description, contact details, and license information. You can also add custom CSS and JavaScript to the Swagger UI to further customize it.
Conclusion
Customizing the Swagger UI in Asp.Net Core Web API is an important step in creating an interactive documentation for your API. It allows developers to understand the API endpoints and make the process of documenting and testing an API easier and faster. By following the steps outlined above, you can easily customize the Swagger UI to suit your project needs.