基础控制器

2018-02-24 15:51 更新

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

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

以上内容是否对您有帮助:
在线笔记
App下载
App下载

扫描二维码

下载编程狮App

公众号
微信公众号

编程狮公众号