当前位置: 首页 > news >正文

OTP防重放攻击

OTP本意是一次性口令,比如邮箱验证码,短信验证码,或者根据totp或者hotp生成的默认30秒一变的6位数字。
不过开发者要注意,必须要在验证成功后失效那个验证码,不然就会导致重放攻击。
对于邮箱验证码,服务器可将邮箱和验证码存入json数组中或redis中,验证时查找匹配,成功则删除该项,一般还应配置失效时间。
对于手机验证码,服务器要将手机号和验证码存入json数组中或redis中,验证时查找匹配,成功则删除该项,一般还应配置失效时间。
对于动态口令,则要采用另外的方式:
先准备一个历史成功json数组,每项是一条json,包含用户id,token,验证时刻+禁止重复的时长
每验证成功一条用户和动态口令,则查数据是否有相同id,相同token并且验证时间还在禁止时间段内,如果查到,则认定为重放攻击,记录日志,验证不通过
如果没有查到,那么如果该用户历史列表为空,则添加json记录,否则更新替换记录的token和验证时刻+禁止重复时长。
注意一般动态口令验证会有一个允许的窗口数,以平衡用户时间和服务器时间的差异,这些前后窗口内的token值在当前验证仍然是可以通过的,所以禁止重复时长至少要覆盖之后的窗口时长。如果token时长是30秒,窗口是2,那么禁止重复时长应该设置为90秒。
如果用户数量大,嫌内存空间占用多,可以考虑每次计算时删除已经过期的条目,或者使用redis,在添加记录时定义失效时间。

...
var loginfaillist=[];
var userotpsucclist=[];
...if (tokenValidates) {let histmatch=userotpsucclist.find(item=>((item.userid==matchuser.uid.toLowerCase())&&(item.token==obj.token)&&(item.invalid>now)))if (histmatch!=undefined) {addfail(now,clientip);logger.error("涉嫌重放攻击 "+matchuser.uid);return res.json({ "msg":"涉嫌重放攻击"});}histmatch=userotpsucclist.find(item=>(item.userid==matchuser.uid.toLowerCase()))if (histmatch==undefined) userotpsucclist.push({"userid":matchuser.uid.toLowerCase(),"token":"obj.token","invalid":now+200000})else { histmatch.token=obj.token; histmatch.invalid=now+200000; }loginfaillist=loginfaillist.filter(itm=>(itm.ip!=req.ip));logger.info("认证通过 "+matchuser.username+" "+clientip);res.json({"msg":"succ","userid":matchuser.uid.toLowerCase(),"username":matchuser.username});}
http://www.lryc.cn/news/398774.html

相关文章:

  • Oracle数据库加密与安全
  • 【YOLO格式的数据标签,目标检测】
  • Memcached内存碎片清理术:优化缓存性能的策略
  • 禁止使用存储过程
  • Flink异常:org/apache/hadoop/hive/ql/parse/SemanticException
  • Java:构造函数与对象
  • Leetcode(经典题)day1
  • k8s record 20240710 监控
  • pdf工具
  • 百度文心4.0 Turbo开放,领跑国内AI大模型赛道!
  • Vue3 defineProps的使用
  • 面向对象进阶基础练习
  • iPhone删除所有照片的高效三部曲
  • OceanBase 配置项系统变量实现及应用详解(2):系统变量的定义及使用场景
  • 本地部署,去除动漫图像背景Anime Remove Background
  • wireshark与tcpdump使用
  • 【密码学】密码学中的四种攻击方式和两种攻击手段
  • 网络层的角色与重要性:互联网通信的关键
  • Transformer模型:WordEmbedding实现
  • 如何压缩pdf文件大小,怎么压缩pdf文件大小
  • Spring Boot集成Atomix快速入门Demo
  • Go语言map并发安全,互斥锁和读写锁谁更优?
  • Java多线程性能调优
  • MacOS 通过Docker安装宝塔面板搭建PHP开发环境
  • Unity发布webgl之后修改StreamingAssets 内的配置文件读取到的还是之前的配置文件的解决方案
  • 离线语音识别芯片在智能生活中的应用
  • 替换:show-overflow-tooltip=“true“ ,使用插槽tooltip,达到内容可复制
  • 219.贪心算法:柠檬水找零(力扣)
  • 通过 Azure OpenAI 服务使用 GPT-35-Turbo and GPT-4(win版)
  • MySQL 面试真题(带答案)