基础控制器
这里是一个基础控制器类的例子:
<?php namespace App\Http\Controllers;
use App\Http\Controllers\Controller;
class UserController extends Controller {
/**
* 显示所给定的用户个人数据。
*
* @param int $id
* @return Response
*/
public function showProfile($id)
{
return view('user.profile', ['user' => User::findOrFail($id)]);
}
}
我们可以通过如下方式引导路由至对应的控制器动作:
Route::get('user/{id}', 'UserController@showProfile');
注意: 所有的控制器都应该扩展基础控制器类。
控制器和命名空间
有一点非常重要,那就是我们无需指明完整的控制器命名空间,在类名称中 App\Http\Controllers 之后的部分即可用于表示「根」命名空间。 RouteServiceProvider 默认会在包含根控制器命名空间的路由群组中,加载 routes.php 此文件。
若你要在 App\Http\Controllers 此目录深层使用 PHP 命名空间以嵌套化或组织你的控制器,只要使用相对于 App\Http\Controllers 根命名空间的特定类名称即可。因此,若你的控制器类全名为 App\Http\Controllers\Photos\AdminController,你可以像这样注册一个路由:
Route::get('foo', 'Photos\AdminController@method');
命名控制器路由
和闭包路由一样,你也可以指定控制器路由的名称。
Route::get('foo', ['uses' => 'FooController@method', 'as' => 'name']);
指向控制器行为的 URL
要产生一个指向控制器行为的 URL,可使用 action 辅助方法。
$url = action('App\Http\Controllers\FooController@method');
若你想仅使用相对于控制器命名空间的类名称中的一部分,来产生指向控制器行为的 URL,可用 URL 产生器注册控制器的根命名空间。
URL::setRootControllerNamespace('App\Http\Controllers');
$url = action('FooController@method');
你可以使用 currentRouteAction 方法来获取正在执行的控制器行为名称:
$action = Route::currentRouteAction();
更多建议: