基础:
所有的laravel路由都定义在 app/Http/routes.php 这个文件里,会被框架自带加载。简单的路由会接受一个URI和一个Closure类。
Route::get('foo', function () {
return 'Hello World';
});
默认的routes.php 是被RouteServiceProvider所加载进入框架的,允许自定义路由和响应
Route::get($uri, $callback);
Route::post($uri, $callback);
Route::put($uri, $callback);
Route::patch($uri, $callback);
Route::delete($uri, $callback);
Route::options($uri, $callback);
html是不支持PUT DELETE 等方法的,所以需要伪造一下
表单中加入隐式的_method方法和value值 <form action="/foo/bar" method="POST">
<input type="hidden" name="_method" value="PUT">
<input type="hidden" name="_token" value="{{ csrf_token() }}">
</form> 也可以通过 method_field('PUT')
输出
<input type="hidden" name="_method" value="PUT">
如果需要一个路由对多个HTTP请求进行相应,可以使用math方法或者any方法
Route::match(['get', 'post'], '/', function () {
//
}); Route::any('foo', function () {
//
});
通过Route::current()访问当前的路由
$route = Route::current(); $name = $route->getName(); $actionName = $route->getActionName();
$name = Route::currentRouteName(); $action = Route::currentRouteAction();
二 路由参数
必选参数
Route::get('user/{id}', function ($id) {
return 'User '.$id;
}); 或者
Route::get('posts/{post}/comments/{comment}', function ($postId, $commentId) {
//
});
可选参数 加个问号就是可以选参数
Route::get('user/{name?}', function ($name = null) {
return $name;
}); Route::get('user/{name?}', function ($name = 'John') {
return $name;
});
参数约束
对路由中的URI参数进行约束,通过where字段中加入正则表达式
Route::get('user/{name}', function ($name) {
//
})
->where('name', '[A-Za-z]+'); Route::get('user/{id}', function ($id) {
//
})
->where('id', '[0-9]+'); Route::get('user/{id}/{name}', function ($id, $name) {
//
})
->where(['id' => '[0-9]+', 'name' => '[a-z]+']);
全局约束
可以在RouteServiceProvider中的 boot
方法中 对给定的路由参数进行全局约束
位于app\Http\Provider\RouteServiceProvider.php中
public function boot(Router $router)
{
$router->pattern('id', '[0-9]+'); parent::boot($router);
}
之后访问id会自动进行约束
Route::get('user/{id}', function ($id) {
// Only called if {id} is numeric.
});
路由重命名
通过在路由定义数组中使用 as 参数可以为路由重新定义方法
Route::get('user/profile', ['as' => 'profile', function () {
//
}]); 也可以同时定义控制器
Route::get('user/profile', [
'as' => 'profile', 'uses' => 'UserController@showProfile'
]);
也可以通过链式调用name函数来定义
Route::get('user/profile', 'UserController@showProfile')->name('profile');
路由群组
通过在群组属性数组中定义一个 as属性为群组定一个公共前缀
Route::group(['as' => 'admin::'], function () {
Route::get('dashboard', ['as' => 'dashboard', function () {
// Route named "admin::dashboard"
}]);
});
测试
定义路由群组: Route::group(['as' => 'admin::'], function(){
Route::get('groupsub', ['as' => 'sub', function(){
echo "in route group";
}]);
}); 通过路由群组前缀访问路由: Route::get('/test', function(){
return redirect() -> route('admin::sub');
}); 访问http://localhost/test时会被重定向到
http://localhost/groupsub输出 in route group
CSRF验证
使用 csrf_token()生成token值添加到表单中laravel会自动验证
<input type="hidden" name="_token" value="csrf_token()“ /> 使用 csrf_field() 自动生成字段
<?php echo csrf_field(); ?>
生成
<input type="hidden" name="_token" value="<?php echo csrf_token(); ?>">
通过在VerifyCsrfToken
中except数组中可以添加不验证的路由VerifyCsrfToken.php文件中
class VerifyCsrfToken extends BaseVerifier
{
/**
* The URIs that should be excluded from CSRF verification.
*
* @var array
*/
protected $except = [
//此处添加
];
}