本篇文章给大家分享的是有关基于ThinkPHP6 的注解路由以及如何进行自动接口文档和自动测试数据的生成,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。
> 1、安装
composer require iszsw/mock
> 2、添加测试代码 在 app/controller 目录下增加Test.php文件
<!--?php namespace app\controller; use app\BaseController; use iszsw\mock\annotation\illustrate\AutoValidate; use iszsw\mock\annotation\illustrate\Route; use iszsw\mock\annotation\illustrate\Mock; use iszsw\mock\annotation\illustrate\MockPack; use iszsw\mock\annotation\illustrate\WikiItem; use iszsw\mock\annotation\illustrate\WikiMenu; /** * @WikiMenu("测试") * [@package](https://my.oschina.net/u/925486) app\controller * Author: zsw zswemail@qq.com */ class Test extends BaseController { /** * @Route("test", method="GET") * @WikiItem("首页", description="首页详情") * * @AutoValidate({"username":"require|chsAlpha"}, message={"username":"请输入用户名"}) * @Mock("username", mode="request", title="用户名", example="name") * @Mock("name", mode="response", title="名字", example="name", description="文章ID") */ public function index($username){ return "hello " . $username; } /** * @Route("mock", method="GET") * @WikiItem("详情", description="文章详情") * * @Mock("id", title="ID", example="numberBetween", description="文章ID") * @MockPack("articles", mode="response", title="文章列表", description="文章列表", limit=5) * @Mock("id", mode="response", title="ID", example="randomDigitNotNull", description="文章ID") * @Mock("title", mode="response", title="标题", example="name") * @Mock("create_time", mode="response", title="创建时间", example={"date": {"Y-m-d", "now"}}) * @Mock("content", mode="response", title="内容", example={"sentence": 10}) * @Mock("image", mode="response", title="图片", example="randomDigit") * @MockPack("user", main=true, mode="response", title="用户", description="发布者信息", limit=0) * @Mock("username", mode="response", title="用户名", example="name") * @MockPack("user") * @MockPack("articles") * @Mock("page", mode="response", title="页码", example="randomDigitNotNull", description="当前页码") */ public function mock(){} }
--> 3、 访问路由、测试数据、接口文档
路由:/test?username=zsw 数据:/mock?mock=1 文档:/wiki
> 路由注解 模型注解 自动注入同Tp6官方注解
> 新增AutoValidate注解
@AutoValidate({"username":"require|chsAlpha"}, message={"username":"请输入用户名"})
> MockPack 嵌套数据生成支持 无限级嵌套
@MockPack extends MockBase // 数据长度 0表示单层数据 @var int limit /* * 置顶 (limit > 1 时有效) * false:['fields'=>[["a"=>"b"], ["aa"=>"bb"]]] * true:[["a"=>"b"], ["aa"=>"bb"]] */ @var boolean main
例:
// MockPack(key) MockPack中key相同值之间组成一层嵌套 /** * @MockPack("articles", mode="response", title="文章列表", description="文章列表", limit=3) * * @Mock("title", mode="response", title="标题", example="name") * @Mock("content", mode="response", title="内容", example={"sentence": 10}) * * @MockPack("user", main=true, mode="response", title="用户", description="发布者信息", limit=0) * @Mock("username", mode="response", title="用户名", example="name") * @MockPack("user") * * @MockPack("articles") */ 生成结果 { "articles": [{ "title": "乔阳", "content": "Vero impedit et consequatur quasi doloribus dolores illum sit expedita doloremque fugiat esse deleniti quisquam.", "user": { "username": "方建明" } }, { "title": "蒙桂花", "content": "Iure explicabo officiis minima et impedit sunt dignissimos necessitatibus ratione animi nam aperiam dolorum.", "user": { "username": "谷致远" } }, { "title": "郑文", "content": "Minus cum unde exercitationem sunt laudantium eveniet voluptatem magni ut cum non.", "user": { "username": "宁丽娟" } }] }
> Mock 数据生成
@Mock extends MockBase /** * 自定义字符串 example="zsw" * Faker方法名 参考https://github.com/fzaninotto/Faker * 自定义方法名 \app\logic\Mock::name * example="方法名" || example={"方法名": {"参数1", "参数2"}} */ @var string|array example
<!--?php /** * @WikiMenu("测试") */ class Test extends BaseController { /** * @Route("test", method="GET") * @WikiItem("首页", description="首页详情") * @Mock("name", mode="response", title="名字", example="name", description="名字") */ public function index(){ return "zsw"; } }
<?php namespace app\controller; use app\BaseController; use iszsw\mock\annotation\illustrate\Route; use iszsw\mock\annotation\illustrate\Mock; use iszsw\mock\annotation\illustrate\MockPack; use iszsw\mock\annotation\illustrate\WikiItem; use iszsw\mock\annotation\illustrate\WikiMenu; /** * @WikiMenu("测试") */ class Test extends BaseController { /** * @Route("mock", method="GET") * @WikiItem("详情", description="文章详情") * @Mock("id", title="ID", example="numberBetween", description="文章ID") * * @MockPack("articles", mode="response", title="文章列表", description="文章列表", limit=3) * @Mock("title", mode="response", title="标题", example="name") * @Mock("content", mode="response", title="内容", example={"sentence": 10}) * * @MockPack("user", main=true, mode="response", title="用户", description="发布者信息", limit=0) * @Mock("username", mode="response", title="用户名", example="name") * @MockPack("user") * * @MockPack("articles") */ public function mock(){} }
生成的数据格式为
{ "articles": [{ "title": "乔阳", "content": "Vero impedit et consequatur quasi doloribus dolores illum sit expedita doloremque fugiat esse deleniti quisquam.", "user": { "username": "方建明" } }, { "title": "蒙桂花", "content": "Iure explicabo officiis minima et impedit sunt dignissimos necessitatibus ratione animi nam aperiam dolorum.", "user": { "username": "谷致远" } }, { "title": "郑文", "content": "Minus cum unde exercitationem sunt laudantium eveniet voluptatem magni ut cum non.", "user": { "username": "宁丽娟" } }] }
<?php namespace app\controller; use iszsw\mock\annotation\illustrate\Route; use iszsw\mock\annotation\illustrate\WikiItem; use iszsw\mock\annotation\illustrate\WikiMenu; /** * @WikiMenu("测试") */ class Test { /** * @Route("test", method="GET") * @WikiItem("首页", description="首页详情") * @Mock("username", mode="request", title="用户名", example="name") * @Mock("name", mode="response", title="名字", example={"\app\controller\Mock::name": {100}}, description="文章ID") */ public function index($username){} }
以上就是基于ThinkPHP6 的注解路由以及如何进行自动接口文档和自动测试数据的生成,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。