Restful Api

Restful Api 架构介绍
转载:http://www.ruanyifeng.com/blog/2014/05/restful_api.html

一、框架介绍:Swagger UI, Swagger-PHP, SLim framework
Swagger UI
https://swagger.io/tools/swagger-ui/
Swagger UI允许任何人——无论是您的开发团队还是您的最终消费者——在没有任何实现逻辑的情况下可视化并与API的资源交互。它是由OpenAPI(以前称为Swagger)规范自动生成的,具有可视化文档,便于后端实现和客户端使用。

Swagger-PHP
http://zircote.com/swagger-php/
使用doctrine注释为RESTful API生成交互式OpenAPI文档。
SLim framework
https://www.slimframework.com/
Slim是一个PHP微框架,帮助您快速编写简单但功能强大的web应用程序和api。

二、框架安装
https://pkg.phpcomposer.com/
安装工具composer
https://getcomposer.org/download/
安装工具 composer.phar

 

安装slim
composer require slim/slim "^3.10.0"
php composer.phar require slim/slim "^3.10.0"

安装Swagger-PHP
composer require zircote/swagger-php
php composer.phar require zircote/swagger-php
然而,由于众所周知的原因,国外的网站连接速度很慢,并且随时可能被“墙”甚至“不存在”。

“Packagist 中国全量镜像”所做的就是缓存所有安装包和元数据到国内的机房并通过国内的 CDN 进行加速,这样就不必再去向国外的网站发起请求,
从而达到加速 composer install 以及 composer update 的过程,并且更加快速、稳定。因此,即使 packagist.org、github.com 发生故障(主要是连接速度太慢和被墙),
你仍然可以下载、更新安装包。
如果安装失败,配置下镜像的地址
全局:composer config -g repo.packagist composer https://packagist.phpcomposer.com
全局:php composer.phar config -g repo.packagist composer https://packagist.phpcomposer.com

当前项目:composer config repo.packagist composer https://packagist.phpcomposer.com
当前项目:php composer.phar config repo.packagist composer https://packagist.phpcomposer.com

三、框架整合
3-1、服务器Apache 、Nginx 、IIS 配置
https://www.slimframework.com/docs/v3/start/web-servers.html
3-2、服务端入口文件index.php
<?php
use \Psr\Http\Message\ServerRequestInterface as Request;
use \Psr\Http\Message\ResponseInterface as Response;

require '../vendor/autoload.php';

$app = new \Slim\App;
$app->get('/hello/{name}', function (Request $request, Response $response, array $args) {
    $name = $args['name'];
    $response->getBody()->write("Hello, $name");

    return $response;
});
//配置Swagger-PHP
$app->get('/swagger.json', function ($request, $response) {
    $swagger = \Swagger\scan('./src');
    $response->getBody()->write($swagger);
    return $response;
});
$app->run();
3-3、前端Swagger-UI配置
 window.onload = function() {

      // Build a system
      const ui = SwaggerUIBundle({
        url: "/test/slim/swagger.json", //修改这个位置
        dom_id: '#swagger-ui',
        deepLinking: true,
        presets: [
          SwaggerUIBundle.presets.apis,
          SwaggerUIStandalonePreset
        ],
        plugins: [
          SwaggerUIBundle.plugins.DownloadUrl
        ],
        layout: "StandaloneLayout"
      })

      window.ui = ui
    }

swagger-php注释文档

http://zircote.com/swagger-php/#links

http://zircote.com/swagger-php/1.x/annotations.html#items

https://laravel-china.org/topics/7430/how-to-write-api-documents-based-on-swagger-php

https://bfanger.nl/swagger-explained/#parameterObject

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值