news 2026/6/15 15:13:26

解决堡垒机会话频繁断开:使用 Tampermonkey 脚本自动保活

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
解决堡垒机会话频繁断开:使用 Tampermonkey 脚本自动保活

🛡️ 解决堡垒机会话频繁断开:使用 Tampermonkey 脚本自动保活

适用场景​:运维、安全审计、远程办公等需要长时间保持 Web 堡垒机(Bastion Host)会话的场景。
问题​:堡垒机因“无操作”在 5~10 分钟内自动登出,严重影响工作效率。
解决方案​:通过浏览器油猴脚本(Tampermonkey)模拟用户活动,实现“静默保活”。


🔧 一、为什么需要保活?

大多数企业级堡垒机(如 JumpServer、阿里云云堡垒机、自研系统等)出于安全考虑,会设置 ​会话空闲超时机制​(例如 5 分钟无操作自动登出)。

但实际工作中,我们可能:

  • 需要长时间查看日志
  • 等待命令执行结果
  • 多窗口协作操作

频繁重新登录不仅打断工作流,还可能丢失上下文。


🛠 二、解决方案:Tampermonkey 模拟用户活动

✅ 优势

  • 无需刷新页面​(避免重新登录)
  • 完全前端实现​,不依赖后端
  • 免费、开源、本地运行
  • 仅作用于指定域名​,安全可控

📝 三、操作步骤

步骤 1:安装 Tampermonkey 插件

  • Chrome / Edge 用户访问:https://www.tampermonkey.net/
  • 点击 “Add to Chrome” 安装
  • 安装后浏览器右上角会出现 🐒 图标

步骤 2:创建保活脚本

  1. 点击 Tampermonkey 图标 → 选择“创建新脚本”
  2. 删除默认内容,粘贴以下代码:
// ==UserScript==// @name Bastion Keep-Alive// @namespace http://tampermonkey.net/// @version 1.0// @description 在堡垒机页面定时模拟用户活动,防止会话超时断开// @author Your Name// @match https://10.99.XX.XX/*// @grant none// ==/UserScript==(function(){'use strict';// 设置保活间隔(建议小于堡垒机超时时间,例如4分钟)constINTERVAL=4*60*1000;// 4分钟functionsimulateActivity(){try{console.log('🛡️ [Keep-Alive] 模拟用户活动 at',newDate().toLocaleTimeString());// 触发 mousemove 事件(多数系统以此判断活跃)document.dispatchEvent(newMouseEvent('mousemove',{view:window,bubbles:true,cancelable:true,clientX:Math.random()*100,clientY:Math.random()*100}));}catch(e){console.warn('⚠️ Keep-Alive 脚本异常:',e.message);}}// 立即执行一次 + 定时循环simulateActivity();setInterval(simulateActivity,INTERVAL);})();

⚠️ ​重要​:请将@match行中的https://10.99.XX.XX/*替换为你实际的堡垒机地址。

  • 如果使用 HTTP,添加// @match http://your-ip/*
  • 如果带端口(如 :8443),写成https://10.99.XX.XX:8443/*
  1. Ctrl+S保存脚本

步骤 3:验证脚本是否生效

  1. 打开你的堡垒机页面(如https://10.99.XX.XX/client/...
  2. F12打开开发者工具 → 切到Console标签
  3. 观察是否每隔 4 分钟出现如下日志:
    🛡️ [Keep-Alive] 模拟用户活动 at 14:30:22
  4. 同时检查 Tampermonkey 图标是否亮起(表示脚本已注入)

✅ 出现日志 → 脚本正常运行!会话将不再因“无操作”而断开。


⚠️ 四、注意事项

  1. 遵守公司安全策略
    自动保活可能违反部分企业的安全规定,请确保你有权限使用。
  2. 不要设置过短间隔
    建议保活间隔为超时时间的 70%80%(如超时 5 分钟,设为 34 分钟)。
    避免高频操作被系统判定为异常行为。
  3. 某些系统需更强交互
    如果mousemove无效,可尝试增加键盘事件:
    document.dispatchEvent(newKeyboardEvent('keydown',{key:'Control'}));
  4. IP 地址变更需更新脚本
    若堡垒机 IP 或端口变化,记得同步修改@match规则。

💡 五、进阶建议

  • 多环境支持​:可添加多个@match行,覆盖测试/生产环境。
  • ​**视觉反馈(调试用)**​:临时加document.body.style.boxShadow = '0 0 10px red'看是否触发。
  • 结合 AutoHotkey​:若浏览器插件受限,可用桌面自动化工具辅助。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 13:08:26

大白话异步vs同步,全双工vs半双工,串行vs并行(新增)

1. 同步 vs 异步(关注“要不要时钟”/“要不要对齐节奏”)同步(Synchronous):📣 “咱俩按节拍一起走”→ 通信双方靠一个共同的时钟信号协调,像军训队列,喊“一二一”,你…

作者头像 李华
网站建设 2026/6/15 13:16:34

基于Web的客户关系管理系统的设计与实现开题报告

郑州工程技术学院2025届毕业设计(论文)开题报告学院:信息工程学院 专业:软件工程 论文(设计)题目基于Web的客户关系管理系统的设计与实现 学生姓名班…

作者头像 李华
网站建设 2026/6/15 13:24:43

一生一芯学习:多道程序 yield-os.c

随着处理器主频的越来越高,每次读写一次磁盘要耗费很多个时钟周期来等待磁盘操作的完成,与其傻傻等待,在这等待的过程中我们可以做更多有意义的事情,如当第一个程序需要等待输入输出的时候,切换到第二个程序来运行&…

作者头像 李华
网站建设 2026/6/15 13:35:51

基于web的乐养系统设计与实现任务书

重庆工商大学派斯学院毕业论文任务书内容模板课题的内容1. 背景研究与需求分析调查和分析当前基于web的乐养系统与健康监护服务的现状与需求。分析用户对于养老服务预约、健康管理记录、费用查询与缴费等方面的具体需求,并给出相应的解决方案。2. 系统设计定义系统的…

作者头像 李华
网站建设 2026/6/15 5:47:26

从富士康到特斯拉:未来工厂的护城河到底是什么?

在过去三十年里,全球制造业的标杆无疑是富士康。它代表了工业3.0时代的巅峰:通过极致的标准化、严苛的成本控制和庞大的规模效应,将“代工”这一商业模式做到了难以逾越的高度。然而,当我们把目光投向特斯拉,看到的不仅…

作者头像 李华
网站建设 2026/6/15 0:56:49

WindowResizer:Windows窗口尺寸控制的终极解决方案

WindowResizer:Windows窗口尺寸控制的终极解决方案 【免费下载链接】WindowResizer 一个可以强制调整应用程序窗口大小的工具 项目地址: https://gitcode.com/gh_mirrors/wi/WindowResizer 还在为无法调节某些应用程序窗口大小而烦恼吗?WindowRes…

作者头像 李华