位置: 编程技术 - 正文

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版(微信红包的随机性)

  • 小规模纳税人销售额超过500万
  • 制造企业印花税降为50%
  • 资产减值损失纳税调增还是调减
  • 税务申报差额征收 服务减除清单
  • 开办期的所得税年度申报
  • 所得税预缴怎么做分录
  • 内账采购含税怎么转不含税
  • 租赁合同印花税率
  • 租房违约金怎么计算,怎么写
  • 银行收单业务员做什么的
  • 无形资产摊销是谨慎性原则吗
  • 国有企业取得的土地收储款是否要上缴财政
  • 应收账款管理应该从哪些方面进行
  • 公司车辆交强险需要什么手续
  • 不征税收入税收政策
  • 附加税水利行政事业是否取消?
  • 价内税包括
  • 预缴纳税申报怎么报
  • 高新企业减免所得税政策
  • 金融企业贷款损失税前扣除
  • 应收账款收款后怎么做账
  • 取得带息应收票据时,企业应于期末计算票据利息
  • 风险控制措施包括哪5个方面
  • 给供应商垫付运费合法吗
  • php教程 ftp 函数
  • 月末结转营业外支出有余额吗
  • 微软商店 低价区
  • 伊莎贝尔公主
  • 公司为员工缴纳社保的法律规定
  • Realsense D455/435内参标定以及手眼标定
  • 瑞士伯尔尼小镇
  • php实现删除功能
  • 可以抵扣的项目有哪些
  • vue清空form数据再重新赋值
  • 增值税为什么不能在税前扣除
  • 依法无需办理税务登记证
  • 存货盘亏计入什么收入
  • jsoncpp使用
  • 一个人失恋了该怎么安慰她
  • mustn't be allowed
  • sql 附加数据库
  • 差旅费报销时如何处理
  • 金融企业往来支出属于什么科目
  • 查补以前年度税款账务处理
  • 应交税费借方是增加还是减少
  • 外币账户记账方法
  • 离线发票累计金额为0
  • 现金日记账支出写借方还是贷方
  • 为什么实收资本不属于企业资产
  • 网店会计做些什么
  • 客户赔款会计科目
  • 私企需要计提盈余公积吗
  • sql排序分组语句
  • mysql 5.7.12 winx64安装配置方法图文教程
  • mysql单表10亿
  • 建立mysql
  • mysql里删除表里的数据
  • Windows Sever 2016技术预览版3 本月发布
  • windows vista可以换7吗
  • centos7 阿里云 yum
  • 老毛桃U盘装系统综合教程
  • ubuntu下载net-tools
  • sxs.exe病毒
  • win1020h2正式版
  • find按照文件大小查找
  • win7任务管理器怎么调回原来样子
  • win10账户登录闪退
  • win7如何重装系统电脑
  • win7旗舰版系统激活密钥
  • opengl纹理贴图步骤
  • python accdb
  • 网页设计绿色
  • 学javascript的书
  • unity3d物理现象模拟
  • 猫的游戏视频
  • javascript 对象的this指向
  • 福建省国家税务局电子税务局官网入口
  • 深圳献血奖励标准
  • 杭州市电子税务局官网登录
  • 税务网上抄报流程是什么
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设