Laravel思维导图之HTTP请求、响应、表单验证

Laravel HTTP 层

今天我来分享 Laravel 中 HTTP 层关于请求、响应与表单验证的知识。

0x00 HTTP 请求

HTTP请求

获取请求

在控制器方法中使用 Illuminate\Http\Request 类型提示,
可以以依赖注入方式来获取当前 HTTP 请求的实例。

将路由参数置于其他依赖之后可以传入路由参数。

Request 提供了内置方法来便捷地做请求相关处理。

  • path 方法返回请求路径信息。

  • is 方法验证收到的请求路径与指定规则是否匹配。

  • url 返回不带有查询字符串的 URL。

  • fullUrl 返回包含查询字符串的完整 URL。

  • method 方法返回 HTTP 请求方式。

  • isMethod 方法验证 HTTP 请求方式与指定规则是否匹配。

输入数据的预处理与规范化

在 Laravel 的全局中间件中默认包含了 TrimStringsConvertEmptyStringsToNull 两个中间件。这些中间件被列在 App\Http\Kernel 类中。它们会自动处理所有请求中传入的字符串字段,比如将空的字符串字段转变成 null 值。想停用这些功能,则需要在 App\Http\Kernel 类的 $middleware 属性中移除这些中间件。

获取输入数据

Laravel 支持从 Request 中获取常规数据、旧输入数据、cookies。

获取常规数据的方法有:

  • 使用 all 方法以 数组 形式获取到所有输入数据。

  • input 方法获取指定输入值。

  • 通过动态属性获取输入数据。

  • 通过 json 方法获取 JSON 输入信息。

  • 通过 only/except 方法获取部分输入数据。

  • 通过 has 方法确定是否有输入值。

对于旧数据,Laravel 允许你将本次的输入数据保留到下一次请求发送前。
这个特性在表单验证错误后重新填写表单相当有用。

获取输入数据

文件资源

获取上传文件的相关方法:

  • file 方法获取上传的文件。

  • hasFile 方法确认上传的文件是否存在。

  • isValid 方法验证上传的文件是否有效。

UploadedFile 这个类也包含了访问文件完整路径和扩展的方法。

  • path 方法获取路径。

  • extension 方法获取扩展名。

此外,store 方法支持上传文件储存到本地磁盘或者云存储上。

0x01 HTTP 响应

HTTP响应

所有路由和控制器都会返回一个响应并返回给用户的浏览器。

创建响应

Laravel 支持的 HTTP 响应类型包括字符串、数组、对象、附件头信息、附加 Cookie 等。

创建响应

重定向

重定向响应是 Illuminate\Http\RedirectResponse 类的实例,
并且包含用户需要重定向至另一个 URL 所需的头信息。

Laravel 支持:

  • 通过全局 redirect 辅助函数实现重定向。

  • 通过 back 辅助函数实现重定向至上级页面。

  • 重定向至命名路由,并根据需要携带普通或 Eloquent 模型参数。

  • 通过 action 方法传递控制器和行为名称作为参数来实现重定向至控制器行为。

  • 重定向至一个新的 URL 的同时通常会 附加 Session 闪存数据。

重定向

其他响应

使用全局辅助函数 response 可以轻松的生成其他类型的响应实例。

其他响应

响应宏

自定义可以在很多路由和控制器重复使用的响应,可以使用 Response Facade 实现的 macro 方法。

0x02 表单验证机制详解

Laravel 提供了多种不同的验证方法来对应用程序传入的数据进行验证。默认情况下,Laravel 的基类控制器使用 ValidatesRequests Trait,它提供了方便的方法使用各种强大的验证规则来验证传入的 HTTP 请求数据。

表单验证

快速上手实例

表单验证实例

重点在于在控制器的方法中,添加验证逻辑。

表单请求验证

这部分与上面实例的差别在于为了满足更复杂的验证情境,我们需要创建一个表单请求。表单请求是一个自定义的请求类,里面包含着验证逻辑。想要运行验证规则,在控制器方法中利用类型提示传入请求。

表单请求验证

在自定义的表单请求类中可以实现:

  • 通过 rules 方法添加验证规则。

  • 通过 withValidator 方法在表单请求以后添加钩子。

  • 通过 authorize 方法授权表单请求。

  • 重写 AppHttpRequestsRequest 中的
    formatErrors 方法来自定义错误格式。

  • 重写 messages 方法自定义错误消息。

手动创建验证请求

之前的内容是直接使用 ValidatesRequests Trait 的 validate 方法来实现表单验证。此外,还可以手动创建一个 validator 实例并通过 Validator::make 方法在 Facade 生成一个新的 validator 实例来实现表单验证。

手动创建验证请求

处理错误消息

