多应用+插件架构,代码干净,二开方便,首家独创一键云编译技术,文档视频完善,免费商用码云13.8K 广告
当然,您可以获取请求路由的 URI 区段。 ## 基础路由参数 ~~~ Route::get('user/{id}', function($id) { return 'User '.$id; }); ~~~ ## 可选择的路由参数 ~~~ Route::get('user/{name?}', function($name = null) { return $name; }) ~~~ ## 带默认值的路由参数 ~~~ Route::get('user/{name?}', function($name = 'John') { return $name; }); ~~~ ## 使用正则表达式限制参数 ~~~ 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]+']) ~~~ ## 定义全局模式 如果你想让特定路由参数总是遵询特定的正则表达式,可以使用 pattern 方法。在 RouteServiceProvider 的 boot 方法里定义模式: `$router->pattern('id', '[0-9]+');` 定义模式之后,会作用在所有使用这个特定参数的路由上: ~~~ Route::get('user/{id}', function($id) { // 只有 {id} 是数字才被调用。 }); ~~~ ## 取得路由参数 如果需要在路由外部取得其参数,使用 input 方法: ~~~ if ($route->input('id') == 1) { // } ~~~ 你也可以使用 Illuminate\Http\Request 实体取得路由参数。当前请求的实例可以通过 Request facade 取得,或透过类型提示 Illuminate\Http\Request 注入依赖: ~~~ use Illuminate\Http\Request; Route::get('user/{id}', function(Request $request, $id) { if ($request->route('id')) { // } }); ~~~