Laravel 的HTTP请求#

获取请求#

要通过依赖注入的方式来获取当前HTTP请求的实例,你应该在控制器方法中类型提示Illuminate\Http\Request

传入的请求的实例通过 服务容器自动注入:

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;

class UserController extends Controller

{

  /*

    存储一个新用户

    @param Request $request

    @return Response

  */

  public function store(Request $request)

  {

    $name = $request->input(‘name‘);

  }

}

依赖注入 & 路由参数#

如果控制器方法要从路由参数中获取数据,则应在其他依赖项之后列出路由参数。例如,如果你的路由是这样定义的:

Route::put(‘user/{id}‘,‘[email protected]‘);

如下所示使用类型提示 Illuminate\Http\Request ,就可以通过定义控制器方法获取路由参数id:

<?php

namespace App\Http\Controller;

use Illuminate\Http\Request;

class UserController extends Controller

{

  /*

  更新指定的用户

  @param Request $request

  @param string $id

  @return Response

  */

  public function update(Request $request,$id)

  {

    //

  }

}

通过路由闭包获取请求#

你也可以在路由闭包中类型提示 Illuminate\Http\Request类,服务容器在执行时会自动将当前请求注入到闭包中:

use Illuminate\Http\Request;

Route::get(‘/‘,function(Request $request){});

请求路径&方法#

Illuminate\Http\Request 实例提供了多种方法来检查应用程序的HTTP请求,并继承了

Symfony\Component\HttpFoundation\Request 类。下面是该类几个有用的方法:

获取请求路径#

path 方法返回请求的路径信息。也就是说,如果传入的请求的目标地址是 http://domain.com/foo/bar 那么path 将

返回 foo/bar;

$uri = $request->path();

is 方法可以验证传入的请求路径和指定规则是否匹配。使用这个方法时,你也可以传递一个*字符作为通配符:

