PHP code example of linfly / annotation
1. Go to this page and download the library: Download linfly/annotation library . Choose the download type require .
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
linfly / annotation example snippets
use LinFly\Annotation\Route\Controller;
use LinFly\Annotation\Route\Route;
/**
* 控制器注解
* @param string|array $prefix 路由分组路径
*
* @Controller(prefix="/api")
*/
// PHP8注解方式
#[Controller(prefix: '/api')]
class ApiController
{
/**
* 注解路由
* @param string|array $path 路由路径 使用"/"开始则忽略控制器分组路径
* @param array $methods 请求方法 例:GET 或 ['GET', 'POST'],默认为所有方法
* @param string $name 路由名称 用于生成url的别名
* @param array $params 路由参数
*
* @Route(path="get", methods="get")
*/
// PHP8注解方式
#[Route(path: 'get', methods: 'get')]
public function get()
{
return 'get';
}
}
use LinFly\Annotation\Route\Controller;
use LinFly\Annotation\Route\Middleware;
use LinFly\Annotation\Route\Route;
/**
* @Controller(prefix="/api")
*
*
* 注解中间件 需要和注解路由一起使用
* @param string|array $middlewares 路由中间件 支持多个中间件
* @param array $only 指定需要走中间件的方法, 不指定则全部走中间件, 与except互斥 只支持在控制器上使用
* @param array $except 指定不需要走中间件的方法, 不指定则全部走中间件, 与only互斥 只支持在控制器上使用
*
* @Middleware(middlewares=AuthMiddleware::class, only={"get"})
*/
// PHP8注解方式
#[Middleware(middlewares=AuthMiddleware::class, only: ['get'])]
class ApiController
{
/**
* @Route(path="get", methods="get")
* @Middleware(middlewares={TokenCheckMiddleware::class})
*/
// PHP8注解方式
#[Middleware(middlewares=[TokenCheckMiddleware::class])]
public function get()
{
return 'get';
}
}
use app\validate\UserValidate;
use LinFly\Annotation\Validate\Validate;
use support\Request;
use support\Response;
class IndexController
{
/**
* @access public
*
* 注解验证器参数说明
* @param string|array $params 验证器参数 支持多个,例如: {"$get.id", "$post.name", "$post.title"}
* 验证器参数 支持:
* $post 获取所有 POST 参数
* $get 获取所有 GET 参数
* $all 获取所有 REQUEST 参数
* $post.xx 自定义 POST 参数名称 xx为实际的参数名称
* $get.xx 自定义 GET 参数名称 xx为实际的参数名称
* xx 自定义 REQUEST 参数名称 xx为实际的参数名称
* @param string $validate 验证器类名
* @param string $scene 验证场景
*
*
* @Validate(validate=UserValidate::class)
* @param Request $request
* @return Response
*/
// PHP8注解方式
//#[Validate(validate: UserValidate::class)]
public function index(Request $request)
{
return response('hello webman');
}
}
use LinFly\Annotation\Route\BindRoute;
use LinFly\Annotation\Route\Middleware;
use LinFly\Annotation\Validate\Validate;
use support\Request;
use support\Response;
use app\validate\UserValidate;
class IndexController
{
/**
* 绑定原生路由注解参数说明
* @param array $params 路由参数
* @param string $name 路由名称 用于生成url的别名
*/
#[BindRoute(params: ['info' => 'test_bind_route'], name: 'test_bind_route')]
#[Validate(validate: UserValidate::class)]
#[Middleware(middlewares=[TokenCheckMiddleware::class])]
public function index(Request $request)
{
$name = $request->route->getName();
$params = $request->route->param();
return response('hello webman');
}
}
/**
* 指定需要继承的方法, 不指定则全部继承, 与except互斥; 如果为false, 则不继承任何注解
* @param array|false $only
* 指定不需要继承的方法, 不指定则全部继承, 与only互斥
* @param array $except
* 参数为true时, 则合并父类的注解, 参数为false时, 则覆盖父类的注解
* @param bool $merge
*/
public function __construct(public array|false $only = [], public array $except = [], public bool $merge = true);
namespace app\controller;
use app\middleware\UserAuthMiddleware;
use app\validate\UserValidate;
use LinFly\Annotation\Annotation\Inherit;
use LinFly\Annotation\Route\Controller;
use LinFly\Annotation\Route\Middleware;
use LinFly\Annotation\Route\Route;
use LinFly\Annotation\Validate\Validate;
use support\Request;
#[
// 用户授权中间件
Middleware(middlewares: UserAuthMiddleware::class),
Validate(validate: UserValidate::class),
// 让所有子类都继承父类的注解(父类使用了继承注解, 子类可选使用继承注解)
Inherit,
// 让所有子类只继承父类的中间件注解
// Inherit(only: [Middleware::class]),
]
abstract class UserAuthController
{
}
namespace app\controller;
use LinFly\Annotation\Route\Controller;
use LinFly\Annotation\Route\GetRoute;
#[
Controller(prefix: 'user'),
// 不继承父类的注解
// Inherit(only: false),
// 继承父类的所有注解
// Inherit(only: []),
// 只继承父类的中间件注解
// Inherit(only: [Middleware::class]),
// 不继承父类的验证器注解
// Inherit(except: [Validate::class]),
]
class TestController extends UserAuthController
{
#[GetRoute]
public function info()
{
return json([
'user_id' => 1,
'username' => 'test',
]);
}
}
/**
* @param string|array $path
* 自定义控制器路径 变量{$className}值为删除命名空间前缀后转小驼峰的名称
*
* @param string $namespace
* 需要删除的命名空间前缀
*
* @param null|callable $filter
* 自定义过滤器
*/
public function __construct(string|array $path = '/{$className}', public string $namespace = '', ?callable $filter = null);
use LinFly\Annotation\Route\NamespaceController;
use LinFly\Annotation\Route\GetRoute;
// 自动设置控制器路径,通过注解继承来使用则只需要在父类上使用命名空间注解即可
#[NamespaceController(namespace: 'app\controller')]
class IndexController
{
#[GetRoute]
public function index()
{
return 'hello webman';
}
}
$container = \LinFly\FacadeContainer::getInstance();
$container->definition(config('dependence', []));
return $container;
/**
* @param string|array $name 实例或者别名
* @param array $parameters 参数
*/
public function __construct(protected string $name = '', protected array $parameters = []);
namespace app\service;
use LinFly\Annotation\Annotation\Inject;
class TestService
{
public function test()
{
return true;
}
}
namespace app\controller;
use LinFly\Annotation\Annotation\Inject;
use app\service\TestService;
class TestController
{
/**
* @Inject()
*
* 可以使用var注解指定注入的类, 或者声明属性类型来指定注入的类
* 更推荐使用声明属性类型的方式,优先级高于var注解
* @var TestService
*/
// PHP8注解方式
#[Inject]
protected TestService $testService;
public function test() {
var_dump($this->testService->test());
// true
}
}
use Doctrine\Common\Annotations\Annotation\Target;
use LinFly\Annotation\AbstractAnnotation;
/**
* @Annotation
* @Target({"CLASS"})
*/
#[\Attribute(\Attribute::TARGET_CLASS)]
class TestControllerParams extends AbstractAnnotation
{
/**
* 第一个参数必须包含array类型,用来接收注解的参数
* @param string|array $controller
*/
public function __construct(public string|array $controller = '')
{
$this->paresArgs(func_get_args(), 'controller');
}
}
use Doctrine\Common\Annotations\Annotation\Target;
use LinFly\Annotation\AbstractAnnotation;
/**
* @Annotation
* @Target({"METHOD"})
*/
#[\Attribute(\Attribute::TARGET_METHOD)]
class TestMethodParams extends AbstractAnnotation
{
/**
* 第一个参数必须包含array类型,用来接收注解的参数
* @param string|array $method
*/
public function __construct(public string|array $method = '')
{
$this->paresArgs(func_get_args(), 'method');
}
}
use app\annotation\params\TestControllerParams;
use app\annotation\params\TestMethodParams;
use support\Request;
/**
* 自定义类的注解类
* @TestControllerParams(controller=IndexController::class)
*/
// PHP8原生注解
// #[TestControllerParams(controller: IndexController::class)]
class IndexController
{
/**
* 自定义方法的注解类
* @TestMethodParams(method="index")
*/
// PHP8原生注解
// #[TestMethodParams(method: __METHOD__)]
public function index(Request $request)
{
// 业务代码 ...
}
}
use app\annotation\params\TestControllerParams;
use app\annotation\params\TestMethodParams;
use LinFly\Annotation\Annotation;
// 获取指定类的注解列表 包括:类注解、属性注解、方法注解、方法参数注解
$generator = Annotation::yieldParseClassAnnotations(IndexController::class);
/**
* @var string $annotationName 注解类类名
* @var array $items 注解类参数列表
*/
foreach ($generator as $annotationName => $items) {
switch ($annotationName) {
case TestControllerParams::class:
case TestMethodParams::class:
foreach ($items as $item) {
var_dump($item['type'] . ' -> ' . $item['annotation']);
}
break;
}
}
namespace app\annotation\handle;
use LinFly\Annotation\Interfaces\IAnnotationHandle;
class TestHandle implements IAnnotationHandle
{
public static function handle(array $item): void
{
switch ($item['type']) {
case 'class':
case 'method':
var_dump($item['type'] . ' -> ' . $item['annotation']);
break;
}
}
}
namespace app\bootstrap;
use app\annotation\handle\TestHandle;
use app\annotation\params\TestControllerParams;
use app\annotation\params\TestMethodParams;
use LinFly\Annotation\Annotation;
use Webman\Bootstrap;
class CreateAnnotationHandle implements Bootstrap
{
/**
* start
* @access public
* @param $worker
* @return void
*/
public static function start($worker)
{
// monitor进程不执行
if ($worker?->name === 'monitor') {
return;
}
// 添加测试控制器注解类处理器
Annotation::addHandle(TestControllerParams::class, TestHandle::class);
// 添加测试控制器方法注解类处理器
Annotation::addHandle(TestMethodParams::class, TestHandle::class);
}
}
return [
// ...这里省略了其它配置...
app\bootstrap\CreateAnnotationHandle::class,
];