laravel version: 5.5.*
路由文件: route/web.php
路由类型
- get 只匹配get类型的请求
- post 只匹配post类型的请求
- delete 只匹配delete类型的请求
- put 只匹配put类型的请求
- any 匹配
get
post
delete
put
任意一种类型的请求
基本使用
基本格式: Route::路由方式('路由', '命名空间\控制器@方法');
- 在PHP中..
// 基本路由
Route::get('/', 'TestController@index');
Route::post('/store', 'TestController@store');
Route::put('/update/{id}', 'TestController@update');
Route::delete('/delete/{id}', 'TestController@destroy');
RouteW::any('/test', 'TestController@test');
// 特殊路由
Route::resource('/article', 'ArticleController');
Route::resources([
'/article' => 'ArticleController',
'/comment' => 'CommentController',
]);
- 在模板中..
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>laravel route</title>
</head>
<body>
<!-- Get Request -->
<a href="/">Get Request</a>
<!-- Post Request -->
<form action="/store" method="post">
{{csrf_filed()}}
<button>Post Request</button>
</form>
<!-- Put Request -->
<form action="/put/1" method="post">
{{csrf_filed()}}
@method('PUT')
<button>Put Request</button>
</form>
<!-- Delete Request -->
<form action="/put/1" method="post">
{{csrf_filed()}}
@method('DELETE')
<button>Delete Request</button>
</form>
<!-- 除了使用框架的函数和模板引擎, 也可以使用这样的方式来访问 -->
<form action="/put/1" method="post">
<input type="hidden" name="_method" value="PUT">
<input type="hidden" name="_token" value="{{ csrf_token() }}">
<button>Delete Request</button>
</form>
</body>
<html>
CSRF 验证
所有 POST 类型的路由(包括 _POST_,_PUT_, _DELETE_)
, 都必须使用通过 CSRF 验证
才能匹配到路由
{{csrf_filed()}} // 生成 scrf token 字段
{{csrf_token()}} // 生成 scrf token 值
路由参数
- 必须参数: 访问路由时, 没有指定的参数就不能访问
Route::get('user/{id}', function ($id) {
return 'User ' . $id;
});
- 可选参数: 访问路由时, 没有指定的参数也能访问
Route::get('user/{id?}', function ($id) {
$userId = $id ? $id : '';
return 'User ' . $userId;
});
- 多个参数
Route::get('user/{id}/{name?}', function ($id, $name='') {
return $name .'-'. $id;
});
- 参数约束,
get请求
的参数能够在地址栏中修改,为了保证参数的正确性,可以使用参数约束
// 约束单个参数
Route::get('user/{id}', function ($id) {
// $id 必须是数字,且不能为空
return "hello world";
})->where('id', '[0-9]+');
// 约束多个参数
Route::get('user/{id}/{name}', function ($id) {
// $id 必须是数字,且不能为空
return "hello world";
})->where(['id' => '[0-9]+', 'name' => '\w{3,5}']);
路由重定向
访问第一个路由跳转到第二个路由
Route::redirect('第一个路由', '第二个路由', HTTP状态码);
Route::redirect('/here', '/there', 301);
路由命名
命名路由为生成 URL 或重定向提供了方便
Route::get('user/profile', function () {
// 使用 route 助手函数, 通过路由名称生成 URL
return "url". route('profile');
})->name('profile');
// 也可以这样
Route::get('user/profile', 'UsersController@profile')->name('profile');
路由分组
使用路由分组,可以方便的设置多个路由的 中间件 命令空间
前缀
等相同的信息
Route::group([
'middleware' => 'login', // 如果有多个可以使用数组 ['login', 'admin']
'namespace' => '\admin',
'prefix' => '/admin',
], function () {
Route::get('/uers/index', 'UsersController@index');
// 等价于: Route::get('/admin/uers/index','admin\UsersController@index')->middleware('login');
});
资源路由
资源路由一般会和资源控制器配合使用
使用资源路由,可以快速生成多条常用的路由, 多资源路由的原理也是一样
// 资源路由
Route::resource('/admin/user', '\admin\UsersController');
// 批量资源路由
Route::resource([
'/admin/user' => '\admin\UsersController',
'/admin/article' => '\admin\ArticlesController',
]);
资源路由
自定义错误页面
- 在
resource/views
目录下新建一个errors
目录 - 自定义指定
http 状态码
的blade模板文件
-
abort()
中断request请求
Route::get('/404', function () {
abort(404, 'Not Found'); // 404.blade.php
abort(503); // 503.blade.php
});
网友评论