基础控制器

这里是一个基础控制器类的例子:

<?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();

文章导航