if ($request->is(‘admin/*‘)){}

获取请求的URL#

你可以使用url 或者fullUrl方法去获取传入请求的完整URL,url方法返回不带有查询字符串的URL,而fullUrl方法的返回值

包含查询字符串:

//WIthout Query String ...

$url = $request->url();

//With Query String ...

$url = $request->fullUrl();

获取请求方法#

对于传入的请求method方法将返回HTTP的请求方式。你也可以使用isMethod 方法去验证HTTP的请求方式于指定

规则是否相配:
$method = $request->mothod();

if($request->isMethod(‘post‘)){}

输入预处理&规范化#

默认情况下,Laravel在应用程序的全局中间件堆栈中包含了TrimStrings 和 ConvertEmptyStringsToNull 两个中间件。

这些中间件由App\Http|Kernel 类列在堆栈中。他们会自动处理请求上所有传入的字符串字段,并将空的字符串

字段转变为null值。这样你就不用再担心路由和控制器中数据规范化的问题。

如果你想停用这些功能,可以从应用程序的中间件堆栈中删除这两个中间件,只需在App\Http\Kernel类的

$middleware 属性中移除他们。

获取输入#

获取所有输入数据#

你可以使用all 方法以 数组 形式获取到所有输入数据:

$intput = $request->all();

获取指定输入值#

使用几种简单的方法(不需要特别指定那个HTTP动作),就可以访问Illuminate\Http\Request 实例中所有的用户输入,

也就是说无论是什么样的HTTP动作,input方法都可以被用来获取用户输入数据:

$name = $request->input(‘name‘);

你可以给input 方法的第二个参数传入一个默认值。如果请求的输入值不存在请求上,就返回默认值:

$name = $request->input(‘name‘,‘Sally‘);

如果传输表单数据中包含[数组]形式的数据,那么可以使用[点]语法来获取数组:

$name = $request->input(‘prodects.0.name‘);

$names = $request->input(‘products.*.name‘);

从查询字符串获取输入#

使用input 方法可以从整个请求中获取输入数据(包括查询字符串),而 query  方法可以只从查询字符串中获取输入数据

$name = $request->query(‘name‘);

如果请求的查询字符串收不存在,则将返回这个方法的第二个参数:

$name = $request->query(‘name‘,‘Helen‘);

你可以不提供参数调用query方法来以关联数组的行还是检索所有查询字符串值:

$query = $request->query();

通过动态属性获取输入#

你也可以通过Illuminate\Http\Request 实例的动态属性来获取用户输入。例如,如果你应用的表单中包含name字段,

那么可以向这样访问该字段的值:

$name = $request->name;

Laravel 在处理动态属性的优先级是,先在请求的数据中查找,如果没有,再到路由参数汇总查找。

获取JSON输入信息#

如果发送到应用程序的请求数据是json,只要请求的Content-Type 标头正确设置为 application/json 就可以通过Input 方法

访问JSON数据,你甚至可以使用[点]语法来读取json数组:
$name = $request->input(‘user.name‘);

获取部分输入数据#

如果你需要获取输入数据的子集,则可以用only和except 方法,这两个方法都接收 数组或 动态列表作为参数

$input = $request->only([‘username‘,‘password‘]);

$input = $request->only(‘username‘,‘password‘);

$input= $request->except([‘credit_card‘]);

$input = $request->except(‘credit_card‘);

only 方法会返回所有你指定的键值对,但不会返回请求汇总不存在的键值对。

确定是否存在输入值#

要判断请求是否存在某个值,可以使用has方法。如果请求汇总存在该值,has方法就会返回true;

if($request->has(‘name‘))

{

}

当提供一个数组作为参数时,has方法将确定是否存在数据中所有给定的值:

if($request->has([‘name‘,‘email‘]))

{

  //

}

如果你想确定请求是否存在值并且不为空,可以使用filled方法;

if($request->filled(‘name‘))

{

  //

}

原文地址:https://www.cnblogs.com/simadongyang/p/8456823.html

时间: 2024-10-02 19:39:18

Laravel 的HTTP请求#的相关文章

laravel判断HTTP请求是否ajax

if(Request->ajax()){ echo "AJAX"; }else{ echo '普通请求':}

laravel中的请求信息和重定向

Request::path(); //获取请求的路径 Request::is('admin/*'); //判断是否符合指定模式 Request::url(); //获取请求的url Request::segment(1); //获取请求URL信息 Request::header("Content-Type"); Request::server('PATH_INFO'); //$_SERVER数组中信息 Request::ajax() //如果是ajax请求则为true Request:

自定义laravel表单请求验证类(FormRequest共用一个rules())

我们可以利用Form Request来封装表单验证代码,从而精简Controller中的代码逻辑,使其专注于业务.而独立出去的表单验证逻辑可以复用到其它请求中,看过几篇文章,大多都是讲怎么创建Request,表面看起来是将逻辑与业务分离了,但是没有做到复用,一个业务就得新建一个Request类实在太累,索性这里我将项目全部的表单验证放在一个Request类里,实现高度可复用,下面是具体实现. 首先创建Request php artisan make:request CreateUserReque

laravel 返回ajax请求错误信息 第二种

public function login(Request $request) { $info = Validator::make($request->all(), [ 'username' => 'required', 'password' => 'required', ],[ 'username.required' => '用户名必须填写', 'password.required' => '密码必须填写', ]); if ($info->fails()) { //返

《learning laravel》翻译第三章-----搭建我们第一个网站

重要: 这是一个稳定的版本. 让我们知道你的喜好. 我们将会修改bug和错误,并且定期更新所有章节. 第二章: 搭建我们第一个网站 既然我们知道如何安装Laravel了, 那现在就开始通过我们自己的方式来搭建我们第一个基于Laravel的网站吧. 在本章中,通过搭建Laravel应用程序你将会很方便得学习Laravel的结构,路由,控制器,模板,Artisan命令,Elixir API和很多基础特性. 剖析Laravel结构 假设你将Laravel安装在 ~/Code/Laravel目录.跳转到

Laravel框架学习(四)

一. composer的安装: 1.Composer是什么? 是 PHP 用来管理依赖(dependency)关系的工具. 你可以在自己的项目中声明所依赖的外部工具库(libraries), Composer 会帮你安装这些依赖的库文件. 2.网址:https://getcomposer.org 下载:https://getcomposer.org/download/ 中国全量镜像:http://pkg.phpcomposer.com/ 启用本镜像服务命令: composer config -g

laravel框架容器管理的一些要点

本文面向php语言的laravel框架的用户,介绍一些laravel框架里面容器管理方面的使用要点.文章很长,但是内容应该很有用,希望有需要的朋友能看到.php经验有限,不到位的地方,欢迎帮忙指正. 1. laravel容器基本认识 laravel框架是有一个容器框架,框架应用程序的实例就是一个超大的容器,这个实例在bootstrap/app.php内进行初始化: 这个文件在每一次请求到达laravel框架都会执行,所创建的$app即是laravel框架的应用程序实例,它在整个请求生命周期都是唯

[php]laravel框架容器管理的一些要点

本文面向php语言的laravel框架的用户,介绍一些laravel框架里面容器管理方面的使用要点.文章很长,但是内容应该很有用,希望有需要的朋友能看到.php经验有限,不到位的地方,欢迎帮忙指正. 1. laravel容器基本认识 laravel框架是有一个容器框架,框架应用程序的实例就是一个超大的容器,这个实例在bootstrap/app.php内进行初始化: 这个文件在每一次请求到达laravel框架都会执行,所创建的$app即是laravel框架的应用程序实例,它在整个请求生命周期都是唯

laravel框架容器管理的一些要点(转)

本文面向php语言的laravel框架的用户,介绍一些laravel框架里面容器管理方面的使用要点.文章很长,但是内容应该很有用,希望有需要的朋友能看到.php经验有限,不到位的地方,欢迎帮忙指正. 1. laravel容器基本认识 laravel框架是有一个容器框架,框架应用程序的实例就是一个超大的容器,这个实例在bootstrap/app.php内进行初始化: 这个文件在每一次请求到达laravel框架都会执行,所创建的$app即是laravel框架的应用程序实例,它在整个请求生命周期都是唯