PHP 基于 SW-X 框架,搭建高性能API架构(四)

简介: 中间件属于AOP切面编程的衍生,SW-X中的中间件可以通过绑定路由地址,实现控制器无切入的关联绑定。在中间件中,可以进行请求拦截(前置操作)、或者请求缓存销毁(后置操作)等业务。

前言

官网地址:SW-X框架-专注高性能便捷开发而生的PHP-SwooleX框架

希望各大佬举起小手,给小弟一个star:https://github.com/swoolex/swoolexlex


1、什么是中间件

中间件属于AOP切面编程的衍生,SW-X中的中间件可以通过绑定路由地址,实现控制器无切入的关联绑定。

在中间件中,可以进行请求拦截(前置操作)、或者请求缓存销毁(后置操作)等业务。


2、通过路由绑定中间件

接回上章案例,我们现在要对/api/*前缀的所有接口,统一绑定一个名为Auth的中间件。

需要先再/config/middleware.php中间件配置文件中注册绑定规则:

<?php
return [
    // 匹配中间件,路由前半段是/api/开头的都会绑定到
    '/api/*' => [
        \box\middleware\Auth::class,
    ],
];

所有中间件不强制继承\x\Middleware基类,但一般建议继承,\x\Middleware类提供了一个error()方法,当开发者想中断应用继续向下执行时,可以调用该方法,抛出自定义的提示内容到客户端,该方法兼容了框架中4种不同的服务。

中间件建议(但不强制)统一存放在/box/middleware/目录下, 便于项目管理。

接下来,我们在/box/middleware/目录下,创建一个Auth.php类,并写入代码:

<?php
/**
 * +----------------------------------------------------------------------
 * 权限中间件
 * +----------------------------------------------------------------------
 * 官网:SW-X框架-专注高性能便捷开发而生的PHP-SwooleX框架
 * +----------------------------------------------------------------------
 * 作者:小黄牛 <1731223728@qq.com>
 * +----------------------------------------------------------------------
 * 开源协议:http://www.apache.org/licenses/LICENSE-2.0
 * +----------------------------------------------------------------------
*/
namespace box\middleware;
use x\Middleware;
use x\Restful;
class Auth extends Middleware{
  // 需要跳过的路由
  private $_skip = [
    'shop/delete',
  ];
  // 需要跳过的前置路由
  private $_group_skip = [
    'login/',
  ];
  /**
   * 前置操作
   * @todo 无
   * @author 小黄牛
   * @version v2.5.0 + 2021.07.20
   * @deprecated 暂不启用
   * @global 无
   * @return void
  */
  public function handle() {
    // 获得当前路由地址
    $route = \x\Config::get('route');
    $url = str_replace($route['suffix'], '', ltrim(\x\Request::url(), $route['cutting']));
    $url = substr_replace($url, '', 0, (strpos($url, $route['cutting'])+1));
    // 跳过校验
    if (in_array($url, $this->_skip)) {
      return true;
    }
    // 跳过校验
    foreach ($this->_group_skip as $v) {
      if (stripos($url, $v) === 0) {
        return true;
      }
    }
    // 通过上下文,获得请求实例
    $Request = \x\context\Request::get();
    $get = $Request->get;// get表单
    $post = $Request->post;// post表单
    $header = $Request->header;// post表单
    // 没有访问权限
    if (!isset($get['test'])) {
      Restful::code(Restful::ACTION_ERROR())->callback();
      // 返回false表示中断执行
      return false;
    }
    // 返回true表示继续向下执行
    return true;
  }
}

同时,由于上面我们使用了一个ACTION_ERROR状态码,所以要在Restful状态码文件中加入响应的配置。

/restful/default/code.php修改成如下代码:

<?php
return [
    'ERROR' => 0, // 默认失败状态码
    'SUCCESS' => 1, // 默认成功状态码
    'ACTION_ERROR' => 40001, // 默认成功状态码
];

/restful/default/msg.php修改成如下代码:

<?php
return [
    // 默认错误状态码对应的tips
    'ERROR' => [
        'default' => '请求失败', // 默认值
    ],
    // 默认成功状态码对应的tips
    'SUCCESS' => [
        'default' => '请求成功', // 默认值
    'test' => '测试msg',
    ],
    // 权限校验失败
    'ACTION_ERROR' => [
        'default' => '权限校验失败', // 默认值
    ],
];

这时候我们访问http://IP地址:端口/api/shop/select接口,就会看到框架抛出了下面的状态码:

{
  "code": 40001,
  "msg": "权限校验失败",
  "data": []
}

如果访问http://IP地址:端口/api/shop/select?test=就是通过的。

同时,我们还可以创建/app/http/v1_0_1/controller/shop/delete.php/app/http/v1_0_1/controller/login/send.php接口,来测试中间件判断是否能够正常跳过。


/app/http/v1_0_1/controller/shop/delete.php代码如下:

<?php
namespace app\http\v1_0_1\controller\shop;
use x\controller\Http;
// 引入Restful组件
use x\Restful;
class delete extends Http
{
    public function index() {
    // Restful组件抛出接口响应
    return Restful::code(Restful::SUCCESS())->data([
            'title' => '我是api/shop/delete,跳过了中间件校验',
        ])->callback();
  }
}

