成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

PHP使用Swagger生成好看的API文檔

瀏覽:219日期:2022-06-06 16:53:10
目錄
  • 一、安裝swagger-php
  • 二、設置一個輸出api文檔數據的接口
  • 三、使用
  • 四、顯示swagger ui

PHP使用Swagger生成好看的API文檔不是不可能,而是非常簡單。

首先本人使用Laravel框架,所以在Laravel上安裝swagger-php。

一、安裝swagger-php

composer require zircote/swagger-php

swagger-php提供了命令行工具,所以可以全局安裝,然后把工具的路徑加到PATH里去。

composer global require zircote/swagger-php

然后把zircote/swagger-php/bin 目錄加到PATH里。這個東西本人用不到,就不研究了。

二、設置一個輸出api文檔數據的接口

a)、生成一個控制器: SwaggerController

b)、添加一個方法: getJSON()

    public function getJSON()
    {
$swagger = \OpenApi\Generator::scan([app_path("Http/Controllers/")]);
return response()->json($swagger, 200);
    }

有的文章里寫 \Swagger\scan(),但我這里報錯,說找不到這個類。查了官方文檔,要用 \OpenApi\Generator::scan()。有可能是新版本做了修改。

c)、設置路由

api.php 或者 web.php都行,路徑不同而已。本人選擇api.php。所以訪問路徑要加個前綴:/api。

Route::group(["prefix" => "swagger"], function () {
    Route::get("json", [\App\Http\Controllers\SwaggerController::class, "getJSON"]);
});

d)、測試訪問

訪問 http://localhost:8000/api/swagger/json 如果看到頁面正常輸出json,說明配置成功了。不然就按錯誤提示一項項去修改吧。

三、使用

GET方法

    /** 
     * @OA\Get(
     *     tags={"數據管理"},
     *     summary="數據查詢",
     *     path="/api/data/search",
     *     @OA\Response(response="200", description="Display a listing of projects."),
     *     @OA\Parameter(
     * description="數據名稱",
     * in="query",
     * name="name",
     * required=false,
     * @OA\Schema(type="string"),
     *     ),
     *     @OA\Parameter(
     * description="狀態(tài)",
     * in="query",
     * name="status",
     * required=false,
     * @OA\Schema(type="integer"),
     *     ),
     *     @OA\Parameter(
     * description="每頁記錄數",
     * in="query",
     * name="page-size",
     * required=false,
     * @OA\Schema(type="integer"),
     *     ),
     *     @OA\Parameter(
     * description="當前頁碼",
     * in="query",
     * name="current-page",
     * required=false,
     * @OA\Schema(type="integer"),
     *     ),
     * )
     */

這里面:

in 表示該參數出現(xiàn)在哪里。 query的話就是用&拼在url后面; path 類似于 /api/data/search/{param} ; header就是包含在 request header里;cookie 自然是放在cookie里。

這個版本里formData, body這些都沒有了。

required 看名字就知道 true是必填項,false是選填項。

POST方法

    /** 
     * @OA\Post(
     *     tags={"數據管理"},
     *     summary="添加數據",
     *     path="/api/data",
     *     @OA\Response(response="200", description="Display a listing of projects."),
     *     @OA\RequestBody(
     * @OA\MediaType(
     *     mediaType="x-www-form-urlencoded",
     *     @OA\Schema(
     * ref="#/components/schemas/DataModel",
     *     ),
     * ),
     *     ),
     * )
     */

因為本人的前端代碼post都是表單提交,所以這里的post方法要用@OA\RequestBody。

@OA\Parameter是參數,是可以放到url上,但是post的表單提交,數據是不出現(xiàn)在url上的。

@OA\MediaType 這個: x-www-form-urlencoded 表單提交;application/json 提交json格式的數據;multipart/form-data 文件上傳;

     *     @OA\Schema(
     * ref="#/components/schemas/DataModel",
     *     ),

這個是關聯(lián)到一個已經定義好的schema上,省得使用相同數據的每個接口注釋里都寫一遍。

