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

解决堡垒机会话频繁断开:使用 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​:若浏览器插件受限,可用桌面自动化工具辅助。

http://www.cnnetsun.cn/news/17772.html

相关文章:

  • 全球创始人IP+AI万人峰会:赋能与精神滋养并重,引领2026增长新范式
  • 基于Web的客户关系管理系统的设计与实现开题报告(1)
  • 三菱FX PLC下载线驱动安装终极指南:快速解决通信连接问题
  • NetAssistant:终极网络调试解决方案的完整指南
  • 013的加密世界权威指南_第一部分
  • 完整指南:5大核心特性带你玩转Font Awesome 7
  • UtilEmpty空值检查工具类
  • 革命性跨平台EPUB阅读器:智能同步让阅读无处不在
  • 【完整源码+数据集+部署教程】动力电池等检测系统源码分享[一条龙教学YOLOV8标注好的数据集一键训练_70+全套改进创新点发刊_Web前端展示]
  • TDK/INVENSENSE/应美盛传感器ICM-42670-P的概述
  • 《公共管理学》2025网课答案
  • 无需复杂配置!在家也能远程操控 Kali 桌面,cpolar这招太实用了
  • 哪吒监控:打造企业级服务器监控体系的5大核心优势
  • 终极指南:5分钟快速部署IoTSharp物联网平台
  • Spring Boot 4.0 + MyBatis-Plus 实战响应式编程的能力实战
  • 2026 等保测评趋势:从被动合规到主动安全的转型路径
  • 微服务架构设计 - 可降级设计
  • 基于SpringBoot的建金粮食供应链管理系统的设计与实现计算机毕业设计项目源码文档
  • 计算机图形学·24 消隐1 深度缓存-扫描线深度缓存-区间扫描线深度缓存
  • 计算机图形学·25 消隐2 区域子分算法-光线投射算法
  • MinerU升级终极指南:避坑技巧与实战解决方案
  • Archery数据库管理平台:5大核心功能深度解析与实战配置指南
  • 学Python有用吗?
  • Onekey终极指南:3分钟学会Steam游戏清单自动下载
  • 程序员:微软的面试流程探讨
  • 爆款!国产开源公众号AI管家ChatWiki全解析
  • 2、Linux 操作系统基础与 Bash 命令行使用指南
  • 网闸厂家排行:安全隔离技术迭代下的选型指南
  • 单北斗变形监测在水库安全中的应用与维护该如何实施?
  • Win11Debloat:终极Windows系统清理优化完整指南