Laravel 技术笔记 (一)【Routing 路由】

序言

此系列文章将不定期更新,献给未来健忘的自己,也献给刚接触 Laravel 的初学者们,若您在观看本系列文章后能有所收穫与成长,那将是我莫大的荣幸,废话不多说,让我们开始 Laravel 的探索之旅吧 ~
- Laravel 版本:9


路由定义

Laravel 的路由定义档案位于 routes/web.php 中,以下是一组基本的路由定义:

Route::get('/', function () {    return view('welcome');});

这组程式码是指当有使用者造访 「/」(网域的根目录)时,会执行匿名函式中的程式码,也就是回传名称为 welcome 的 view 档案(resources/views/welcome.blade.php)给使用者,最终会看到下面的这个画面:
http://img2.58codes.com/2024/20135794vmpmq83Jm5.jpg


路由重新导向

如果你要重新导向至另一路由,可搭配 Route::redirect() 使用:

/* 可使用第三个参数自定义状态码(预设为302) */Route::redirect('/here', '/there', 301);

路由动词

Laravel 可要求使用者发出 HTTP 请求时需匹配特定动词才符合路由定义:

/* GET */Route::get('/');/* POST */Route::post('/');/* PUT */Route::put('/');/* PATCH */Route::patch('/');/* DELETE */Route::delete('/');/* 任何动词都匹配 */Route::any('/');/* 自行定义,这里示範 GET 与 POST */Route::match(['get', 'post'], '/');

路由处理

除了回传 view 之外,也可以使用字串传递 controller 名称与方法:

/* 需使用 controller 的 namespace */use App\Http\Controllers\UserController; Route::get('/user', [UserController::class, 'index']);
/* controller 名称空间与 method 名称使用 @ 隔开 */Route::get('/user', 'App\Http\Controllers\UserController@index');

上面两种语法结果相同,只差在是否使用名称空间,注意第二种语法需将 controller 的名称空间输入完整,否则 Laravel 会找不到目标。


路由参数

如果你定义的路由有参数,也能用以下的语法将参数传入匿名函式:

Route::get('/user/{id}/profile', function ($id) {    /* 参数 id 将被传入 */})/* 在参数的后面加上 ? 可使参数变成选用,这种情况下也需定义预设值给路由 */Route::get('/user/{id?}/profile', function ($id = 1) {})

路由名称

在专案其他地方要引用路由时,可先替路由命名,就可以使用 route() 引用路由:

/* 在路由后方使用 name 替路由命名 */Route::get('/user/profile', function () {})->name('profile');/* 使用 route() 引用路由 */route('profile')/* 传递参数给 route() */route('profile', ['id' => 1])

路由前缀

若有路由共用一组路径名称,可使用 prefix() 进行设定:

/* 範例中代表请求路径需符合 admin/users 才会匹配路由 */Route::prefix('admin')->group(function () {    Route::get('/users', function () {    });});

路由群组

若有複数路由共用 middleware、prefix 等等设定可将路由群组化:

/* 使用 group 将複数路由群组化,範例中两组 Route::get() 路由将同时套用相同的 middleware 设定 */Route::middleware(['first', 'second'])->group(function () {    Route::get('/');    Route::get('/user/profile');});

路由速率限制

如果要限制使用者只能在一段时间内访问路由的次数:
(1) 在 App\Providers\RouteServiceProvider 档案内定义速率限制

/* 第一个参数为此速率限制的名称,可自行随意命名,範例为每分钟限制1000次 */protected function configureRateLimiting(){    RateLimiter::for('global', function (Request $request) {        return Limit::perMinute(1000);    });}
/* 可使用 response() 自行定义超出限制时回传的内容 */RateLimiter::for('global', function (Request $request) {    return Limit::perMinute(1000)->response(function () {        return response('Custom response...', 429);    });});
/* 可使用 by() 取得使用者 IP 并限制访问路由的次数 */RateLimiter::for('global', function (Request $request) {            return Limit::perMinute(1000)->by($request->ip())->response(function () {                return response('Custom response...', 429);            });        });

(2) 将上面设定好的路由限制器 global 加到路由上

/* 透过 middleware() 将速率限制器加到路由上 */Route::middleware(['throttle:global'])->group(function () {    Route::post('/audio', function () {    });});

备用路由

若希望在其他路由都没有匹配的情况下执行备用的路由,可使用 Route::fallback():

/* 注意!!备用路由应该是你所有定义路由中的最后一个 */Route::fallback(function () {});

路由快取

在将专案部署上线后,可搭配路由快取,加速载入的时间:

$ php artisan route:cache

清除路由快取:

$ php artisan route:clear

关于作者: 网站小编

码农网专注IT技术教程资源分享平台,学习资源下载网站,58码农网包含计算机技术、网站程序源码下载、编程技术论坛、互联网资源下载等产品服务,提供原创、优质、完整内容的专业码农交流分享平台。

热门文章