lin-cms-tp/reflex-core

LinCms TP 的反射类核心模块封装,含多种路由注册模式,路由及请求类型验证,基于`wangyu/reflex-core`扩展

dev-master 2019-05-17 06:55 UTC

This package is auto-updated.

Last update: 2024-10-17 18:46:43 UTC


README

LinCms TP 的反射类核心模块封装,含多种路由注册模式,路由及请求类型验证,基于wangyu/reflex-core扩展

  • 反射路由模式
  • 优化路由注册
  • 反射参数验证
  • 简洁
  • 优秀

composer安装说明

composer require lin-cms-tp/reflex-core

如果安装失败,报错 but these conflict with your requirements or minimum-stability

请在更改composer.json文件

"require": {
    "php": ">=7.1.0",
    /* 省略其他 */
    "wangyu/reflex-core": "dev-master",
    "lin-cms-tp/reflex-core": "dev-master"
},

使用说明

反射路由模式

  • 需要更改route.php文件注册路由方式

注册模块路由LinRoute::init()

use LinCmsTp\Route as LinRoute;
// 注册模块路由
LinRoute::init(); // 等于使用 LinRoute::init('api');

注册类路由LinRoute::cls()

use LinCmsTp\Route as LinRoute;
// 注册类路由
LinRoute::cls(
    'app\api\controller\cms\User', // 类命名空间
    ['Auth','linRouteParam'] // 中间件
);

注册方法路由LinRoute::fuc()

use LinCmsTp\Route as LinRoute;
// 注册类路由
LinRoute::fuc(
    'app\api\controller\cms\User', // 类命名空间
    'login', // 方法
    ['Auth','linRouteParam'] // 中间件
);

设置API方法注释@route('路由','请求类型')

/**
 * 账户登陆
 * @route('cms/user/login','post')
 * @param Request $request
 * @param('\app\api\validate\user\LoginForm')
 * @return array
 * @throws \think\Exception
 */
public function login(Request $request)
{
    $params = $request->post();
    $user = UserModel::verify($params['nickname'], $params['password']);
    $result = Token::getToken($user);
    logger('登陆领取了令牌', $user['id'], $user['nickname']);
    return $result;
}

路由中间件

  • 需要在系统config配置middleware.php
<?php
return [
    // 默认中间件命名空间
    'default_namespace' => 'app\\http\\middleware\\',
    'linRouteParam' => LinCmsTp\Param::Class
];
  • 需要在接口类注释设置@middleware
/**
 * Class Book
 * @route('v1/book')
 * @middleware('Auth')
 * @package app\api\controller\v1
 */
class Book
{}

联系我们

  • QQ: 354007048
  • Email: china_wangyu@aliyun.com