[ Laravel 5.6 文档 ] 安全系列 —— 重置密码
http://laravelacademy.org/post/8929.html
简介
想要快速实现该功能?只需要在新安装的 Laravel 应用下运行
php artisan make:auth
(如果你已经执行过此命令,可忽略),然后在浏览器中访问http://your-app.test/register
或者其他分配给应用的 URL,该命令会生成用户登录注册所需要的所有东西,包括密码重置!
大多数 Web 应用都提供了为用户重置密码的功能,Laravel 也不例外,Laravel 提供了用于发送密码重置链接及实现密码重置逻辑的便捷方法,而不需要你在每个应用中自己重复实现。
注:在使用 Laravel 提供的密码重置功能之前,
User
模型必须使用了Illuminate\Notifications\Notifiable
trait。
数据库相关
开始之前,先验证 App\User
模型实现了 Illuminate\Contracts\Auth\CanResetPassword
契约。当然,Laravel 自带的 App\User
模型已经实现了该接口,并使用 Illuminate\Auth\Passwords\CanResetPassword
trait 来包含实现该接口需要的方法。
生成重置令牌表迁移
接下来,用来存储密码重置令牌的表必须被创建,Laravel 已经自带了这张表的迁移,就存放在 database/migrations
目录。所以,你所要做的仅仅是运行迁移:
php artisan migrate
这张表就是 password_resets
:

路由
Laravel 自带了 Auth\ForgotPasswordController
和 Auth\ResetPasswordController
控制器(这两个控制器类会通过 php artisan make:auth
命令自动生成),分别用于发送密码重置链接邮件和重置用户密码功能。重置密码所需的路由都已经通过 make:auth
命令自动生成了:
php artisan make:auth
对应路由定义在 Illuminate\Routing\Router
的 auth
方法中:

视图
和路由一样,重置密码所需的视图文件也通过 make:auth
命令一并生成了,这些视图文件位于resources/views/auth/passwords
目录下,你可以按照所需对生成的文件进行相应修改。
重置密码
定义好重置用户密码路由和视图后,只需要在浏览器中通过 /password/reset
访问这个入口路由。框架自带的 ForgotPasswordController
已经包含了发送密码重置链接邮件的逻辑, ResetPasswordController
包含了重置用户密码的逻辑:

输入注册邮箱,点击发送密码重置链接,就会发送密码重置链接到该邮箱:
打开邮箱会收到这样一封重置密码邮件:

点击重置密码按钮,即可进入重置密码页面:

填写表单提交之后即可重置密码。
密码被重置后,用户将会自动登录到应用并重定向到 /home
。你可以通过定义 ResetPasswordController
的 redirectTo
属性来自定义密码重置成功后的跳转链接:
protected $redirectTo = '/dashboard';
注:默认情况下,密码重置令牌一小时内有效,你可以通过修改
config/auth.php
文件中的选项expire
来改变有效时间。
自定义
自定义认证 Guard
在配置文件 auth.php
中,可以配置多个“guards”,以便用于实现基于多用户表的独立认证,你可以通过重写内置的 ResetPasswordController
控制器上的 guard
方法来使用你所选择的 guard,该方法将会返回一个 guard 实例:
use Illuminate\Support\Facades\Auth; protected function guard()
{
return Auth::guard('guard-name');
}
自定义密码 broker
在配置文件 auth.php
中,可以配置多个密码,以便用于重置多个用户表的密码 broker,同样,可以通过重写自带的 ForgotPasswordController
和 ResetPasswordController
控制器中的 broker
方法来使用你所选择的 broker:
use Illuminate\Support\Facades\Password; /**
* 获取密码重置期间所使用的broker.
*
* @return PasswordBroker
* @translator laravelacademy.org
*/
protected function broker()
{
return Password::broker('name');
}
自定义密码重置邮件
你可以很方便地编辑发送密码重置链接给用户的通知类实现自定义密码重置邮件,要实现这一功能,需要重写 User
模型上的 sendPasswordResetNotification
方法,在这个方法中,可以使用任何你所喜欢的通知类发送通知,该方法接收的第一个参数是密码重置 $token
:
/**
* 发送密码重置通知.
*
* @param string $token
* @return void
*/
public function sendPasswordResetNotification($token)
{
$this->notify(new ResetPasswordNotification($token));
}
http://laravelacademy.org/post/8929.html
[ Laravel 5.6 文档 ] 安全系列 —— 重置密码的更多相关文章
- [ Laravel 5.6 文档 ] 进阶系列 —— 任务调度
简介 Cron 是 UNIX.SOLARIS.LINUX 下的一个十分有用的工具,通过 Cron 脚本能使计划任务定期地在系统后台自动运行.这种计划任务在 UNIX.SOLARIS.LINUX下术语为 ...
- SharePoint 2010 文档管理系列
前言,这是自己第一次写一个系列的文档,本来想使用SharePoint 2013版本,但是碍于SharePoint 2013对于硬件要求过高,自己的笔记本无法承受,所以退而求其次选择了在SharePoi ...
- JAVA帮助文档全系列 JDK1.5 JDK1.6 JDK1.7 官方中英完整版下载
JAVA帮助文档全系列 JDK1.5 JDK1.6 JDK1.7 官方中英完整版下载JDK(Java Development Kit,Java开发包,Java开发工具)是一个写Java的applet和 ...
- [ Laravel 5.5 文档 ] 处理用户请求 —— HTTP 请求的过滤器:中间件
[ Laravel 5.5 文档 ] 处理用户请求 —— HTTP 请求的过滤器:中间件 http://laravelacademy.org/post/7812.html 简介 中间件为过滤进入应用的 ...
- SharePoint 2010 文档管理系列之准备篇
前言:很早自己就想写一个系列的文章,但是不知道写什么,最近在QQ群里,好多人说在做文档管理,其实文档管理也是SharePoint的一个很不错的功能点,自己想了想,也想多学习点东西,所以写这个主题吧,今 ...
- [ Laravel 5.5 文档 ] 快速入门 —— 目录结构篇
简介 Laravel 默认的目录结构试图为不管是大型应用还是小型应用提供一个良好的起点.当然,你也可以按照自己的喜好重新组织应用的目录结构,因为 Laravel 对于指定类在何处被加载没有任何限制 — ...
- Laravel 5.5 文档 ] 快速入门 —— 安装配置篇
服务器要求 Laravel 框架对PHP版本和扩展有一定要求,不过这些要求 Laravel Homestead 都已经满足了,不过如果你没有使用 Homestead 的话(那真是一件很遗憾的事情),有 ...
- [ Laravel 5.5 文档 ] 底层原理 —— 一次 Laravel 请求的生命周期
Posted on 2018年3月5日 by 学院君 简介 当我们使用现实世界中的任何工具时,如果理解了该工具的工作原理,那么用起来就会得心应手,应用开发也是如此.当你理解了开发工具如何工作,用起 ...
- SharePoint 2010 文档管理系列之文档搜索
前言:如果一个文档库里面有很多文档,成千上万,对我们来说查找就是个麻烦事儿,所以搜索的必要性就体现出来了.下面,我们简单的介绍下,sharepoint搜索配置,并创建一个简单的搜索页面. 一. 配置S ...
随机推荐
- tcpdump的表达式介绍
表达式是一个正则表达式,tcpdump利用它作为过滤报文的条件,如果一个报文满足表 达式的条件,则这个报文将会被捕获.如果没有给出任何条件,则网络上所有的信息包 将会被截获. 在表达式中一般如下几种类 ...
- 洛谷P2835 刻录光盘 [2017年6月计划 强连通分量02]
P2835 刻录光盘 题目描述 在JSOI2005夏令营快要结束的时候,很多营员提出来要把整个夏令营期间的资料刻录成一张光盘给大家,以便大家回去后继续学习.组委会觉得这个主意不错!可是组委会一时没有足 ...
- [C#] 利用方向鍵移動 TextBox Focus
論壇問題 版面上有 100 個 textbox,編號為 1-100,textbox 排列為 1 欄 20 個,共 5 欄,當一開打這個 form 會將在第一欄第一列第一個 textbox 的背景顏色變 ...
- callee和caller属性的区别
在函数内部,有两个特殊的对象:arguments和this .arguments是一个类数组对象,用于存放传入函数中的所有参数. callee是arguments对象的属性,caller是所有函数对象 ...
- Hadoop 无法启动的问题
最近乱搞把本来就快要挂了的hdfs又给弄坏了.问题如下, 应该是节点没有启动. [hadoop@namenode hadoop]$ hadoop dfsadmin -report Configured ...
- 蚁群算法MATLAB解VRP问题
Excel exp12_3_2.xls内容: ANT_VRP函数: function [R_best,L_best,L_ave,Shortest_Route,Shortest_Length]=ANT ...
- iView3.x Anchor(锚点)组件 导航锚点
iView3.x Anchor(锚点)组件 导航锚点 iview 3.x框架中新添了一个Anchor(锚点组件),用这个组件去做页面的分类导航正好合适,但是苦于官方文档太过抽象研究了一整天,才勉强可以 ...
- Leetcode876.Middle of the Linked List链表的中间节点
给定一个带有头结点 head 的非空单链表,返回链表的中间结点. 如果有两个中间结点,则返回第二个中间结点. 示例 1: 输入:[1,2,3,4,5] 输出:此列表中的结点 3 (序列化形式:[3,4 ...
- kubernetes1.5新特性跟踪
Kubernetes发布历史回顾 Kubernetes 1.0 - 2015年7月发布 Kubernetes 1.1 - 2015年11月发布 Kubernetes 1.2 - 2016年3月发布 K ...
- 异步操作async await
async函数的特点: 语义化强 里面的await只能在async函数中使用 await后面的语句可以是promise对象.数字.字符串等 async函数返回的是一个Promsie对象 await语句 ...