這里也可以單獨寫:

 * @OA\Schema(
 *   required={"name", "code"},
 *   @OA\Property(property="name", type="string", title="姓名", description="這是姓名"),
 *   @OA\Property(property="code", type="string", title="代碼", description="這是代碼"),
 *   @OA\Property(property="phone", type="string", title="電話", description="這是電話"),
 * ),

上面這樣,有多少個參數就寫多少個@OA\Property。

這里的required是個數組,寫在里面的都是必填項。

其它方法都差不多,以后有用到了再記錄。

四、顯示swagger ui

下載swagger ui的代碼: https://github.com/swagger-api/swagger-ui/releases

解壓后,把目錄里的dist目錄,復制到laravel的public目錄下面,改名為swagger-ui。文件名隨便取,不沖突就行。

找開這個swagger-ui目錄下的swagger-initializer.js,內容大概如下:

window.onload = function() {
  //<editor-fold desc="Changeable Configuration Block">
  // the following lines will be replaced by docker/configurator, when it runs in a docker-container
  window.ui = SwaggerUIBundle({
    url: "/api/swagger/json",
    dom_id: "#swagger-ui",
    deepLinking: true,
    presets: [
      SwaggerUIBundle.presets.apis,
      SwaggerUIStandalonePreset
    ],
    plugins: [
      SwaggerUIBundle.plugins.DownloadUrl
    ],
    layout: "StandaloneLayout"
  });
  //</editor-fold>
};

主要是改 url這項。改成前面設的路由地址。這里是 "/api/swagger/json"。

完成后訪問 http://localhost:8000/swagger-ui/ 就能看到swagger形成的api文檔了。

到此這篇關于PHP使用Swagger生成好看的API文檔的文章就介紹到這了,更多相關PHP Swagger內容請搜索以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持!

