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

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获取文件扩展名的常用方法小结【五种方式】

    PHP获取文件扩展名的常用方法小结 在编写Web开发中,经常会遇到需要获取文件扩展名的需求。因此,本文将介绍PHP中获取文件扩展名的常用方法,主要涵盖以下五种方式: 通过pathinfo函数获取文件扩展名 <?php $filename = ‘example.jpg’; $extension = pathinfo($filename, PATHINFO…

    PHP 2023年5月26日
    00
  • PHP上传图片到数据库并显示的实例代码

    下面是PHP上传图片到数据库并显示的完整攻略: 准备工作 在开始编写代码之前,需要做一些准备工作: 创建一个MySQL数据库和一张图片表,表中至少包含以下列:id(主键)、imageName(图片名称)、imageType(图片类型)、imageData(图片数据); 在你的项目中创建一个文件夹用于存储上传的图片。 上传图片的流程 创建一个HTML表单,包含…

    PHP 2023年5月23日
    00
  • php进程间通讯实例分析

    让我们来详细讲解“PHP进程间通讯实例分析”的完整攻略。 什么是进程间通讯(IPC)? 进程间通讯(Inter-Process Communication,IPC)是指两个或多个进程之间传输信息或者资源的过程。在PHP中,进程间通讯主要用于不同的进程之间进行数据交换。 如何实现PHP进程间通讯(IPC)? 实现进程间通讯的方法有很多,比如共享内存、信号量、管…

    PHP 2023年5月27日
    00
  • 深入解析PHP中foreach语句控制数组循环的用法

    深入解析PHP中foreach语句控制数组循环的用法 1. foreach语句的基本格式 在PHP中,我们常用foreach语句来遍历数组。foreach语句的一般形式如下: foreach($array as $value) { //执行操作 } 其中,$array表示要遍历的数组,可以是索引数组或关联数组。$value表示当前循环到的元素的变量名,可以在…

    PHP 2023年5月26日
    00
  • PHP使用CURL实现下载文件功能示例

    关于“PHP使用CURL实现下载文件功能示例”的攻略如下: 概述 CURL是一款用来传输数据的工具,可以通过HTTP、FTP、SMTP等协议发送和接收数据。在PHP中,可以使用CURL来实现文件的下载功能,实现代码简单,效率高。 步骤 使用CURL下载文件的步骤如下: 初始化CURL,创建CURL句柄。使用curl_init()函数进行初始化,该函数返回一个…

    PHP 2023年5月27日
    00
  • 微信小程序获取微信运动步数的实例代码

    下面我将详细讲解“微信小程序获取微信运动步数的实例代码”的完整攻略。 一、前提条件 在使用微信小程序获取微信运动步数之前,需要满足以下几个前提条件: 用户已经在微信中授权了小程序访问微信运动步数。 小程序已经申请了微信运动步数的授权。 二、获取微信运动步数的实现方式 2.1 方式一:使用微信运动接口获取步数 微信开放平台提供了相关的微信运动接口,小程序可以通…

    PHP 2023年5月23日
    00
  • PHP常用的类封装小结【4个工具类】

    PHP常用的类封装小结【4个工具类】 在PHP开发中,使用类的封装可以提高代码的复用性、可维护性和可读性。本文介绍了4种常用的PHP类封装,包括: Curl类封装 Redis类封装 MySQL类封装 日志类封装 下面将详细介绍这4种类的封装方法以及使用场景。 Curl类封装 Curl是一种网络传输工具,PHP中内置了Curl扩展,可以用来发送HTTP请求等。…

    PHP 2023年5月28日
    00
  • PHP在线生成二维码(google api)的实现代码详解

    下面是关于“PHP在线生成二维码(google api)的实现代码详解”的攻略,可以供您参考: 简介 在互联网时代,有时我们需要将某个内容分享给他人或者在广告、产品包装上加上一些URL地址,那么生成二维码就成了一种非常常见的做法。本攻略将介绍如何使用PHP在线生成二维码,使用的API是Google API。 步骤 1. 申请Google API Key 首先…

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