一.Laravel控制器
基础控制器(组织请求处理逻辑)
通过路由来指定控制器行为:
Route::get('user/{id}','UserController@showProfile');//路由所带参数也会被传递到showProfile方法
命名控制器路由:
Route::get('foo', ['uses' => 'FooController@method', 'as' => 'name']);
$url = route('name')//生成命名控制器路由的 URL
$url = action('FooController@method');//生成指向控制器行为的 URL
$action = Route::currentRouteAction();//取到正在运行的控制器行为名称
中间件和控制器:
Route::get('profile', [
'middleware' => 'auth',
'uses' => 'UserController@showProfile'
]);//将 中间件 指定给控制器路由
在控制器构造器中使用 middleware 方法,你可以很容易地将中间件指定给控制器。你甚至可以对中间件作出限制,仅将它提供给控制器类中的某些方法。
public function __construct()
{
$this->middleware('auth');
$this->middleware('log', ['only' => ['fooAction', 'barAction']]);
$this->middleware('subscribed', ['except' => ['fooAction', 'barAction']]);
}
RESTful 资源控制器资源
控制器让你可以轻松地创建与资源相关的 RESTful 控制器,
使用 make:controller Artisan 命令,我们可以快速地创建一个像这样的控制器
php artisan make:controller 控制器名称
Route::resource('photos', 'PhotosController');//在控制器中注册资源化路由
这一条路由声明会创建多个路由,用来处理各式各样和相片资源相关的的 RESTful 行为。同样地,生成的控制器有着各种和这些行为绑定的方法,包含要处理的 URI 及方法对应的注释。
由资源控制器处理的行为:
动词 | 路径 | 行为(方法) | 路由名称 |
---|---|---|---|
GET | /photos | index | photo.index |
GET | /photos/create | create | photos.create |
POST | /photos | store | photos.store |
GET | /photos/{photo} | show | photos.show |
GET | /photos/{photo}/edit | edit | photos.edit |
PUT/PATCH | /photos/{photo} | update | photos.update |
DELETE | /photos/{photo} | destroy | photos.destroy |
部分资源路由:(声明资源路由时,你可以指定让此路由仅处理一部分的行为)
Route::resource('photos', 'PhotosController',
['only' => ['index', 'show']]);
Route::resource('photos', 'PhotosController',
['except' => ['create', 'store', 'update', 'destroy']]);
命名资源路由(所有的资源控制器行为默认都有路由名称;不过你可以在选项中传递一个 names 数组来重写这些名称)
Route::resource('photos', 'PhotosController', ['names' => ['create' => 'photo.build']]);
嵌套资源(有时你可能会需要定义「嵌套」资源路由。例如,相片资源可能会附带多个「评论」。要「嵌套」此资源控制器,可在路由声明中使用「点」记号)
Route::resource('photos.comments', 'PhotoCommentController');//photos/{photos}/comments/{comments}通过类示URL访问
附加资源控制器(如果想在资源控制器中默认的资源路由之外加入其它额外路由,则应该在调用 Route::resource 之前 定义这些路由。否则,由 resource 方法定义的路由可能会不小心覆盖你附加的路由)
隐式控制器
通过定义单个路由来处理控制器类中的各种行为,
使用 Route::controller 方法来定义路由
Route::controller('users', 'UserController');//controller 方法接受两个参数。第一个参数是控制器所处理的基本 URI,第二个是控制器的类名称
只要在控制器中加入方法。方法的名称应由它们所响应的 HTTP 动词作为开头,紧跟着首字母大写的 URI 所组成
<?php
namespace App\Http\Controllers;
class UserController extends Controller
{
/**
* 响应对 GET /users 的请求
*/
public function getIndex()
{
//
}
/**
* 响应对 GET /users/show/1 的请求
*/
public function getShow($id)
{
//
}
/**
* 响应对 GET /users/admin-profile 的请求
*/
public function getAdminProfile()
{
//
}
/**
* 响应对 POST /users/profile 的请求
*/
public function postProfile()
{
//
}
}
分派路由名称
命名控制器中的某些路由,可以在 controller 方法中传入一个名称数组作为第三个参数
Route::controller('users', 'UserController', [ 'getShow' => 'user.show', ]);
依赖注入与控制器
构造器注入
方法注入...都不太懂
路由缓存
若你的应用程序完全通过控制器使用路由,你可以利用 Laravel 的路由缓存。使用路由缓存可以大幅降低注册全部路由所需的时间。
要生成路由缓存,只要运行 route:cache 此 Artisan 命令
php artisan route:cache
这就可以了!现在你的缓存路由文件将被用来代替 app/Http/routes.php 这一文件。请记得,若你添加了任何新的路由,就必须生成新的路由缓存。因此你可能希望只在你的项目部署时才运行 route:cache 这一命令。
要移除缓存路由文件而不生成新的缓存,请使用 route:clear 命令
php artisan route:clear
二.Laravel请求
获取请求:要通过依赖注入的方式获取 HTTP 请求的实例,就必须在控制器的构造器或方法中,使用 Illuminate\Http\Request 类型提示
public function store(Request $request)
{
$name = $request->input('name');
//
}
如果控制器方法也有输入数据是从路由参数传入的,只需将路由参数置于其它依赖之后
EP:Route::put('user/{id}', 'UserController@update');
public function update(Request $request, $id)
{
//
}
基本请求信息:Illuminate\Http\Request 的实例提供了多种方法来用于检查应用程序的 HTTP 请求。Larevel 的 Illuminate\Http\Request 继承了 Symfony\Component\HttpFoundation\Request 类
获取请求的 URI
$uri = $request->path();//path 方法会返回请求的 URI;
if ($request->is('admin/*')) {
//is 方法可以验证接收到的请求 URI 与指定的规则是否相匹配,*号为通配符
}
$url = $request->url();//使用 url 方法,可以获取完整的网址
获取请求的方法
$method = $request->method();//method方法会返回此次请求的http动作
if ($request->isMethod('post')) {
//isMethod方法来验证http动作是否和指定的字符串是否相匹配
}
获取输入数据
特定值:$request->input('name');``$request->字段名;
$request->input('name', 'Sally');//第二个参数中传入一个默认值。当请求的输入数据不存在于此次请求时,就会返回默认值
$request->input('products.0.name');//如果是「数组」形式的输入数据,则可以使用「点」语法来获取数组
$request->has('name')
//确认是否有值
$input = $request->all();
//获取所有输入数据
如果想获取输入数据的子集,则可以使用 only 及 except 方法。这两个方法都接受单个数组或是动态列表作为参数
$input = $request->only(['username', 'password']); $input = $request->only('username', 'password'); $input = $request->except(['credit_card']); $input = $request->except('credit_card');
旧输入数据:Laravel 可以让你将本次的输入数据保留到下一次请求发送前。对于在表单验证失败后重新填入表单值相当有用
将输入数据闪存至 Session$request->flash();
$request->flashOnly('username', 'email'); $request->flashExcept('password');//数据的子集保存至 Session
闪存输入数据至 Session 后重定向return redirect('form')->withInput(); return redirect('form')->withInput($request->except('password'));
获取旧输入数据->若要获取上一次请求后所闪存的输入数据,则可以使用Request
实例中的old方法。old方法提供一个简便的方式从 Session 取出被闪存的输入数据
$username = $request->old('username');
Laravel 也提供了全局辅助函数old。如果你要在 Blade 模板 中显示旧输入数据,可以使用更加方便的old辅助函数{{ old('username') }}
从请求中取出Cookie值$value = $request->cookie('name');
上传文件
获取上传文件,可以使用 Illuminate\Http\Request 实例中的 file 方法获取上传的文件。file 方法返回的对象是 Symfony\Component\HttpFoundation\File\UploadedFile 类的实例,该类继承了 PHP 的 SplFileInfo 类,并提供了许多和文件交互的方法
$file = $request->file('photo');
$request->hasFile('photo')//确认上传的文件是否存在
$request->file('photo')->isValid()//验证上传的文件是否有效
$request->file('photo')->move($destinationPath); $request->file('photo')->move($destinationPath, $fileName);//将文件从缓存位置(由你的 PHP 配置决定)移动至你指定的永久保存位置
三.视图
视图包含你应用程序所用到的 HTML,它能够将控制器和应用程序逻辑在呈现逻辑中进行分离。视图被存在 resources/views 目录下
因为这个视图被保存在 resources/views/greeting.php,所以我们可以像这样使用全局的辅助函数 view 来返回
Route::get('/', function () { return view('greeting', ['键' => '值']); });//view 辅助函数的第一个参数会对应到 resources/views 目录内视图文件的名称;传递到 view 辅助函数的第二个参数是一个能够在视图内取用的数据数组
视图文件也可以被存放在 resources/views 的子目录内。. (小数点)的表示法可以被用来表示在子目录内的视图文件
return view('home.user.index', $data);
判断视图文件是否存在
view()->exists('emails.customer')//在视图文件存在时返回 true
return view('greetings', ['name' => 'Victoria']);//传递一个数组的数据给视图
$view = view('greeting')->with('name', 'Victoria');//使用 with 来传递额外数据给视图