Heim >Backend-Entwicklung >PHP-Tutorial >用swagger-php/ui干API测试

用swagger-php/ui干API测试

WBOY
WBOYOriginal
2016-06-13 12:15:121862Durchsuche

用swagger-php/ui做API测试
功能:
1 swagger-php根据自定义的规则生成API请求规则,通过phar生成json文件
2 打开swagger-ui/dist/index.html。输入json文件夹目录地址(需要同源),swagger-ui会根据请求的JSON生成API,页面很漂亮。输入请求参数后执行会获取返回值。
缺点:不能对返回的数据进行验证。功能类似chrome的插件postman。
Api Action测试参考代码:
Resource/PostAction.php
Java代码  收藏代码
/**
* @SWG\Resource(
*   apiVersion="2.2.0",
*   swaggerVersion="1.2",
*   basePath="http://test.xxx.com/Api/Post",
*   resourcePath="/Post",
*   description="Operations about Post",
*   produces="['application/json']"
* )
*/ 
 
/**
* @SWG\Api(
*   path="/apps",
*   @SWG\Operation(
*     method="POST",
*     summary="Find app by buID",
*     notes="Returns apps based on BUID",
*     type="Post",
*     nickname="apps",
*     authorizations={},
*     @SWG\Parameter(
*       name="apiVersion",
*       description="api version",
*       required=true,
*       type="integer",
*       format="int64",
*       paramType="form",
*       minimum="1.0",
*       allowMultiple=false
*     ),
*     @SWG\Parameter(
*       name="sessionID",
*       description="user login session",
*       required=true,
*       type="string",
*       paramType="form",
*       defaultValue="9f6cdd0858a1e93b1426659b283a93ec",
*       allowMultiple=false
*     ),
*    @SWG\Parameter(
*       name="buID",
*       description="BU ID",
*       required=true,
*       type="int64",
*       paramType="form",
*       allowMultiple=false
*     ),
*     @SWG\ResponseMessage(code=400, message="Invalid ID supplied"),
*     @SWG\ResponseMessage(code=404, message="Post not found"),
*     @SWG\ResponseMessage(code=405, message="Invalid input"),
*     @SWG\ResponseMessage(code=200, message="success")
*   )
* )
*/ 

项目描述信息
Info/api.php
Java代码  收藏代码
 
/**
* @SWG\Info(
*   title="MY Project",
*   description=" xxx",
* )
*
*/ 

readme
Java代码  收藏代码
# Usage of API Docs 
### Raw Spec Structure 
* Info - General Info. 
* Model - Entity Class 
* Resource - API endpoint 
 
### Compile API info. 
* after modify the spec, run shell script, as follows. 
 
    `cd api-docs` 
     
    `./genDocumentation.sh` 
 
* the compiled content (.json) is stored in documentation/Output/ 
 
### View API docs 
* visit http://{domain}/documenation/ 


sh 执行文件
Java代码  收藏代码
#!/bin/sh 
../swagger-php/swagger.phar ../output-docs -o ../documentation/output/ 

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn