laravel9-原生注解路由插件-laravel-route-notes

yizhihongxing

laravel-route-notes

laravel框架扩展,原生注解生成路由

优点是直接生成路由文件,不在运行中解析路由,提升效率

使用环境

[PHP] >= 8.0

[Laravel] >= 9.0

如何安装

直接使用composer进行安装:

composer require --dev lovefc/laravel-route-notes

 命令使用

php artisan notes:route [-p dirname] [-f filename]

-p 要生成的控制器目录名称,默认为`app/Http/Controllers/`

-f 生成的路由文件地址,默认为`route/date("Y-m-d-His").php`

如果不指定控制器目录,默认会扫描app/Http/Controllers/下的所有控制器文件进行生成

注解使用

首先要先在控制器类中标记开启注释功能,这样运行命令才会生成路由

<?php
namespace App\Http\Controllers;
use App\Http\Controllers\Controller;
use App\Models\User;


#[annotate('true')]
class UserController extends Controller
{
    #[get('/show')]
    public function show()
    {
        return view('welcome');
    }
}

上面是一个常规的控制器,必须在声明类的上面加上#[annotate('true')],这样才会生成注解。

可以在类的注解上声明全局的属性,比如:

#[annotate('true'),prefix('/user')]

这样下面方法注解就会自动带上前缀,当然你也可以在方法上改变这个前缀。

注解方法的属性跟路由使用基本上一样。

比如:

#[get('show'),prefix('/user'),middleware('myauth')]

上面声明的注解最终会生成以下的路由:

#Route::prefix("/user")->post("all",[userController::class,"show"])->middleware("myauth");

除此之外,也支持where正则验证:

#[get('show/{name}'),where(['name'=>'[a-z]+'])]

又或者这样:

#[get('show/{name}'),where('name','[a-z]+')]

另外你可以在类注解上面声明全局的where属性:

#[annotate('true'),prefix('/user'),where(['name'=>'[a-z]+'])]

重定向路由注解案例:

#[annotate('true')]
class MyController extends Controller
{
    #[get('/index')]
    public function index(Request $request){
        return view('welcome');
    }
    
    #[redirect('/','/index')]
    public function home(){
        
    }
}

分组注解

laravel-route-notes 扩展新增了分组路由支持,先看下面两个控制器

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;

#[annotate('true'),group(['prefix' => '/home','middleware'=>'auth'])]
class MyController extends Controller
{
    #[get('/show')]
    public function show()
    {
        echo 'show';
    }
    
    #[get('/show2')]
    public function show2()
    {
        echo 'show2';
    }    
}

MyController 控制器的类注解上加上了一个 group(['prefix' => '/home','middleware'=>'auth'])

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;

#[annotate('true')]
class My2Controller extends Controller
{
    #[get('/')]
    public function show()
    {
        return view('welcome');
    }

    #[get('/login'),name('login')]
    public function login()
    {
        return view('welcome');
    }    

    #[get('/show3'),group(['prefix' => '/home','middleware'=>'auth'])]
    public function show2()
    {
        echo 'show3';
    }    
}

My2Controller控制器的方法show2上的注解上,同样也有个group(['prefix' => '/home','middleware'=>'auth'])

那么我们看一下最后生成的路由是什么样子的:

<?php

use Illuminate\Support\Facades\Route;
use App\Http\Controllers\My2Controller;
use App\Http\Controllers\MyController;

Route::get("/",[My2Controller::class,"show"]);

Route::get("/login",[My2Controller::class,"login"])->name("login");

Route::group(['prefix'=>'/home','middleware'=>'auth'],function(){

    Route::get("/show3",[My2Controller::class,"show2"]);

    Route::get("/show",[MyController::class,"show"]);

    Route::get("/show2",[MyController::class,"show2"]);

});

大家可以看到,对于相同命名的路由都会归类到一起。

关于路由分组,其实限制又有不少,因为如果命名了group(['属性'=>'属性值']),那么最好不要再去单独声明相同的属性了。

另外,如果你类注解声明了`group(['prefix' => '/home']`,那么方法注解里,在声明`prefix('/home2')`,将不会起作用,相同的属性,在分组里面声明并不会生效。

类注解的都是会自动注册到方法注解里面,也可以在方法注解里面覆盖。

更多说明,请阅读composer包里的说明文档,赶快来试一试吧!

原文链接:https://www.cnblogs.com/lovefc/p/16965788.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:laravel9-原生注解路由插件-laravel-route-notes - Python技术站

(0)
上一篇 2023年4月18日
下一篇 2023年4月18日

相关文章

  • PHP生成word文档的三种实现方式

    让我来为你详细讲解“PHP生成word文档的三种实现方式”的攻略。 一、使用PHPWord库 步骤一:安装PHPWord库 在使用PHPWord库之前,我们需要先安装该库。可以通过以下命令进行安装: composer require phpoffice/phpword 步骤二:创建一个空白word文档 我们可以使用PHPWord库来创建一个空白的Word文档…

    PHP 2023年5月26日
    00
  • 用PHP实现 上一篇、下一篇的代码

    下面是详细的攻略,包含代码实现和示例说明: 1. 获取文章列表 为了实现文章的上一篇和下一篇功能,我们需要先获取文章列表,并根据文章的发布时间或者ID等信息进行排序。可以使用数据库或者文件存储,这里以MySQL数据库为例。 示例代码: // 连接数据库 $servername = "localhost"; $username = &quo…

    PHP 2023年5月27日
    00
  • PHP 7.4 新语法之箭头函数实例详解

    PHP 7.4 新语法之箭头函数实例详解 在 PHP 7.4 中新增了箭头函数语法,这是一个非常实用的新功能,能够让PHP代码更加简洁易懂。本文主要介绍箭头函数的使用方法和实例。 基本语法 箭头函数与普通的PHP函数语法非常相似,只是在函数名称后面添加“=>”符号来表示这是一个箭头函数,然后可以接着添加函数的参数和函数体。下面是箭头函数的基本语法: (…

    PHP 2023年5月27日
    00
  • linux shell之文件锁

    关于”Linux Shell之文件锁”,以下是一些相关介绍。 什么是文件锁 在Linux中,文件锁是实现同步的一种方式。 当我们需要让一个进程修改文件时,我们需要使用文件锁来协调它和其他进程之间的异步操作。 文件锁的类型 Linux提供两种锁:共享锁和独占锁。 共享锁允许多个进程同时读取文件,而独占锁则会将文件完全锁住,只允许一个进程进行读或写操作。 文件锁…

    PHP 2023年5月27日
    00
  • PHP实现的连贯操作、链式操作实例

    PHP中的连贯操作(也称为链式操作),是指使用同一个对象进行多个操作,并且能够将这些操作连贯起来,以实现更加简洁和易读的代码构造。在本文中,我们将给出一个PHP实现的连贯操作的攻略,并且给出两个示例说明。 一、基本概念 1.1 什么是连贯操作 在PHP中,一个对象的连贯操作,指的是一连串方法的调用,每个方法返回的都是同一个对象。这样就可以在一个语句中调用多个…

    PHP 2023年5月27日
    00
  • PHP自动载入类文件函数__autoload的使用方法

    当我们在PHP中使用类时,需要提前把该类所在的文件引入到脚本中,否则会导致提示类未定义。如果我们有多个类需要引入,这个过程可能非常复杂,也容易出错。为了解决这个问题,我们可以使用PHP的自动载入类文件函数__autoload。 __autoload函数的概述 __autoload函数,是PHP 5引入的一个内置函数,主要用于在调用类之前自动引入该类所在的文件…

    PHP 2023年5月26日
    00
  • PHP用星号隐藏部份用户名、身份证、IP、手机号等实例

    我来讲解一下 “PHP用星号隐藏部份用户名、身份证、IP、手机号等实例”的攻略。 步骤如下: 通过PHP内置函数实现对目标信息的隐藏:可以使用str_replace、substr、preg_replace等函数实现。 取得目标信息长度后将需要隐藏的字符用星号替换:如可通过字符串长度得到需要隐藏的字符个数,然后将这些字符替换成星号。 下面是两个示例说明: 示例…

    PHP 2023年5月23日
    00
  • 使用cluster 将自己的Node服务器扩展为多线程服务器

    使用cluster模块可以将Node服务器扩展为多线程服务器。在使用cluster模块时,需要在主进程中创建子进程,然后将子进程绑定到服务器端口。然后,每个子进程都可以监听到相同的端口,接收到的请求将会均匀分发给每个子进程。 下面是使用cluster模块将Node服务器扩展为多线程服务器的完整攻略: 1. 安装cluster模块 使用npm安装cluster…

    PHP 2023年5月27日
    00
合作推广
合作推广
分享本页
返回顶部