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

JavaScript做网页是否过期的处理

通过路由上的参数生成唯一md5和路由上token做验证_md5 token-CSDN博客

前言:基于这篇文章我们做网页是否超时,网页是否过期的处理。打开一个网页允许他在一定时间内可以访问,过了这个时间就不可以访问了,encrypt是h5加密方法,看看上面的文档

解释:其实原理也很简单:就是设置一个过期时间,加到了当前时间上,然后再解析的地方获取一下这个过期时间的值,和当前时间做个比较就行了

var tokenExpireSec = Math.floor(Date.now() / 1000) + 20  // 在当前时间上+30s表示30s之后过期

用到的地方:

var currentSeconds = Math.floor(Date.now() / 1000); // 拿到当前时间

if (currentSeconds > tokenExpireSec) {

    return "网页鉴权超时"

}

设置过期时间:

var webExpireSec = 300; // 网页有效期(秒)var expireSec = Math.floor(Date.now() / 1000) + webExpireSec;var token = encrypt(videoId + timestamp + ui_control + expireSec) + "-" + expireSec;

解析时间是否过期的地方(通过-分割,判断当前时间是否大于设置的过期时间,大于则网页过期)

let token = new URLSearchParams(location.search).get('token')let tokenArr = token.split("-");
if (tokenArr.length >= 2) {token = tokenArr[0];// 判断是否过期let currentSeconds = Math.floor(Date.now() / 1000);let tokenExpireSec = parseInt(tokenArr[1]);if (currentSeconds > tokenExpireSec) {return "网页鉴权超时"}sysToken = md5(videoId + timestamp + ui_control + tokenArr[1]);
}

备注:也可以用时间来单独做md5加密,不用混杂videoId + timestamp + ui_control这些字段也ok的

其他:

npm引用:

import CryptoJS from "crypto-js";/*** md5* @param {string|Buffer} data* @see https://tool.xuexiareas.com/encryption/md5* @returns {string} 小写16进制*/
const md5 = (data: string) => {return CryptoJS.MD5(data).toString();
}

script引用:crypto-js:https://github.com/brix/crypto-js

添加好友备注【进阶学习】拉你进技术交流群

http://www.lryc.cn/news/411766.html

相关文章:

  • python coding时遇到的问题
  • 攻防演练号角吹响,聚铭铭察高级威胁检测系统助您零失分打赢重保攻坚战
  • 个人量化交易兴起!有什么好用的量化软件推荐?迅投QMT量化平台简介!
  • SQL labs-SQL注入(七,sqlmap对于post传参方式的注入,2)
  • SAM 2: Segment Anything in Images and Videos
  • 软件测试面试,如何自我介绍?
  • 力扣第四十七题——全排列II
  • Springer旗下中科院2区TOP,国人优势大!
  • 【C++】C++入门知识详解(下)
  • 分压电阻方式的ADC电压校准
  • 使用Postman测试API短轮询机制:深入指南
  • 明清进士人数数据
  • C# 串口通信(通过serialPort控件发送及接收数据)
  • 数据安全的新盾牌:SQL Server数据库镜像技术详解
  • 【C语言版】数据结构教程(一)绪论(上)
  • 酒后为什么总感觉渴?
  • Docker安装OwnCloud私有云盘对接ceph
  • 创建了Vue项目,需要导入什么插件以及怎么导入
  • abstract 关键字
  • 用Python编写你的网络监控系统详解
  • 操作系统——虚拟内存
  • Zoom视频会议软件使用
  • MVC软件设计模式及QT的MVC架构
  • 使用WSL通过SSH连接并运行图形界面程序
  • 柳湛宇-简历
  • 6-1 从全连接层到卷积
  • 【Android Studio】项目目录结构
  • electron-builder打包vue2项目问题合集
  • 5行代码快速Git配置ssh
  • 气相色谱检测常见问题和实战案例分享-测试狗