xianrenqh / api-doc-php
api-doc-php
Installs: 16
Dependents: 1
Suggesters: 0
Security: 0
Stars: 1
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/xianrenqh/api-doc-php
Requires
- php: >=5.6.0
README
###说明: 此代码拷贝于IT小强的源码,开源git地址:https://github.com/itxq/api-doc-php
修改部分代码,并增加tp使用注释。 如喜欢原版请使用IT小强的git
###版本更新:
1.4.3 修复注释间多个空格bug
1.4.1 调整json代码块颜色
1.4.0 新增输出返回json数据
1.3.0 新增header参数
1.2.0 优化原版本
主要功能:
- 根据接口注释自动生成接口文档
演示地址
【Gitee Pages:】http://itxq.gitee.io/api-doc-php
开源地址:
【GigHub:】https://github.com/xianrenqh/api-doc-php
扩展安装:
- 
方法一:composer命令 composer require xianrenqh/api-doc-php
- 
方法二:直接下载压缩包,然后进入项目中执行 composer命令 composer update来生成自动加载文件
引用扩展:
- 当你的项目不支持composer自动加载时,可以使用以下方式来引用该扩展包
// 引入扩展(具体路径请根据你的目录结构自行修改)
require_once __DIR__ . '/vendor/autoload.php';
使用扩展:
// 引入扩展(具体路径请根据你的目录结构自行修改)
require_once __DIR__ . '/../vendor/autoload.php';
// 加载测试API类1
require_once __DIR__ . '/Api.php';
// 加载测试API类2
require_once __DIR__ . '/Api2.php'; 
$config = [
    'class'         => ['Api', 'Api2'], // 要生成文档的类
    'filter_method' => ['__construct'], // 要过滤的方法名称
];
$api = new \xianrenqh\apidoc\BootstrapApiDoc($config);
$doc = $api->getHtml();
exit($doc);
thinkphp5.1使用方法:
1、在控制器下面可以创建例如: application/index/controller/Doc.php
文档代码为:
<?php
namespace app\index\controller;
use xianrenqh\apidoc\ApiDoc;
use think\Controller;
class Doc
{
    public function index()
    {
        $config = [
            'class'         => [
                'app\\index\\controller\\Api',
            ], // 要生成文档的类
            'filter_method' => ['__construct', '_empty'], // 要过滤的方法名称
        ];
        $api    = new \xianrenqh\apidoc\BootstrapApiDoc($config);
        $doc    = $api->getHtml();
        exit($doc);
    }
}
访问:http://localhost/index/doc即可访问到文档
注意:Api.php控制器的方法里一定要有title,method等参数说明用来给文档提示说明文字,如果无,会报错
2、Api.php案例代码:
namespace app\index\controller;
use think\App;
use think\Controller;
use think\Db;
/**
 * @title API接口
 * @desc API接口
 * Class APi
 * @package app\index\controller
 */
class Api extends Controller
{
    /**
     * @title 获取所有栏目
     * @url /index/api/homecategory
     * @method POST
     * @header string MX-device-type 设备类型 空 必须
     * @code 200 成功
     * @code 201 失败
     * @json {"code":200,"msg":"登录成功","data":{"token":"47b536ddbfccc0a777434a48e5a33a63","shop_id":10001,"admin_type":1,"user":{"id":2,"name":"A002"}}}
     * @return int status 状态码 (具体参见状态码说明)
     * @return string msg 提示信息
     */
    public function homecategory()
    {
        //... 你的代码
    }
}