HTML怎么显示速率限制重置时间_HTML X-RateLimit-Reset解析【说明】

需后端在Access-Control-Expose-Headers中暴露X-RateLimit-Reset,前端用Date.parse(response.headers.get('Date'))获取服务端当前时间,再与X-RateLimit-Reset(秒级时间戳×1000)做差计算剩余秒数,避免客户端时钟偏差。怎么把 X-RateLimit-Reset 转成可读时间显示在网页上浏览器拿不到原始响应头里的 X-RateLimit-Reset,除非后端显式允许跨域暴露------这是最常卡住的第一步。实际做法是后端在 Access-Control-Expose-Headers 响应头里加上 X-RateLimit-Reset,否则 JavaScript 的 response.headers.get('X-RateLimit-Reset') 拿到的是 null。前端用 fetch 发请求后,必须检查是否真能读到该 header(不是所有环境都默认放行)X-RateLimit-Reset 值是 Unix 时间戳(秒级),不是毫秒,别直接塞进 new Date() 里转成本地时间时,用 new Date(timestamp * 1000) 才对;错写成 new Date(timestamp) 会得到 1970 年的错误时间为什么 new Date().getTime() - resetTime * 1000 算出来是负数因为 X-RateLimit-Reset 是服务端时间戳,而你本地时间可能快或慢几秒------尤其在用户设备时间不准、或服务端用 NTP 校准过的情况下,差值就不可靠。更稳的做法是:用服务端返回的 Date 响应头(比如 Wed, 01 May 2024 12:34:56 GMT)算出服务端当前时间,再和 X-RateLimit-Reset 做差。这样消除了客户端时钟偏差的影响。立即学习"前端免费学习笔记(深入)";先取 response.headers.get('Date'),用 new Date(dateHeader).getTime() 得到服务端当前毫秒时间再取 reset = parseInt(response.headers.get('X-RateLimit-Reset')) * 1000倒计时剩余秒数 = Math.max(0, Math.round((reset - serverNow) / 1000))X-RateLimit-Reset 在不同 API 中的单位和格式差异绝大多数 REST API(如 GitHub、GitLab、Cloudflare)用的是秒级 Unix 时间戳,但个别内部系统可能返回毫秒,或者干脆是相对秒数(如 300 表示 5 分钟后重置)。不能无脑假设。 幻导航网 发现优质实用网站,开启网络探索之旅!

相关推荐
lbb 小魔仙4 分钟前
告别腾讯会议40分钟限制:用ToDesk协作版开在线会议,免费不限时远程会议新方案
python·langchain·jenkins
六月雨滴5 分钟前
Oracle 数据库内存管理
数据库·oracle
凯瑟琳.奥古斯特8 分钟前
PyTorch动态计算图详解
人工智能·pytorch·python·深度学习
一个数据大开发18 分钟前
企业知识工程的三条路线:Neo4j 知识中台、Agent + Action 与本体原生 Runtime
大数据·python·neo4j
甲方大人请饶命19 分钟前
SSM-基础
java·数据库·spring
Jackyzhe22 分钟前
从零学习Kafka:幂等与事务
数据库·学习·kafka
六月雨滴29 分钟前
Oracle 会话与进程管理
数据库·oracle
没有感情的robot32 分钟前
网页录制方法总结
python
shark-chili32 分钟前
基于claude code的redis慢查询指令复刻实践
数据库·redis·缓存
m0_7381207238 分钟前
ctfshow靶场SSRF部分——基础绕过到协议攻击解题思路与技巧(二)
python·网络协议·tcp/ip·安全·网络安全