基于laravel Request的所有方法详解
获取请求的实例
通过 Facade
Request 这个 facade 可以让我们得到绑定在容器里的当前这个请求。比如:
?1 | $name = Request::input( 'name' ); |
注意,如果你在一个命名空间里,你需要在类文件的顶部使用 use Request; 这条声明来导入 Request 这个 facade 。
通过依赖注入
要通过依赖注入得到当前 HTTP 请求的实例,需要在你的控制器构造函数或者方法里 type-hint 类。当前请求的这个实例会被 Service Container 自动注入进来。
?1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | <?php namespace App\Http\Controllers; use Illuminate\Http\Request; use Illuminate\Routing\Controller; class UserController extends Controller { /** * 保存新的用户 * * @param Request $request * @return Response */ public function store(Request $request ) { $name = $request ->input( 'name' ); // } } |
如果你的控制器方法期待来自路由参数上的 input(值),可以在其它的依赖的后面列出这些路由参数:
?1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | <?php namespace App\Http\Controllers; use Illuminate\Http\Request; use Illuminate\Routing\Controller; class UserController extends Controller { /** * Store a new user. * * @param Request $request * @param int $id * @return Response */ public function update(Request $request , $id ) { // } } |
检索输入
检索输入的值
使用几个简单的方法,你可以得到在 Illuminate\Http\Request 实例上的用户的所有的输入。你不用管请求使用的 HTTP 动作是什么,可以使用同样的方法来得到所有的输入的值。
?1 | $name = Request::input( 'name' ); |
在缺少输入值的时候去获取到默认值
?1 | $name = Request::input( 'name' , 'Sally' ); |
确定一个输入值是否出现
?1 2 3 4 | if (Request::has( 'name' )) { // } |
得到请求里的所有输入的值
?1 | $input = Request::all(); |
得到请求里的部分输入值
?1 2 3 | $input = Request::only( 'username' , 'password' ); $input = Request::except( 'credit_card' ); |
如果输入里面包含数组类型的值,可以使用点的形式访问到这个数组里的值:
?1 | $input = Request::input( 'products.0.name' ); |
以前输入的值
Laravel 会存储在一次请求与下一次请求之间的输入值。比如,你可能需要在验证了输入错误之后重新填写表单。
把输入值闪存到会话里
flash 方法可以把当前的输入的值闪存(flash)到会话( session) 里。这样,在用户下一次对应用发出请求的时候可以用到这些输入值:
?1 | Request::flash(); |
把一部分输入值闪存到会话里
?1 2 3 | Request::flashOnly( 'username' , 'email' ); Request::flashExcept( 'password' ); |
闪存与重定向
你想闪存输入值并且用一个重定向(redirect)到前一个页面上,可以把输入闪存链到一个重定向上。
?1 2 3 | return redirect( 'form' )->withInput(); return redirect( 'form' )->withInput(Request::except( 'password' )); |
得到以前的数据
得到前一个请求里的闪存的输入值,可以使用在 Request 实例上的 old 这个方法。
?1 | $username = Request::old( 'username' ); |
如果你打算用 Blade 模板显示以前的输入值,可以使用 old 这个帮手:
?1 | {{ old( 'username' ) }} |
Cookies
Laravel 框架创建的所有的 Cookies 都是加密的,并且会签上一个认证的代码,意思就是如果这些 Cookies 在客户端那里被修改过,就会被认为是无效的 Cookies。
检索 Cookie 值
?1 | $value = Request::cookie( 'name' ); |
把一个新 Cookie 附加给一个响应
cookie 这个帮手的作用就是去生成新的 Symfony\Component\HttpFoundation\Cookie 实例。可以使用 withCookie 方法把Cookies 附加到 Response 实例上:
?1 2 3 | $response = new Illuminate\Http\Response( 'Hello World' ); $response ->withCookie(cookie( 'name' , 'value' , $minutes )); |
创建永恒的 Cookie
永恒,我们的意思其实就是 5 年。
?1 | $response ->withCookie(cookie()->forever( 'name' , 'value' )); |
文件
检索一个上传了的文件
?1 | $file = Request::file( 'photo' ); |
确定一个文件是不是被上传了
?1 2 3 4 | if (Request::hasFile( 'photo' )) { // } |
file 方法返回来的对象是 Symfony\Component\HttpFoundation\File\UploadedFile 类的一个实例,这个类继承了 PHP 的 SplFileInfo 类,提供了很多方法可以跟文件交互。
确定上传的文件是否有效
?1 2 3 4 | if (Request::file( 'photo' )->isValid()) { // } |
移动一个上传的文件
?1 2 3 | Request::file( 'photo' )->move( $destinationPath ); Request::file( 'photo' )->move( $destinationPath , $fileName ); |
其它文件方法
在 UploadedFile 实例上还有一些其它的方法。具体可以看一下 Class API 的文档 。
其它的请求信息
Request 类为你的应用提供了很多方法可以检查 HTTP 请求,它继承了 Symfony\Component\HttpFoundation\Request 类。下面是几个亮点。
检索请求 URI
?1 | $uri = Request::path(); |
检索请求方法
?1 2 3 4 5 6 | $method = Request::method(); if (Request::isMethod( 'post' )) { // } |
确定请求路径是否匹配一个模式
?1 2 3 4 | if (Request::is( 'admin/*' )) { // } |
得到当前请求的地址
?1 | $url = Request::url(); |
以上这篇基于laravel Request的所有方法详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/weixin_38112233/article/details/78586306
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。