位置: 编程技术 - 正文

通过修改Laravel Auth使用salt和password进行认证用户详解(laravel url重写)

编辑:rootadmin

推荐整理分享通过修改Laravel Auth使用salt和password进行认证用户详解(laravel url重写),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:通过修改幻灯片的什么可以改变超链接文字的颜色,通过修改幻灯片的什么可以改变超链接文字的颜色,通过修改母版中文字,通过修改幻灯片的 可以改变整个模板超链接文本的颜色,通过修改下列哪个参数可以,通过修改幻灯片的什么可以改变超链接文字的颜色,通过修改源代码修改网页内容,通过修改注册表修改edge主页,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

本文主要给大家介绍了通过修改Laravel Auth用salt和password进行认证用户的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍:

Laraval自带的用户认证系统Auth非常强大易用,不过在Laravel的用户认证系统中用户注册、登录、找回密码这些模块中用到密码加密和认证算法时使用的都是bcrypt,而很多之前做的项目用户表里都是采用存储salt + password加密字符串的方式来记录用户的密码的,这就给使用Laravel框架来重构之前的项目带来了很大的阻力,不过最近自己通过在网上找资料、看社区论坛、看源码等方式完成了对Laravel Auth的修改,在这里分享出来希望能对其他人有所帮助。 开篇之前需要再说明下如果是新项目应用Laravel框架,那么不需要对Auth进行任何修改,默认的bcrypt加密算法是比salt + password更安全更高效的加密算法。

修改用户注册

首先,在laravel 里启用验证是用的artisan命令

执行完命令后在routes文件(位置:app/Http/routes.php)会多一条静态方法调用

这个Route是Laravel的一个Facade (位于IlluminateSupportFacadesRoute), 调用的auth方法定义在IlluminateRoutingRouter类里, 如下可以看到auth方法里就是定义了一些Auth相关的路由规则

通过路由规则可以看到注册时请求的控制器方法是AuthController的register方法, 该方法定义在IlluminateFoundationAuthRegistersUsers这个traits里,AuthController在类定义里引入了这个traits.

在register方法里首先会对request里的用户输入数据进行验证,你只需要在AuthController的validator方法里定义自己的每个输入字段的验证规则就可以

接着往下看验证通过后,Laravel会掉用AuthController的create方法来生成新用户,然后拿着新用户的数据去登录Auth::guard($this->getGuard())->login($this->create($request->all()));

所以我们要自定义用户注册时生成用户密码的加密方式只需要修改AuthController的create方法即可。

比如:

修改用户登录

修改登录前我们需要先通过路由规则看一下登录请求的具体控制器和方法,在上文提到的auth方法定义里可以看到

验证登录的操作是在AppHttpControllersAuthAuthController类的login方法里。打开AuthController发现Auth相关的方法都是通过性状(traits)引入到类内的,在类内use 要引入的traits,在编译时PHP就会把traits里的代码copy到类中,这是PHP5.5引入的特性具体适用场景和用途这里不细讲。 所以AuthController@login方法实际是定义在IlluminateFoundationAuthAuthenticatesUsers这个traits里的

登录验证的主要操作是在Auth::guard($this->getGuard())->attempt($credentials, $request->has('remember'));这个方法调用中来进行的,Auth::guard($this->getGuard()) 获取到的是IlluminateAuthSessionGuard (具体如何获取的看Auth这个Facade IlluminateAuthAuthManager里的源码)

看一下SessionGuard里attempt 方法是如何实现的:

retrieveByCredentials是用传递进来的字段从数据库中取出用户数据的,validateCredentials是用来验证密码是否正确的实际过程。

这里需要注意的是$this->provider这个provider是一个实现了IlluminateContractsAuthUserProvider类的provider, 我们看到目录IlluminateAuth下面有两个UserProvider的实现,分别为DatabaseUserProvider和EloquentUserProvider, 但是我们验证密码的时候是通过那个来验证的呢,看一下auth的配置文件

这里配置的是driver => eloquent , 那么就是通过EloquentUserProvider的retrieveByCredentials来验证的, 这个EloquentUserProvider 是在SessionGuard实例化时被注入进来的, (具体是怎么通过读取auth配置文件, 实例化相应的provider注入到SessionGuard里的请查阅IlluminateAuthAuthManager 里createSessionDriver方法的源代码)

通过修改Laravel Auth使用salt和password进行认证用户详解(laravel url重写)

接下来我们继续查看EloquentUserProvider中retrieveByCredentials和validateCredentials方法的实现:

上面两个方法retrieveByCredentials用除了密码以外的字段从数据库用户表里取出用户记录,比如用email查询出用户记录,然后validateCredentials方法就是通过$this->haser->check来将输入的密码和哈希的密码进行比较来验证密码是否正确。

好了, 看到这里就很明显了, 我们需要改成自己的密码验证就是自己实现一下validateCredentials就可以了, 修改$this->hasher->check为我们自己的密码验证规则就可以了。

首先我们修改$user->getAuthPassword()把数据库中用户表的salt和password传递到validateCredentials中修改AppUser.php 添加如下代码

然后我们在建立一个自己的UserProvider接口的实现,放到自定义的目录中:

新建app/Foundation/Auth/AdminEloquentUserProvider.php

最后我们修改auth配置文件让Laravel在做Auth验证时使用我们刚定义的Provider,修改config/auth.php:

修改app/Provider/AuthServiceProvider.php

Auth::provider方法是用来注册Provider构造器的,这个构造器是一个Closure,provider方法的具体代码实现在AuthManager文件里

闭包返回了AdminEloquentUserProvider对象供Laravel Auth使用,好了做完这些修改后Laravel的Auth在做用户登录验证的时候采用的就是自定义的salt + password的方式了。

修改重置密码

Laravel 的重置密码的工作流程是:

向需要重置密码的用户的邮箱发送一封带有重置密码链接的邮件,链接中会包含用户的email地址和token。 用户点击邮件中的链接在重置密码页面输入新的密码,Laravel通过验证email和token确认用户就是发起重置密码请求的用户后将新密码更新到用户在数据表的记录里。

第一步需要配置Laravel的email功能,此外还需要在数据库中创建一个新表password_resets来存储用户的email和对应的token

通过重置密码表单的提交地址可以看到,表单把新的密码用post提交给了/password/reset,我们先来看一下auth相关的路由,确定/password/reset对应的控制器方法。

可以看到对应的控制器方法是AppHttpControllersAuthPasswordController类的reset方法,这个方法实际是定义在IlluminateFoundationAuthResetsPasswords 这个traits里,PasswordController引入了这个traits

方法开头先通过validator对输入进行验证,接下来在程序里传递把新密码和一个闭包对象传递给Password::broker($broker)->reset();方法,这个方法定义在IlluminateAuthPasswordsPasswordBroker类里.

在PasswordBroker的reset方法里,程序会先对用户提交的数据做再一次的认证,然后把密码和用户实例传递给传递进来的闭包,在闭包调用里完成了将新密码更新到用户表的操作, 在闭包里程序调用了的PasswrodController类的resetPassword方法

PasswrodController类resetPassword方法的定义

在这个方法里Laravel 用的是bcrypt 加密了密码, 那么要改成我们需要的salt + password的方式,我们在PasswordController类里重写resetPassword方法覆盖掉traits里的该方法就可以了。

结语

到这里对Laravel Auth的自定义就完成了,注册、登录和重置密码都改成了sha1(salt + password)的密码加密方式, 所有自定义代码都是通过定义Laravel相关类的子类和重写方法来完成没有修改Laravel的源码,这样既保持了良好的可扩展性也保证了项目能够自由迁移。

注:使用的Laravel版本为5.2

总结

标签: laravel url重写

本文链接地址:https://www.jiuchutong.com/biancheng/289904.html 转载请保留说明!

上一篇:laravel通过创建自定义artisan make命令来新建类文件详解(laravel添加数据)

下一篇:PHP面向对象中new self()与 new static()的区别浅析(php是面向对象语言吗)

  • 销售清单要装订吗
  • 税务系统重置密码
  • 工会经费应税项怎么算
  • 印花税是当月交当月的吗
  • 事业单位财政拨款取得方式
  • 个人设备投资需要交税吗
  • 非居民税收征管方式包括
  • 存在问题的具体表现和产生问题的原因分析
  • 多缴所得税返还现金流
  • 税控盘抵减增值税需要结转吗
  • 工程项目垃圾清运项目编码
  • 调增应纳税所得额
  • 以前年度固定资产入账错误怎么办?
  • 小规模纳税人如何升级为一般纳税人
  • 小规模纳税人免税怎么做账
  • 怎么判断分红前已提取足够法定公积金?
  • 补提以前年度摊销
  • 长期待摊费用提前清理
  • 先收钱后开票怎么做分录
  • 投资性房地产房产税如何计算
  • 先收到发票后到货分录
  • windows defender隔离区
  • 双系统怎么卸载ubuntu
  • win10怎么恢复被系统删除的文件
  • 一般劳务报酬和其他劳务报酬的区别
  • 高新企业开办费是多少
  • ubuntu16.04lts
  • 如果退货卖家拒绝会把货退回来么
  • 核定征收的企业利润怎么处理
  • 公司试乘试驾车卖掉在增值税哪个模块里开具
  • 年终结算增值税怎么算
  • 办置业公司需要哪些材料
  • 基于中国国情的中国式现代化具有哪些特色
  • nvidia显卡驱动怎么安装
  • 金融商品转让业务包括
  • 长期待摊费用是资产
  • 固定资产处置怎么计算
  • 进口形式发票能证明商品是进口的吗
  • 服务业折旧费怎么计算
  • python中@是什么意思
  • 出口业务的会计处理
  • 电子承兑到期清算方式是线上还是线下
  • 利息应怎么录入收入
  • 食用油交税吗
  • 个人抬头的发票可以入账吗
  • 企业发生的职工福利费支出,不超过工资
  • 公司买卖股票亏损了 要交企业所得税吗
  • 残疾人就业保证金上年工资总额是说上一年度么
  • 进口退货退税
  • 进项税额与库存的关系
  • 本月计提费用,发票下个月到可以吗
  • 煤炭资源税优惠政策
  • 如何冲销应付账款
  • 开出银行转账支票
  • 政府专项扶持资金
  • 建筑劳务公司的会计账务处理
  • 债务重组的方式主要包括哪些
  • mysql密码忘记了怎么找回
  • freebsd12安装
  • vmware虚拟机怎么克隆
  • win7升级win10黑屏
  • win7电脑蓝牙图标怎么弄出来
  • ssgrate.exe - ssgrate是什么进程
  • win单击变双击
  • microsoft/微软
  • number mac
  • fsav32.exe是什么进程 有什么作用 fsav32进程查询
  • grep命令用法
  • win7自带解压缩
  • 炉石传说代码怎么导入
  • Sublime Text + decoda 调试Quick-cocos2d-x 游戏
  • android使用教程
  • js parseint parsefloat
  • 四川国税发票查询验证
  • 进项转出怎么做
  • 小规模纳税人购买车辆可以抵扣税吗
  • 主管税务机关指的是
  • 购买材料如何计入成本
  • 税务税率9个点怎么算
  • 法治税务建设工作思路
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设