这里是一个基础控制器类的例子:
<?php namespace AppHttpControllers;
use AppHttpControllersController;
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");
>注意: 所有的控制器都应该扩展基础控制器类。
控制器和命名空间
有一点非常重要,那就是我们无需指明完整的控制器命名空间,在类名称中 AppHttpControllers 之后的部分即可用于表示「根」命名空间。 RouteServiceProvider 默认会在包含根控制器命名空间的路由群组中,加载 routes.php 此文件。
若你要在 AppHttpControllers 此目录深层使用 PHP 命名空间以嵌套化或组织你的控制器,只要使用相对于 AppHttpControllers 根命名空间的特定类名称即可。因此,若你的控制器类全名为 AppHttpControllersPhotosAdminController,你可以像这样注册一个路由:
Route::get("foo", "PhotosAdminController@method");
命名控制器路由
和闭包路由一样,你也可以指定控制器路由的名称。
Route::get("foo", ["uses" => "FooController@method", "as" => "name"]);
指向控制器行为的 URL
要产生一个指向控制器行为的 URL,可使用 action 辅助方法。
$url = action("AppHttpControllersFooController@method");
若你想仅使用相对于控制器命名空间的类名称中的一部分,来产生指向控制器行为的 URL,可用 URL 产生器注册控制器的根命名空间。
URL::setRootControllerNamespace("AppHttpControllers");
$url = action("FooController@method");
你可以使用 currentRouteAction 方法来获取正在执行的控制器行为名称:
$action = Route::currentRouteAction();