+1

Xây dựng trang hỗ trợ ASP.NET API sử dụng Swagger

Khi các bạn xây dựng các API cho phép bên thứ 3 sử dụng hay đơn giản là cho các thành viên trong dự án sử dụng mà lại không có tài liệu hay bất kỳ hướng dẫn nào thì thật là tồi tệ.

Hôm nay mình sẽ hướng dẫn các bạn xây dựng một trang hỗ trợ ASP.NET API sử dụng Swagger. Nào cùng bắt đầu thôi nào. Chúng ta sẽ sử dụng code mẫu API tại đây: https://github.com/aspnet/Docs/tree/master/aspnet/tutorials/first-web-api/sample

1. Bắt đầu

Swashbuckle có 2 thành phần chính:

  • Swashbuckle.SwaggerGen: cung cấp các chức năng để tạo ra tài liệu JSON Swagger mô tả các đối tượng, phương thức, kiểu dữ liệu trả về, tham số, ...
  • Swashbuckle.SwaggerUI: tích hợp phiên bản Swagger UI, cái mà sử dụng chỉnh sửa mô tả, chức năng của Web API.

2. NuGet Packages

Bạn có thể cài Swashbuckle với các cách sau:

  • Từ Package Manager Console: Install-Package Swashbuckle -Pre
  • Thêm Swashbuckle vào file project.json: "Swashbuckle": "6.0.0-beta902"
  • Trong Visual Studio:
    • Chuột phải vào dự án của bạn trong Solution Explorer > Manage NuGet Packages
    • Gõ Swashbuckle trong ô tìm kiếm
    • Check "Include prerelease"
    • Cài đặt Package source tới nuget.org
    • Chọn Swashbuckle và install

3. Cài đặt và cấu hình Swagger vào middleware

Trong Visual Studio, bạn nhấn F5 để chạy ứng dụng và sẽ vào địa chỉ: http://localhost:<random_port>/swagger/v1/swagger.json trên trình duyệt để nhìn tài liệu mô tả các endpoints được sinh ra

Ví dụ:

{
"swagger": "2.0",
"info": {
    "version": "v1",
    "title": "API V1"
},
"basePath": "/",
"paths": {
    "/api/Todo": {
    "get": {
        "tags": [
        "Todo"
        ],
        "operationId": "ApiTodoGet",
        "consumes": [],
        "produces": [
        "text/plain",
        "application/json",
        "text/json"
        ],
        "responses": {
        "200": {
            "description": "OK",
            "schema": {
            "type": "array",
            "items": {
                "$ref": "#/definitions/TodoItem"
            }
            }
        }
        },
        "deprecated": false
    },
    "post": {
        ...
    }
    },
    "/api/Todo/{id}": {
    "get": {
        ...
    },
    "put": {
        ...
    },
    "delete": {
        ...
},
"definitions": {
    "TodoItem": {
    "type": "object",
    "properties": {
        "key": {
        "type": "string"
        },
        "name": {
        "type": "string"
        },
        "isComplete": {
        "type": "boolean"
        }
    }
    }
},
"securityDefinitions": {}
}

Đây là tài liệu được sử dụng được hiện thị khi bạn vào địa chỉ http://localhost:<random_port>/swagger/ui

swagger-ui.png

Mỗi một phương thức trong ToDo controller có thể được test từ UI. Chọn bất kỳ phương thức nào và Try it out! get-try-it-out.png

4. Chỉnh sửa và tùy chỉnh

Swagger không chỉ là để đại diện cho các API, mà còn có các tùy chọn tùy biến các đối tượng model từ UI hoặc ngôn ngữ lập trình

Thông tin API và mô tả

services.ConfigureSwaggerGen(options =>
{
    options.SingleApiVersion(new Info
    {
        Version = "v1",
        Title = "ToDo API",
        Description = "A simple example ASP.NET Core Web API",
        TermsOfService = "None",
        Contact = new Contact { Name = "Shayne Boyer", Email = "", Url = "http://twitter.com/spboyer"},
        License = new License { Name = "Use under LICX", Url = "http://url.com" }
    });
});

Và sẽ được Swagger UI hiện thị như ảnh bên dưới custom-info.png

XML Comment

Để enable XML comment, chuột phải dự án trong Visual Studio và chọn Properties sau đó chọn XML Documentation file trên Output Settings

swagger-xml-comments.png

Bạn cũng có thể enable XML comment bằng cài cài đặt "xmlDoc":true trong project.json


All rights reserved

Viblo
Hãy đăng ký một tài khoản Viblo để nhận được nhiều bài viết thú vị hơn.
Đăng kí