[ Laravel 5.3 文档 ] 安全 —— 密码重置

   2016-09-14 0
核心提示:1、简介想要快速实现该功能?只需要在新安装的Laravel应用下运行php artisan make:auth,然后在浏览器中访问http://your-app.dev/register或者其他分配给应用的URL,该命令会生成用户登录注册所需要的所有东西,包括密码重置!大多数 web 应用提供了用户重置

1、简介

想要快速实现该功能?只需要在新安装的Laravel应用下运行 php artisan make:auth ,然后在浏览器中访问 http://your-app.dev/register 或者其他分配给应用的URL,该命令会生成用户登录注册所需要的所有东西,包括密码重置!

大多数 web 应用提供了用户重置密码的功能,Laravel 提供了便利方法用于发送密码重置链接及实现密码重置逻辑,而不需要你在每个应用中重新实现。

注:在使用Laravel提供的密码重置功能之前, User 模型必须使用了 Illuminate\Notifications\Notifiable trait。

2、数据库考量

开始之前,先验证 App\User 模型实现了  Illuminate\Contracts\Auth\CanResetPassword 契约。当然,Laravel 自带的  App\User 模型已经实现了该接口,并使用  Illuminate\Auth\Passwords\CanResetPassword trait来包含实现该接口需要的方法。

生成重置令牌表迁移

接下来,用来存储密码重置令牌的表必须被创建,Laravel 已经自带了这张表的迁移,就存放在 database/migrations 目录。所有,你所要做的仅仅是运行迁移:

php artisan migrate

3、 路由

Laravel 自带了 Auth\ForgotPasswordControllerAuth\ResetPasswordController ,分别用于发送密码重置链接邮件和重置用户密码功能。重置密码所需的路由都已经通过 make:auth 命令自动生成了:

php artisan make:auth

4、 视图

和路由一样,重置密码所需的视图文件也通过 make:auth 命令一并生成了,这些视图文件位于 resources/views/auth/passwords 目录下,你可以按照所需对生成的文件进行相应修改。

5、重置密码后

定义好重置用户密码路由和视图后,只需要在浏览器中通过 /password/reset 访问这个入口路由。框架自带的  PasswordController 已经包含了发送密码重置链接邮件的逻辑, ResetPasswordController 包含了重置用户密码的逻辑 。

密码被重置后,用户将会自动登录到应用并重定向到 /home 。你可以通过定义 ResetPasswordControllerredirectTo 属性来自定义密码重置成功后的跳转链接:

protected $redirectTo = '/dashboard';

注:默认情况下,密码重置令牌一小时内有效,你可以通过修改 config/auth.php 文件中的选项 expire 来改变有效时间。

6、自定义

自定义认证 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,同样,可以通过重写自带的 ForgotPasswordControllerResetPasswordController 控制器中的 broker 方法来使用你所选择的 broker:

use Illuminate\Support\Facades\Password;

/**
 * Get the broker to be used during password reset.
 *
 * @return PasswordBroker
 */
protected function broker()
{
    return Password::broker('name');
}

自定义密码重置邮件

你可以很方便地编辑发送密码重置链接给用户的通知类实现自定义密码重置邮件,要实现这一功能,需要重写 User 模型上的 sendPasswordResetNotification 方法,在这个方法中,可以使用任何你所喜欢的通知类发送通知,该方法接收的第一个参数是密码重置 $token

/**
 * Send the password reset notification.
 *
 * @param  string  $token
 * @return void
 */
public function sendPasswordResetNotification($token)
{
    $this->notify(new ResetPasswordNotification($token));
}
 
标签: Laravel
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • nginx 各类网站设置 (laravel , thinkphp , nod
    基础部分设置[root@centos ~]# vim /opt/nginx/conf/nginx.confuser www www;worker_processes auto;pid logs/nginx.pid;worker_rlimit_nofile 100000;events {use epoll;multi_accept on;worker_connections 65535 ;}http {include mime.types;default_type
    02-09
  • PHP trait 特性在 Laravel 中的使用个人心得
    trait 是在PHP5.4中为了方便代码复用的一种实现方式,但目前我在看的的PHP项目中较少看的有程序员去主动使用这个实现方式,在laravel中有很多 trait 的使用,关于trait 在 laravel 的使用请参看 Laravel 在哪些地方用了 trait?我曾在 Laravel 中大型项目面向
    02-09
  • 让我们用 laravel-mix 为 TypeScript 和 Sass
    介绍前端编译TypeScript、Sass、模板引擎等时经常用到Gulp和webpack。这是我个人的印象,但它们似乎都难以管理,因为它们的描述往往复杂而冗长。我不想积极进行,因为我要担心加载器的顺序并且有很多配置选项,我必须花时间去了解它们。我想推荐那里laravel
  • PHP Laravel软删除的实现方法介绍
    用Laravel 自带的 Eloquent ORM 来实现软删除。首先在数据迁移文件中添加删除时间字段./database/migrations/2014_10_12_000000_create_users_table.php?phpuse Illuminate\Database\Migrations\Migration;use Illuminate\Database\Schema\Blueprint;use Illu
  • Laravel中如何使用PHP的装饰器模式 php laravel
    本文小编为大家详细介绍“Laravel中如何使用PHP的装饰器模式”,内容详细,步骤清晰,细节处理妥当,希望这篇“Laravel中如何使用PHP的装饰器模式”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。装饰器模式定义:它可以帮助您在
    02-08 laravelphp
  • PHP laravel使用自定义邮件类实现发送邮件
    PHP laravel使用自定义邮件类实现发送邮件
    当登录邮箱为腾讯企业邮箱的时候。Phpmailer发送邮件就不好用了,具体哪里不好用,我没真没找到。但是,邮件得发啊,怎么办呢?我这里搞了一个自定义的发送邮件类,腾讯企业邮箱也可用。但是,邮件发送失败,不会返回报错信息,这个可能是有点坑。源码如下:?
  • 详解PHP laravel中的加密与解密函数
    目录一:简介二:配置三:使用加密/解密1:加密2:不使用序列化进行加密3:解密Laravel为我们提供了完整的加密方法及加密模式。我之前一般在加密的时候使用的是我自己写的加密函数,但是这个玩意,有的位置还是不太使用,当然,破解的话,基本上也是不可能的
  • PHP laravel缓存cache机制详解
    目录一、访问多个缓存存储二、从缓存中获取数据1.获取数据并设置默认值2.检查缓存项是否存在3.数值增加/减少4.获取存储5.获取删除三、缓存中存储数据1.获取存储数据2.缓存不存在时存储数据3.永久存储数据四、从缓存中移除数据Laravel中的cache为我们提供了三
  • PHP laravel实现导出PDF功能
    PHP laravel实现导出PDF功能
    目录一、laravel-tcpdf二、tcpdf三、TCPDF解决保存中文文件名的方法补充一、laravel-tcpdf导出PDF文件Laravel框架为我们集成了一个插件tcpdf。下载地址:https://github.com/elibyy/tcpdf-laravel然后使用composer进行安装就可以了。具体安装过程,请查看文末
  • PHP laravel缓存cache机制怎么实现
    今天小编给大家分享一下PHP laravel缓存cache机制怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Laravel中的cache为我们
点击排行