標簽: PHP
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
久久久久se| 欧美日韩国产一二三| 久久久久久麻豆| 亚洲国产欧美不卡在线观看| 亚洲免费观看高清完整| 久久综合激情| 97久久精品人人做人人爽50路| 亚洲综合激情小说| 欧美在线视频日韩| 国内精品福利| 久久成人精品无人区| 国产精品成人一区二区三区夜夜夜| 91传媒视频在线播放| 午夜精品久久| 久久国产三级精品| 亚洲欧美二区三区| 欧美综合久久久| 久久精品一区二区国产| 午夜在线播放视频欧美| 日韩视频一区| 一区福利视频| 国产精品永久| 欧日韩精品视频| 91黄色在线观看| 99麻豆久久久国产精品免费| 亚洲综合在线第一页| 国产亚洲一区二区在线观看| 欧美在线观看18| 久久人人97超碰国产公开结果| 亚洲成色精品| 亚洲无线视频| 亚洲国产精选| 亚洲午夜高清视频| 亚洲无吗在线| 亚洲福利久久| 亚洲高清视频一区| 欧美日韩网址| 亚洲一级网站| 91亚洲永久精品| 91免费在线播放| 欧美+亚洲+精品+三区| 欧美黄色一级视频| 色综合天天综合色综合av | 9久草视频在线视频精品| 最新日韩在线| 国产欧美日韩综合| 亚洲国产人成综合网站| 国产精品一区在线观看| 欧美videos中文字幕| 韩国毛片一区二区三区| 在线观看成人小视频| 一区二区三区在线免费观看| 精品在线你懂的| 在线观看区一区二| 在线精品亚洲| 中文字幕综合网| 免费在线国产精品| 色悠悠久久综合| 久久精品二区三区| 色婷婷亚洲婷婷| 欧美欧美欧美欧美| 日韩欧美电影一区| 国产精品久久久久天堂| 亚洲一区二区成人在线观看| 91麻豆精品国产91久久久久| 久久日韩粉嫩一区二区三区| 亚洲欧美日韩国产综合在线| 亚洲精品国产a久久久久久 | 极品日韩久久| 性久久久久久| 欧美一级日韩一级| 亚洲免费av高清| 国产乱子伦一区二区三区国色天香| www.日韩大片| 国产亚洲一区在线| 欧美日韩久久一区| 亚洲欧美日韩一区| 国产乱理伦片在线观看夜一区| 伊人久久久大香线蕉综合直播| 91成人在线精品| 欧美国产97人人爽人人喊| 亚洲午夜视频在线观看| 国产一区亚洲一区| 国产一区二区三区成人欧美日韩在线观看 | 激情久久久久久久久久久久久久久久| 成人av资源下载| 久久国产日韩欧美| 国产欧美日韩另类视频免费观看| 亚洲国产裸拍裸体视频在线观看乱了| 黄页视频在线91| 国产精品乱看| 欧美精品一区二区三区蜜臀| 亚洲高清中文字幕| 99视频超级精品| 色域天天综合网| 亚洲欧美日韩在线| 欧美伊人影院| 欧美日韩大陆在线| 午夜精品在线视频一区| 欧美三级视频| 日韩免费看的电影| 久久精品999| 亚洲免费网址| 国产精品视频一二| 北条麻妃一区二区三区| 91精品国产综合久久久久久久| 亚洲观看高清完整版在线观看| 色综合一个色综合亚洲| 日韩一区二区三区视频| 91精品国产全国免费观看| 精品一区二区三区日韩| 美女国产一区| 日韩综合小视频| 亚洲精品在线观看免费| 欧美www视频| 久久成人精品无人区| 鲁大师影院一区二区三区| 亚洲欧美在线视频观看| 一区在线播放| 亚洲一区欧美一区| 欧美美女一区二区三区| av激情亚洲男人天堂| 国产日韩精品一区| 欧美亚洲三级| 国产一区二区在线视频| 26uuu精品一区二区三区四区在线| 欧美精品福利| 亚洲国产精品欧美一二99| 欧美三级视频在线| 国产成人精品影视| 国产喂奶挤奶一区二区三区| 亚洲国产精品一区二区第一页| 亚洲一区二区三区在线看| 国产亚洲午夜| 亚洲精品视频免费观看| 91福利视频网站| 成人黄色av网站在线| 亚洲色图色小说| 91国产免费观看| www.亚洲人| 亚洲国产精品综合小说图片区| 欧美精品粉嫩高潮一区二区| 红桃视频国产一区| 国产大陆精品国产| 亚洲国产精品嫩草影院| 欧美日韩国产小视频在线观看| 国产精品主播直播| 亚洲成av人片在www色猫咪| 亚洲精品一区在线观看| 日韩亚洲国产欧美| 国模娜娜一区二区三区| 日本一区二区免费在线| 欧美专区日韩专区| 136国产福利精品导航网址| 麻豆精品国产传媒mv男同| 国产suv精品一区二区三区| 国产精品视频麻豆| 葵司免费一区二区三区四区五区| 国产不卡视频一区| 亚洲高清免费视频| 久久夜色精品国产噜噜av | 成人动漫精品一区二区| 国产精品国模大尺度视频| 日本精品免费观看高清观看| 波多野结衣中文字幕一区| 国产手机视频一区二区| 91蝌蚪porny成人天涯| 丰满亚洲少妇av| 美女mm1313爽爽久久久蜜臀| 日本欧美肥老太交大片| 亚洲一区二区黄色| 亚洲综合免费观看高清完整版在线| 欧美女孩性生活视频| 亚洲女优在线| 国产一区久久| 99久久精品国产观看| 久久99国产乱子伦精品免费| 精品va天堂亚洲国产| 午夜一区二区三视频在线观看| 激情91久久| 欧美日韩在线观看一区二区三区| 国产精品66部| 精品一区二区成人精品| 婷婷综合五月天| 伊人性伊人情综合网| 国产精品久久毛片| 精品久久久三级丝袜| 国产偷国产偷亚洲高清97cao| 成人91在线观看| 99久久99精品久久久久久| 欧美videos大乳护士334| 欧美日韩一卡二卡| 欧美午夜片在线看| 91精品国产日韩91久久久久久| 精品999久久久| 中文字幕亚洲区| 视频一区二区中文字幕| 久久国产福利国产秒拍| 国产成人精品免费网站| 亚洲成人自拍一区|