/app/http/v1_0_1/controller/login/send.php代码如下:

<?php
namespace app\http\v1_0_1\controller\login;
use x\controller\Http;
// 引入Restful组件
use x\Restful;
class send extends Http
{
    public function index() {
    // Restful组件抛出接口响应
    return Restful::code(Restful::SUCCESS())->data([
            'title' => '我是api/login/send,跳过了中间件校验',
        ])->callback();
  }
}


创建完成后,就可以通过下列地址查看测试效果了:

http://IP地址:端口/api/shop/delete

http://IP地址:端口/api/login/send


相关文章
|
4月前
|
API
用 Koa 框架实现一个简单的 RESTful API
用 Koa 框架实现一个简单的 RESTful API
|
2月前
|
缓存 NoSQL Java
自研一套高性能API网关,你都需要做什么?
本文介绍了自研API网关的基本组成和架构,涵盖网关的作用、请求生命周期、功能点详解(如插件和规则)、技术选型(Java、Netty、Nacos)及设计要点。通过异步化设计、缓存、串行化优化、提高吞吐量和合理配置工作线程,确保高性能与稳定性。最后,提供了网关的架构图,帮助读者全面理解其构建过程。
122 0
|
4月前
|
消息中间件 缓存 架构师
关于 Kafka 高性能架构,这篇说得最全面,建议收藏!
Kafka 是一个高吞吐量、高性能的消息中间件,关于 Kafka 高性能背后的实现,是大厂面试高频问题。本篇全面详解 Kafka 高性能背后的实现。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
关于 Kafka 高性能架构,这篇说得最全面,建议收藏!
|
4月前
|
SQL 缓存 测试技术
构建高性能RESTful API:最佳实践与避坑指南###
—— 本文深入探讨了构建高性能RESTful API的关键技术要点,从设计原则、状态码使用、版本控制到安全性考虑,旨在为开发者提供一套全面的最佳实践框架。通过避免常见的设计陷阱,本文将指导你如何优化API性能,提升用户体验,确保系统的稳定性和可扩展性。 ###
86 12
|
4月前
|
缓存 API 数据库
Python哪个框架合适开发速卖通商品详情api?
在跨境电商平台速卖通的商品详情数据获取与整合中,Python 语言及其多种框架(如 Flask、Django、Tornado 和 FastAPI)提供了高效解决方案。Flask 简洁灵活,适合快速开发;Django 功能全面,适用于大型项目;Tornado 性能卓越,擅长处理高并发;FastAPI 结合类型提示和异步编程,开发体验优秀。选择合适的框架需综合考虑项目规模、性能要求和团队技术栈。
51 2
|
4月前
|
JSON JavaScript 中间件
Koa框架下的RESTful API设计与实现
在现代 Web 开发中,构建高效、可维护的 API 是至关重要的。Koa 是一个流行的 Node.js Web 应用框架,它具有简洁、灵活和强大的特性,非常适合用于设计和实现 RESTful API。
|
4月前
|
开发框架 Java 关系型数据库
Java哪个框架适合开发API接口?
在快速发展的软件开发领域,API接口连接了不同的系统和服务。Java作为成熟的编程语言,其生态系统中出现了许多API开发框架。Magic-API因其独特优势和强大功能,成为Java开发者优选的API开发框架。本文将从核心优势、实际应用价值及未来展望等方面,深入探讨Magic-API为何值得选择。
149 2
|
4月前
|
API PHP 数据库
PHP中哪个框架最适合做API?
在数字化时代,API作为软件应用间通信的桥梁至关重要。本文探讨了PHP中适合API开发的主流框架,包括Laravel、Symfony、Lumen、Slim、Yii和Phalcon,分析了它们的特点和优势,帮助开发者选择合适的框架,提高开发效率、保证接口稳定性和安全性。
161 3
|
4月前
|
安全 API 数据库
Python哪个框架合适开发淘宝商品详情api?
在数字化商业时代,开发淘宝商品详情API成为企业拓展业务的重要手段。Python凭借其强大的框架支持,如Flask、Django、Tornado和FastAPI,为API开发提供了多样化的选择。本文探讨了这些框架的特点、优势及应用场景,帮助开发者根据项目需求选择最合适的工具,确保API的高效、稳定与可扩展性。
47 0
|
4月前
|
安全 API 网络架构
Python中哪个框架最适合做API?
本文介绍了Python生态系统中几个流行的API框架,包括Flask、FastAPI、Django Rest Framework(DRF)、Falcon和Tornado。每个框架都有其独特的优势和适用场景。Flask轻量灵活,适合小型项目;FastAPI高性能且自动生成文档,适合需要高吞吐量的API;DRF功能强大,适合复杂应用;Falcon高性能低延迟,适合快速API开发;Tornado异步非阻塞,适合高并发场景。文章通过示例代码和优缺点分析,帮助开发者根据项目需求选择合适的框架。
708 0

热门文章

最新文章