Swagger API 文档生成

    目录

    支持在项目中使用 Swagger 注解语法,运行命令,生成 Swagger 文件。

    Swagger 是最流行的 API 开发工具,它遵循 OpenAPI Specification(OpenAPI 规范,也简称 OAS)。

    Swagger 可以贯穿于整个 API 生态,如 API 的设计、编写 API 文档、测试和部署。

    Swagger 是一种通用的,和编程语言无关的 API 描述规范。

    imi-apidoc 基于 zircote/swagger-php 开发,100% 支持写法。

    Github: https://github.com/imiphp/imi-apidoc

    Composer

    本项目可以使用composer安装,遵循psr-4自动加载规则,在你的 composer.json 中加入下面的内容:

    {
        "require": {
            "imiphp/imi-apidoc": "~3.0.0"
        }
    }

    然后执行 composer update 安装。

    使用说明

    可以参考 exampletests 目录示例。

    项目配置文件:

    [
        'components'    =>  [
            'ApiDoc'  =>  'Imi\ApiDoc',
        ],
    ]

    Swagger 书写文档说明:https://zircote.github.io/swagger-php/

    Demo:

    <?php
    namespace ImiApp\ApiServer\Controller;
    
    use Imi\Server\Http\Route\Annotation\Route;
    use Imi\Server\Http\Route\Annotation\Action;
    use Imi\Controller\SingletonHttpController;
    use Imi\Server\Http\Route\Annotation\Controller;
    
    /**
     * @OA\Info(title="My First API", version="0.1")
     */
    #[Controller(prefix: '/')]
    class IndexController extends SingletonHttpController
    {
        /**
         * @return void
         */
        #[
            Action,
            Route(url: '/')
        ]
        public function index()
        {
    
        }
    
        /**
         * @param string $username 用户名
         * @param integer $password 密码
         * 
         * @return void
         */
        #[
            Action,
            Route(url: 'login', method: 'POST')
        ]
        public function login(string $username, int $password)
        {
    
        }
    
        /**
         * @OA\Get(
         *     path="/register",
         *     @OA\Response(response="200", description="An example resource")
         * )
         *
         * @param string $username 用户名
         * @param integer $password 密码
         * @param string $birthday 生日
         * 
         * @return void
         */
        #[
            Action,
            Route(url: 'register')
        ]
        public function register(string $username, int $password
        , string $birthday)
        {
    
        }
    
        /**
         * @param int $id
         * @return void
         */
        #[Action]
        public function get(int $id)
        {
    
        }
    
    }

    imi-apidoc 会根据 Route 注解、@param 注释,自动补足相关信息。让你不必为每个接口都书写 Swagger 注解,提升开发效率。

    当然,如果希望更加个性化的信息设置,还是要自己去书写的!

    生成命令:

    Yaml 格式: vendor/bin/imi-swoole doc/api api.yml

    Json 格式: vendor/bin/imi-swoole doc/api api.json

    指定扫描的命名空间:vendor/bin/imi-swoole doc/api api.json --namespace "ImiApp\Controller1,ImiApp\Controller2"

    效果:

    avatar

    avatar