1、访问请求实例
通过依赖注入获取当前HTTP请求实例,应该在控制器的构造函数或方法中对 Illuminate\Http\Request类进行类型提示,当前请求实例会被服务容器自动注入:
1 | <?phpnamespace App\Http\Controllers; use Illuminate\Http\Request; use Illuminate\Routing\Controller; class UserController extends Controller{ public function store(Request $request ) { $name = $request ->input( 'name' );
|
Copier après la connexion
如果你的控制器方法还期望获取路由参数输入,只需要将路由参数置于其它依赖之后即可,例如,如果你的路由定义如下:
1 | $app ->put( 'user/{id}' , 'UserController@update' );
|
Copier après la connexion
你仍然可以对 Illuminate\Http\Request进行类型提示并通过如下方式定义控制器方法来访问路由参数:
1 | <?php namespace App\Http\Controllers; use Illuminate\Http\Request; use Illuminate\Routing\Controller;classUser Controller extends Controller{ public function update(Request $request , $id ) {
|
Copier après la connexion
1.1 基本请求信息
Illuminate\Http\Request实例提供了多个方法来检测应用的HTTP请求,Lumen的 Illuminate\Http\Request继承自 Symfony\Component\HttpFoundation\Request类,这里列出了一些该类中的有用方法:
获取请求URI
path方法将会返回请求的URI,因此,如果进入的请求路径是 http://domain.com/foo/bar,则 path方法将会返回 foo/bar:
Copier après la connexion
is方法允许你验证进入的请求是否与给定模式匹配。使用该方法时可以使用 *通配符:
1 | if ( $request ->is( 'admin/*' )){
|
Copier après la connexion
想要获取完整的URL,而不仅仅是路径信息,可以调用请求实例的 url或 fullUrl方法:
Copier après la connexion
获取请求方法
method方法将会返回请求的HTTP请求方式。你还可以使用 isMethod方法来验证HTTP请求方式是否匹配给定字符串:
1 | $method = $request ->method(); if ( $request ->isMethod( 'post' )){
|
Copier après la connexion
1.2 PSR-7 请求
PSR-7标准指定了HTTP消息接口,包括请求和响应。如果你想要获取PSR-7请求实例,首先需要安装一些库,Lumen使用Symfony HTTP Message Bridge组件将典型的Lumen请求和响应转化为PSR-7兼容的实现:
1 | composer require symfony/psr-http-message-bridgecomposer require zendframework/zend-diactoros
|
Copier après la connexion
安装完这些库之后,你只需要在路由或控制器中通过对请求类型进行类型提示就可以获取PSR-7请求:
1 | use Psr\Http\Message\ServerRequestInterface; $app ->get( '/' , function (ServerRequestInterface $request ) {
|
Copier après la connexion
如果从路由或控制器返回的是PSR-7响应实例,则其将会自动转化为Lumen响应实例并显示出来。
2、获取输入
获取输入值
使用一些简单的方法,就可以从 Illuminate\Http\Request实例中访问用户输入。你不需要担心请求所使用的HTTP请求方法,因为对所有请求方式的输入访问接口都是一致的:
1 | $name = $request ->input( 'name' );
|
Copier après la connexion
你还可以传递一个默认值作为第二个参数给 input方法,如果请求输入值在当前请求未出现时该值将会被返回:
1 | $name = $request ->input( 'name' , 'Sally' );
|
Copier après la connexion
处理表单数组输入时,可以使用”.”来访问数组:
1 | $input = $request ->input( 'products.0.name' ); $names = $request ->input( 'products.*.name' );
|
Copier après la connexion
判断输入值是否出现
判断值是否在请求中出现,可以使用 has方法,如果值出现过了且不为空, has方法返回 true:
1 | if ( $request ->has( 'name' )) {
|
Copier après la connexion
获取所有输入数据
你还可以通过 all方法获取所有输入数据:
1 | $input = $request ->all();
|
Copier après la connexion
获取输入的部分数据
如果你需要取出输入数据的子集,可以使用 only或 except方法,这两个方法都接收一个数组或动态参数列表作为唯一参数:
1 | $input = $request ->only( 'username' , 'password' ); $input = $request ->only( 'username' , 'password' ); $input = $request ->except( 'credit_card' ); $input = $request ->except( 'credit_card' );
|
Copier après la connexion
文件上传
获取上传的文件
可以使用 Illuminate\Http\Request实例的 file方法来访问上传文件,该方法返回的对象是 Symfony\Component\HttpFoundation\File\UploadedFile类的一个实例,该类继承自PHP标准库中提供与文件交互方法的 SplFileInfo类:
1 | $file = $request ->file( 'photo' );
|
Copier après la connexion
验证文件是否存在
使用 hasFile方法判断文件在请求中是否存在:
1 | if ( $request ->hasFile( 'photo' )) {
|
Copier après la connexion
验证文件是否上传成功
使用 isValid方法判断文件在上传过程中是否出错:
1 | if ( $request ->file( 'photo' )->isValid()){
|
Copier après la connexion
保存上传的文件
使用 move方法将上传文件保存到新的路径,该方法将上传文件从临时目录(在PHP配置文件中配置)移动到指定新目录:
1 | $request ->file( 'photo' )->move( $destinationPath ); $request ->file( 'photo' )->move( $destinationPath , $fileName );
|
Copier après la connexion
其它文件方法
UploadedFile实例中很有很多其它方法,查看 该类的API了解更多相关方法。