Rumah >rangka kerja php >ThinkPHP >Menggunakan ThinkPHP6 untuk menjana dokumen API secara automatik

Menggunakan ThinkPHP6 untuk menjana dokumen API secara automatik

王林
王林asal
2023-06-20 15:21:072564semak imbas

Apabila API semakin digunakan secara meluas, penjanaan dokumentasi API secara automatik telah menjadi alat yang sangat diperlukan. Artikel ini akan memperkenalkan cara menggunakan rangka kerja ThinkPHP6 untuk menjana dokumen API secara automatik.

1. Pengenalan kepada rangka kerja ThinkPHP6

ThinkPHP6 ialah rangka kerja sumber terbuka yang cekap, mudah, mudah dan fleksibel yang dibangunkan menggunakan bahasa PHP. Ia menggunakan model pembangunan berorientasikan objek, menyokong seni bina MVC (Model-View-Controller), dan mempunyai fungsi berkuasa seperti penghalaan, caching, pengesahan dan enjin templat.

2. Pasang UI Swagger

Swagger ialah alat penjanaan automatik untuk dokumen API secara automatik dan menyediakan antara muka Web untuk menunjukkan hasil pelaksanaan API. Apabila menggunakan ThinkPHP6 untuk menjana dokumen API secara automatik, kami perlu memasang Swagger terlebih dahulu.

Kami boleh memasang Swagger melalui alat Komposer. Masukkan dalam baris arahan:

composer require zircote/swagger-php

Selepas pemasangan selesai, buat fail konfigurasi Swagger dalam direktori akar projek dan namakannya swagger.php:

<?php
return [
    'swagger' => [
        'api' => [
            'title' => 'API文档',  //API文档的标题
        ],
        'paths' => [
            APP_PATH . '/',
        ],
        'exclude' => [
        ],
        'swagger-ui' => [
            'title' => 'API文档',  //API文档的标题
        ],
        'securityDefinitions' => [
        ],
    ],
];

3. Tentukan dokumen API komen

Untuk membolehkan Swagger mengenal pasti dan menjana dokumentasi API secara automatik, kami perlu menambah ulasan yang sepadan pada kod. ThinkPHP6 menyediakan format ulasan tersuai untuk mentakrifkan dokumentasi API.

Tentukan ulasan dokumen API dalam pengawal:

<?php
declare(strict_types=1);

namespace appcontroller;

class Example
{
    /**
     * @OAGet(
     *      path="/example/index",
     *      operationId="exampleIndex",
     *      tags={"Example"},
     *      summary="示例接口",
     *      description="这是一个示例接口",
     *      @OAResponse(
     *          response=200,
     *          description="操作成功",
     *      ),
     *      @OAResponse(
     *          response=401,
     *          description="未授权",
     *      ),
     *      security={
     *          {"Bearer": {}}
     *      }
     * )
     */
    public function index()
    {
        //接口代码
    }
}

Dalam kod di atas, teg ulasan yang bermula dengan @OA dihuraikan ke dalam format kanonik Swagger. Antaranya, @OAGet mentakrifkan kaedah permintaan API sebagai kaedah Dapatkan mentakrifkan laluan API operationId mentakrifkan teg yang dimiliki oleh ringkasan API; ; perihalan mentakrifkan perihalan terperinci tentang API ;

4. Hasilkan dokumentasi API

Selepas mentakrifkan anotasi dokumentasi API, kami boleh menggunakan Swagger untuk menjana dokumentasi API. Masukkan arahan berikut pada baris arahan:

php think swagger:export --output public/swagger.json

Perintah ini akan menyimpan dokumen API ke fail swagger.json dalam direktori awam.

5. Akses dokumentasi API

Gunakan UI Swagger untuk memaparkan dokumentasi API. Kami boleh menggunakan projek UI Swagger ke pelayan web atau menjalankannya secara tempatan.

Apabila berjalan secara setempat, kita boleh menggunakan arahan berikut untuk memulakan perkhidmatan UI Swagger dengan cepat:

docker run --rm -p 8080:8080 -e SWAGGER_JSON=/data/swagger.json -v /path/to/swagger.json:/data/swagger.json swaggerapi/swagger-ui

Di mana, /path/to/swagger.json ialah laluan mutlak ke swagger.json fail.

Lawati http://localhost:8080 dalam penyemak imbas anda untuk melihat dokumentasi API.

6. Ringkasan

Artikel ini memperkenalkan cara menggunakan rangka kerja ThinkPHP6 dan Swagger untuk menjana dokumen API secara automatik. Menjana dokumen API secara automatik boleh meningkatkan kecekapan pembangunan dan mengurangkan kos penyelenggaraan. Melalui pengenalan artikel ini, saya percaya bahawa pembaca sudah boleh menggunakan rangka kerja ThinkPHP6 dan Swagger dengan mahir untuk merealisasikan penjanaan automatik dokumen API.

Atas ialah kandungan terperinci Menggunakan ThinkPHP6 untuk menjana dokumen API secara automatik. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn