位置: 编程技术 - 正文

php集成动态口令认证(php动态语言)

编辑:rootadmin

推荐整理分享php集成动态口令认证(php动态语言),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:php动态函数,php动态函数,php动态语言,php集成动态口令是什么,php动态语言,php集成动态口令怎么用,php集成动态口令怎么用,php集成动态口令怎么用,内容如对您有帮助,希望把文章链接给更多的朋友!

大多数系统目前均使用的静态密码进行身份认证登录,但由于静态密码容易被窃取,其安全性无法满足安全要求。

动态口令采用一次一密、用过密码作废的方式防止了密码被窃取带来的安全问题。 动态口令分为HOTP(基于事件计数的动态口令,RFC)、TOTP(基于时间计数的动态口令,RFC)、OCRA(挑战应答式动态口令,RFC)等方式。

本文介绍了集成TOTP方式的动态口令认证的方案,PHP框架采用Thinkphp3.2.3,动态口令生成器使用的是google authtication。

1、为Thinkphp框架添加oath算法类

oath算法封装类oath.php代码如下:

由于google的动态口令算法中种子密钥使用了base编码,因此需要base算法,base.php内容如下:

将这两个文件放到Thinkphp框架的ThinkPHPLibraryVendoroath目录下,oath目录是自己创建的。

2、添加数据库字段

用户表添加如下字段: auth_type(0-静态密码,1-动态口令) seed(种子密钥) temp_seed(临时种子密钥) last_logintime(上次登录成功时间) last_otp(上次使用密码) 其中auth_type是为了标明用户使用的哪种认证方式,seed为用户的种子密钥,temp_seed为用户未开通前临时保存的一个种子密钥,如果用户开通动态口令认证成功,该字段内容会填到seed字段。last_logintime和last_otp为上次认证成功的时间和动态口令,用于避免用户同一个口令重复使用。

3、代码集成

php集成动态口令认证(php动态语言)

1)、开通动态口令

在原有系统的修改密码页面,加上认证方式的选择,例如:

如果用户选择动态口令方式,则会生成一张二维码显示在页面,用于用户开通动态口令。为了兼容google authtication,其二维码格式与谷歌一样。生成二维码的方法见我的另一篇《Thinkphp3.2.3整合phpqrcode生成带logo的二维码》 。 生成密钥二维码代码如下:

random是生成随机字符串函数。$rand=str_replace('=','',$rand)这句代码是因为谷歌手机令牌中base解码算法并没有填充的‘='号。

验证用户动态口令的代码如下:

2)、动态口令登录

用户动态口令登录验证的代码:

从数据库读取auth_type,seed,last_otp字段。

4、测试验证

下载google authtication,使用静态密码登录系统,进入修改密码页面。 打开google authtication,扫描二维码,会显示动态口令。

保存内容,开通动态口令成功! 然后你就可以用高大上的动态口令登录系统了!

标签: php动态语言

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

上一篇:微信随机生成红包金额算法php版(微信随机红包表情包怎么弄)

下一篇:微信红包随机生成算法php版(微信红包的随机性)

  • 旧机器设备出口
  • 土地税和房产税缴纳时间
  • 增加固定资产原值账务处理
  • 物业费免交条件
  • 处置固定资产简易征收
  • 无形资产界定标准
  • 核定征收可以享受小微企业税收优惠吗
  • 公司往来款现金流量表
  • 跨年的预付账款如何冲销
  • 收资料费怎么入账科目
  • 合并报表盈余公积怎么提
  • 福利费税前扣除标准2023
  • 个人所得税承租承包经营所得
  • 增值税税率如何计算
  • 应交税费未交增值税明细账
  • 苹果电脑快捷键删除
  • windows10如何设置密码
  • 小规模纳税人可以开增值税专用发票吗
  • xp系统鼠标右键不能用怎么办
  • mac的日历
  • php循环结构有哪几种语句
  • 网页提示摄像头未授权
  • 房产公司财务工作内容
  • PHP:bzcompress()的用法_Bzip2函数
  • php b/s
  • hpdskflt.sys
  • 电脑fs0是什么
  • .hpp是什么文件
  • 委托代销商品发票是谁开给客户
  • 现金流方法
  • php删除数组中重复的元素
  • 免抵退税帐务处理
  • 企业所得税年报截止日期2023
  • 帮别人开增值税专用发票
  • 对公贷款利息支付
  • 图像识别算法汇总表
  • Github ChatGPT-Web:了解最新AI技术的前沿应用!
  • php php
  • 金融企业贷款损失税前扣除
  • 公允价值变动损益借贷方向
  • 发票 技术服务
  • 微擎框架是开源的吗
  • mysql数据类型怎么判断
  • 海关缴款书能重开吗
  • 股权激励如何做会计分录
  • ibm.data.db2
  • 深入浅出embedding pdf
  • 固定资产清理账户借方
  • 资本公积和盈余公积是什么意思
  • 年应税销售额是指纳税人在连续不超过12个月或四个季度
  • 研发支出费用化对财务报表的影响
  • 销售商品成本核算
  • 新注册企业实收资本没到账怎么处理
  • 投资收益的账务怎么处理
  • 印花税滞纳金怎么处理
  • 装饰公司购买的安装服务怎么入账
  • 工程施工会计科目及账务处理
  • 其它流动资产为负数原因
  • 电子版银行回单
  • 利润分配的借方表示增加还是减少
  • sql中将数据放到另一个表中
  • sql2005 create file遇到操作系统错误5拒绝访问 错误1802
  • storm run off
  • win7修改sid
  • win10raw预览
  • xp系统怎么卸载程序
  • win7自带桌面时钟吗
  • win10的蓝屏界面
  • linuxone
  • opengl
  • node.js基础入门
  • div遮罩层整个页面
  • javascript怎么样
  • 内蒙古国家税务
  • 个体户注销税盘需要公章吗
  • 贸易公司税收政策
  • 企业税务代码是什么号
  • 虚假新闻造成的真实伤害
  • 内蒙古国地税网上办税服务厅
  • 国外工资个人所得税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设