大致过程和我之前写的Laravel 扩展差不多 Laravel 写一个中文验证扩展包
只有一些小小的区别这边写个教程。希望为thinkphp 开发者做一点点贡献。
主要讲一些开发的过程和一些感悟吧,对Tp不是特别熟,欢迎大家指正~
源码:https://github.com/liaoshengping/think-swagger
安装:
composer require liaosp/think-swagger -vvv
创建包
我在tp的根目录下创建pkg
mkdir pkg cd pkgpackage-builder build think-swagger
添加 zircote/swagger-php,在composer.json 添加
添加swagger
"require": { "zircote/swagger-php": "^3.2" },
根据 官网的示例,我们希望在TP触发如下代码
<?php require("vendor/autoload.php"); $openapi = \OpenApi\Generator::scan(['/path/to/project']); header('Content-Type: application/x-yaml'); echo $openapi->toYaml();
本地导入composer
需要在tp的compsoer 加入 “minimum-stability”: “dev”
"minimum-stability": "dev"
repositories 加入
{ "type": "path", "url": "pkg\\think-swagger" }
创建控制器
在src 创建 一个Controller.php
一个是展示 html 的,一个是提供swagger api 接口的
具体代码可查阅:
https://github.com/liaoshengping/think-swagger/blob/master/src/Controller.php
添加路由
"autoload": { "psr-4": { "Liaosp\\ThinkSwagger\\": "src" }, "files": [ "src/route.php" ] },
添加router.php
tp5 我现在的版本可以这样做,但是TP6我试了下,不行啊报错;如果后面有Tp6项目了,我会把tp6部分整合一下欢迎大家收藏。
Route::any('apidoc', '\\Liaosp\\ThinkSwagger\\Controller@apidoc'); Route::any('apidocJson', '\\Liaosp\\ThinkSwagger\\Controller@apidocJson');
添加Swagger-ui
swagger ui 是 开源的 js库 github.com/swagger-api/swagger-ui
静态形式引用 dist/index.html
静态资源导入
Swagger 主要需要这三个文件
'/swagger/swagger-ui.css', '/swagger/swagger-ui-bundle.js', '/swagger/swagger-ui-standalone-preset.js'
tp5没有publish ,所以我想了一个办法,通过查询是否存在资源,进行资源的发布。感兴趣的可以看下上面提供的源码
一些感想
可能我的思维Laravel化了,在开发之前我认为一些 本应该有的扩展功能都应该有的,但是我查阅了好几个作者的think-swagger扩展包,不太灵活了。以至于有一些开发扩展包的同学,需要手动改源码,或者干脆就没有composer 包,直接写教程如何去实现。
接着我查阅了下Tp6的源码,在开发扩展方面有一定的增强,比如下面的是我学Tp6 的官方的插件:
Laravel 的包的提供者的命名官方的是在包名加 Provider 我查阅了下tp的扩展包,习惯于用Service 作为包的提供者 "extra": { "think": { "services": [ "Liaosp\\ThinkSwagger\\Service" ] } }
不过Laravel 之前也需要手动添加Provider,希望国产Tp越来越好,目前我测试了下这个包可以在Tp5运行,tp6不行。后面再看看有没有接触TP6项目再把这个包升级一下吧。
源码:https://github.com/liaoshengping/think-swagger
未经允许不得转载:任鹏个人博客 » 分享一个ThinkPHP SwaggerV3扩展包
最新评论
Forex wiki. https://lt.forex-stock-bitcoin-brokers.com
Magnificent items from you, man. I have take note your stuff
Following on from the 3rd March Meetings held by economic de
It is remarkable, rather valuable message dfgdlfg2131.32
一般都会有一个沙盒期的,过了沙盒期就会慢慢放出来
百度不收录是应为是新站的原因吗?
The spike in consumer prices that left inflation at a four-d