调用 Validator 实例的 errors 方法,会得到一个 Illuminate\Support\MessageBag 的实例,可以对 MessageBag 进行各种处理,以满足具体的需求。

处理错误消息

常用的错误信息相关方法:

  • 通过 first 方法查看特定字段的第一个错误消息。

  • 通过 get 方法查看特定字段的所有错误消息。

  • 通过 all 方法查看所有字段的所有错误消息。

  • 通过 has 方法判断特定字段是否含有错误消息。

自定义错误消息则主要通过传递三个参数到 Validator::make 方法来实现。

内置可用的验证规则

Laravel 内置了大量可用的验证规则。如下图:

可用的验证规则

具体用法可以查看文档:http://d.laravel-china.org/docs/5.4/validation#available-validation-rules

按条件添加规则

Laravel 还可以实现灵活的根据条件添加规则,如当字段存在时才进行验证,以及更多复杂的自定义验证规则。

按条件添加规则

验证数组

对于请求中的数组参数,可以使用型号 * 字符获取所有数组中的项。

验证数组

自定义规则

除了 Laravel 内置的验证规则外,还可以根据需要自定义规则。在 服务提供者 中使用 Validator Facade 中的 extend 方法来注册自定义的验证规则。

自定义规则

0x03 下一步

到这篇为止,我完成了 Laravel 入门指南核心概念、HTTP 层的路由、中间件、控制器、请求、响应、表单验证的学习和整理。这几个部分已经可以让你实现简单的面向前端的接口。

接下来我将对数据库及 ORM 部分进行学习和整理。绝大多数应用的数据都存储在数据库中,服务端的功能围绕着数据库中存储的数据展开,从而构建了强大的应用。

0x04 写在最后

对于知识的学习,整理是非常关键的一环,有助于加深理解。

对于 Laravel 的学习我将持续地以思维导图的方式整理输出,并首发在微信公众号 up2048 上分享给需要的读者。

由于思维导图在导出成图片的过程中会变得模糊,为了方便读者,我也提供了思维导图源文件的下载。读者可根据需要,关注微信公众号:up2048,并回复“脑图”来免费获取

- EOF -

推荐阅读

1.2k 声望
89 粉丝
0 条评论
推荐阅读
入行 10 年总结,作为开发必须知道的 Maven 实用技巧
Maven 是基于项目对象模型(POM project object model),可以通过一小段描述信息(配置)来管理项目的构建,报告和文档的软件项目管理工具,简单的说就是用来管理项目所需要的依赖且管理项目构建的工具。

fatfoo12阅读 5.9k

初学后端,如何做好表结构设计?
这篇文章介绍了设计数据库表结构应该考虑的4个方面,还有优雅设计的6个原则,举了一个例子分享了我的设计思路,为了提高性能我们也要从多方面考虑缓存问题。

王中阳Go4阅读 1.8k评论 2

封面图
一分钟搞明白!快速掌握 Go WebAssembly
最近因为各种奇怪的原因,更多的接触到了 WebAssembly。虽然之前很多博客也翻过写过各种文章,但总感觉欠些味道。于是今天梳理了一版,和大家一起展开学习。

煎鱼4阅读 2.2k

Laravel入门及实践,快速上手ThinkSNS+二次开发
【摘要】自从ThinkSNS+不使用ThinkPHP框架而使用Laravel框架之后,很多人都说技术门槛抬高了,其实你与TS+的距离仅仅只是学习一个新框架而已,所以,我们今天来说说Laravel的入门。

ThinkSNS1阅读 2.5k

我让chatGPT用PHP写一个MVC框架,不仅写出来,还能跑!
没想到写出来的框架确实挺简单的,但是又没觉得哪里不对,于是我尝试把这个框架放到服务器试试能不能跑起来,最后还真的可以跑起来,为了让大家能够看到这个框架的演示,我直接爬一个热搜,然后便于展示数据。

TANKING1阅读 1.7k

封面图
开发一个全网搜索引擎的大致流程
由于对搜索引擎技术很感兴趣,便开始尝试开发一个搜索引擎。在参考了网上有限的资料后,加上自己钻研,最终开发出了一个小型的全网搜索引擎,底部有项目地址和搜索测试图片。

会飞的鸟1阅读 5.7k评论 1

快速上手 Go CGO,掌握在 Go 里写 C!
大家好,我是煎鱼。最近因为各种奇怪的原因,接触到了 Go 特色之一 CGO。这方面的相关内容也相对少一些,给大家抛砖引玉。毕竟很多跨语言调用,还是会依赖 CGO 这个特性。希望大家在真正要用时有个前置知识垫肚子...

煎鱼1阅读 1.4k

1.2k 声望
89 粉丝
宣传栏