请求
检索请求路径
//path 方法返回请求的路径信息。因此,如果接收到的请求目标是 http://domain.com/foo/bar,则 path 方法会返回 foo/bar
$uri = $request->path();
//is 方法验证请求的路径是否与给定的模式匹配。使用此方法时,可以将 * 字符作为通配符:
if ($request->is('admin/*')) {
//
}
输入过滤 & 规范化
默认情况下, Laravel 应用程序的全局中间件堆栈中包含了 TrimStrings 和 ConvertEmptyStringsToNull 中间件。它们被放在 App\Http\Kernel 类的堆栈列表中。 这些中间件将自动过滤掉请求中的字符串字段,并将空字符串字段转换为 null。这样一来,你将不用担心路由和控制器的约束规范问题。
如果你想禁用这些行为, 你可以在应用程序中 App\Http\Kernel 类的 $middleware 属性中移除这两个中间件。
// 接受所有存放到数组中
$input = $request->all();
// 自动名称获取,获取多个值传入多个参数
$name = $request->input('name');
//从查询字符串获取输入
$name = $request->query('name');
//如果请求中不存在查询的字符串,则第二个参数将作为默认值返回:
$name = $request->query('name', 'Helen');
//你可以使用不带任何参数的 query 方法来获取所有查询条件的关联数组:
$query = $request->query();
//获取部分输入数据
$input = $request->only(['username', 'password']);
//排除这些数据都获取
$input = $request->except('credit_card');
//判断输入值是否存在
if ($request->has('name')) {
//
}
//如果想要判断一个值在请求中是否存在,并且不为空,需要使用 filled 方法:
if ($request->filled('name')) {
//
}
// 获取上传的文件
$file = $request->file('photo');
//hasFile 方法判断请求中是否存在指定文件
if ($request->hasFile('photo')) {
//
}
//isValid 方法验证上传的文件是否有效
if ($request->file('photo')->isValid()) {
//
}
// 参数接受多值
<?php
test(1,2,3,4,5,6,7);
function test(...$p){
var_dump($p);
}
image.png
响应
//添加响应头
return response($content)
->header('Content-Type', $type)
->header('X-Header-One', 'Header Value')
->header('X-Header-Two', 'Header Value');
//添加 Cookies 到响应
return response($content)
->header('Content-Type', $type)
->cookie('name', 'value', $minutes);
//Cookies & 加密
默认情况下,Laravel 生成的所有 Cookie 都是经过加密和签名,因此不能被客户端修改或读取。 如果你想要应用程序生成的部分 Cookie 不被加密,那么可以使用在 app/Http/Middleware 目录中 App\Http\Middleware\EncryptCookies 中间件的 $except
protected $except = [
'cookie_name',
];
//重定向到命名路由
return redirect()->route('profile', ['id' => 1]);
//重定向到控制器行为
return redirect()->action(
'UserController@profile', ['id' => 1]
);
//重定向到外部域名
return redirect()->away('https://www.google.com');
//文件下载它将作为用户下载文件的文件名。最后,你可以传递 HTTP 头信息数组作为其第三个参数:
return response()->download($pathToFile, $name, $headers);
//流下载有时,你可能希望将给定操作的字符串响应转换为下载响应,而不需要将其写入磁盘。此时可以使用 streamDownload 方法。这个方法接受回调、文件名和可选的头信息数组作为参数
return response()->streamDownload(function () {
echo GitHub::api('repo')
->contents()
->readme('laravel', 'laravel')['contents'];
}, 'laravel-readme.md');
响应宏
//如果你想要定义一个自定义的可以在多个路由和控制器中复用的响应,可以使用 `Response` 门面上的 `macro` 方法。例如,在某个 [服务提供者](https://learnku.com/docs/laravel/6.x/providers) 的 `boot` 方法编写如下代码
<?php
namespace App\Providers;
use Illuminate\Support\ServiceProvider;
use Illuminate\Support\Facades\Response;
class ResponseMacroServiceProvider extends ServiceProvider
{
/**
* 注册应用程序的响应宏
*
* @return void
*/
public function boot()
{
Response::macro('caps', function ($value) {
return Response::make(strtoupper($value));
});
}
}
//macro 方法接受一个名称作为第一个参数,闭包函数作为的第二个参数。响应宏的闭包在 ResponseFactory 实现类或辅助函数 response 中调用宏名称的时候被执行
return response()->caps('foo');
网友评论