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

从一次内部攻防演练说起:我是如何利用CVE-2017-1000028漏洞“捡到”GlassFish管理员密码的

实战复盘GlassFish任意文件读取漏洞的深度利用链那是一个普通的周二下午我正在为客户做内部网络的安全评估。按照惯例我先用Nmap对目标网段进行扫描突然在扫描结果中发现了一台开放4848端口的服务器——这个端口号让我瞬间警觉起来因为4848正是GlassFish应用服务器的默认管理端口。1. 目标识别与初步侦察GlassFish作为一款开源的Java EE应用服务器在企业内部环境中并不罕见。但将管理界面直接暴露在内部网络中往往意味着潜在的安全风险。我决定先对目标进行指纹识别curl -I http://target-ip:4848返回的响应头中清晰地显示了服务器信息Server: GlassFish Server Open Source Edition 4.1.2 X-Powered-By: Servlet/3.1 JSP/2.3这个版本号立即让我联想到CVE-2017-1000028漏洞——一个经典的任意文件读取漏洞。为了确认漏洞存在的可能性我快速查阅了漏洞影响范围漏洞编号影响版本漏洞类型CVE-2017-1000028GlassFish ≤4.1.2任意文件读取2. 漏洞原理深度解析这个漏洞的本质是Java对UTF-8编码的特殊处理机制。正常情况下URL中的路径分隔符应该是正斜杠(/)但Java会错误地将特定编码序列解析为路径遍历字符%c0%af→\uC0AF→/(正斜杠)%c0%ae→\uC0AE→.(点)这种编码转换的深层原因在于Java的UTF-8解码器实现。当遇到%c0%af这样的双字节序列时二进制表示为11000000 10101111去除UTF-8前缀110后得到00000 101111转换为十进制47对应ASCII码中的正斜杠利用这个特性我们可以构造特殊的URL路径实现目录穿越http://target:4848/theme/META-INF/..%c0%af..%c0%af..%c0%afetc/passwd3. 漏洞利用实战过程3.1 初始探测我先尝试读取系统的基础文件确认漏洞存在GET /theme/META-INF/..%c0%af..%c0%af..%c0%af..%c0%af..%c0%afetc/passwd HTTP/1.1 Host: target-ip:4848当看到返回的/etc/passwd文件内容时我知道这个系统确实存在漏洞。但作为安全评估我需要获取更有价值的信息。3.2 关键文件定位GlassFish的管理密码存储在特定位置glassfish/domains/domain1/config/admin-keyfile我构造了如下请求来获取这个关键文件GET /theme/META-INF/..%c0%af..%c0%af..%c0%af..%c0%afdomains/domain1/config/admin-keyfile HTTP/1.1 Host: target-ip:4848返回的文件内容格式如下admin;{SSHA256}DqA5sL7QJ8gV2Np1XwYz9xKbRtHjMlP3OiUvEeWc...3.3 密码破解策略GlassFish使用SSHA256算法存储密码哈希这是一种加盐的SHA-256哈希。我采用了以下步骤进行破解使用hashcat识别哈希类型hashid -m DqA5sL7QJ8gV2Np1XwYz9xKbRtHjMlP3OiUvEeWc...准备破解命令hashcat -m 1410 -a 3 hash.txt ?a?a?a?a?a?a最终在8小时后成功破解出明文密码提示在实际评估中建议使用更强大的字典或组合规则来加速破解过程4. 后渗透与风险扩大获取管理员凭证后登录管理界面(http://target-ip:4848)只是第一步。真正的风险在于后续的攻击链应用部署通过上传恶意WAR包获取Webshell数据访问查看部署的应用配置和数据库连接信息横向移动利用服务器作为跳板访问内部其他系统下表展示了GlassFish管理界面常见的高风险功能功能模块潜在风险安全建议Applications恶意应用部署严格审核部署包Resources数据库凭证泄露加密存储配置Configurations系统设置篡改定期审计配置5. 防御措施与最佳实践基于这次评估经验我总结了以下防护建议版本升级立即升级到GlassFish 4.1.2以上版本网络隔离管理界面不应直接暴露在网络中密码策略强制使用复杂密码并定期更换日志监控密切监控异常文件访问行为对于开发团队我建议在代码层面增加以下防护// 示例安全的路径校验方法 public static boolean isValidPath(String path) { return path.matches(^[a-zA-Z0-9_\\-./]$) !path.contains(..); }这次评估最让我印象深刻的是一个看似简单的文件读取漏洞配合弱密码策略最终可能导致整个系统沦陷。安全防御需要层层设防任何一个环节的疏忽都可能成为攻击者的突破口。

相关文章:

从一次内部攻防演练说起:我是如何利用CVE-2017-1000028漏洞“捡到”GlassFish管理员密码的

实战复盘:GlassFish任意文件读取漏洞的深度利用链 那是一个普通的周二下午,我正在为客户做内部网络的安全评估。按照惯例,我先用Nmap对目标网段进行扫描,突然在扫描结果中发现了一台开放4848端口的服务器——这个端口号让我瞬间警…...

你的MCP4725 DAC输出不准?可能是这3个硬件坑和2个软件误区(附STM32 F4实测排查指南)

MCP4725 DAC精度问题全解析:从硬件设计到软件优化的实战指南 在嵌入式系统开发中,数字模拟转换器(DAC)的精度问题常常让工程师们头疼不已。MCP4725作为一款性价比较高的12位DAC芯片,广泛应用于各种需要精确电压输出的场景。然而,很…...

Python实战:用PyCryptodome构建你的数据安全防线

1. PyCryptodome:Python开发者的加密利器 当你需要为Python应用添加加密功能时,PyCryptodome绝对是个绕不开的名字。这个库的前身是著名的PyCrypto,现在已经成为Python生态中最强大的密码学工具之一。我在多个实际项目中使用过它,…...

96个公共Tracker终极配置指南:让BT下载速度提升300%

96个公共Tracker终极配置指南:让BT下载速度提升300% 【免费下载链接】trackerslist Updated list of public BitTorrent trackers 项目地址: https://gitcode.com/GitHub_Trending/tr/trackerslist 还在为BT下载速度慢而烦恼吗?🤔 今天…...

3步解锁加密音乐:浏览器本地解密完全指南

3步解锁加密音乐:浏览器本地解密完全指南 【免费下载链接】unlock-music 在浏览器中解锁加密的音乐文件。原仓库: 1. https://github.com/unlock-music/unlock-music ;2. https://git.unlock-music.dev/um/web 项目地址: https://gitcode.c…...

用STM32G431玩超级玛丽!CubeMX+HAL库移植NES模拟器保姆级教程(附蓝桥杯板子适配)

用STM32G431玩超级玛丽!CubeMXHAL库移植NES模拟器保姆级教程(附蓝桥杯板子适配) 还记得小时候抱着红白机玩《超级玛丽》的快乐吗?现在,你可以亲手把这份童年回忆"塞进"一块STM32开发板里。本文将带你用STM32…...

RWKV-7 (1.5B World)镜像部署:腾讯云TI-ONE平台GPU容器配置

RWKV-7 (1.5B World)镜像部署:腾讯云TI-ONE平台GPU容器配置 1. 项目概述 RWKV-7 (1.5B World)是一款专为单卡GPU优化的轻量级对话模型,基于RWKV架构开发。这个1.5B参数的模型虽然体积小巧,却具备出色的多语言理解能力,特别适合在…...

协同过滤算法原理与商业化应用实践

1. 协同过滤的商业化应用全景当你在电商平台看到"猜你喜欢"的推荐商品,或者在视频网站发现首页推送的内容恰好符合你的口味,背后很可能就是协同过滤算法在发挥作用。这种技术已经成为现代商业中精准预测用户偏好的核心工具,它不需要…...

避坑指南:为什么ESP32的One-Wire驱动读不了AM2302?手把手教你用MicroPython中断搞定它

ESP32与AM2302的协议兼容性困境:用MicroPython中断方案破解温湿度读取难题 当你在ESP32上尝试用MicroPython的One-Wire驱动读取AM2302温湿度传感器时,大概率会遇到数据读取失败的情况。这不是代码写错了,而是两种协议之间存在微妙的时序差异。…...

如何用NVIDIA Profile Inspector解锁显卡隐藏性能:完整新手教程

如何用NVIDIA Profile Inspector解锁显卡隐藏性能:完整新手教程 【免费下载链接】nvidiaProfileInspector 项目地址: https://gitcode.com/gh_mirrors/nv/nvidiaProfileInspector 你是否觉得NVIDIA显卡的性能还有提升空间?是否想要获得比官方控制…...

GPU加速多智能体强化学习在高频交易中的应用

1. GPU加速多智能体强化学习在高频交易中的技术解析高频交易(HFT)领域正在经历一场由多智能体强化学习(MARL)引发的技术革命。传统量化交易策略往往依赖于静态规则和手工调参,难以适应瞬息万变的市场环境。我们团队基于JAX框架开发的JaxMARL-HFT系统,首次…...

避坑指南:瑞萨FSP中GPT的PWM模式到底怎么选?锯齿波、三角波1/2/3区别全解析

瑞萨FSP中GPT模块PWM模式深度解析:从波形原理到实战选型 在嵌入式电机控制和电源管理领域,PWM信号的精确生成往往是项目成败的关键。瑞萨电子的Flexible Software Package(FSP)为RA系列MCU提供了强大的GPT(General PWM…...

Hugging Face Transformer库实战:从入门到生产部署

1. 理解Hugging Face Transformer库的核心价值第一次接触Hugging Face的Transformer库时,我被它简洁的API设计震撼到了。这个开源库彻底改变了自然语言处理(NLP)领域的研究和应用方式,让开发者能够用几行代码就调用最先进的预训练…...

三菱FX3U PLC编程避坑指南:加减乘除指令用错,小心数据寄存器不够用!

三菱FX3U PLC运算指令实战避坑:寄存器分配的艺术与陷阱 第一次在FX3U上编写配方计算程序时,我遇到了一个诡异的现象——明明乘法运算逻辑正确,最终结果却总是莫名其妙地覆盖了其他变量。经过三天排查才发现,原来是一个32位乘法结果…...

Vue2.0 + ElementUI登录页开发避坑指南:我踩过的5个坑(路由守卫、样式冲突、表单验证)

Vue2.0 ElementUI登录页开发避坑指南:我踩过的5个坑 去年接手公司后台管理系统重构时,我负责的第一个模块就是登录页。本以为照着ElementUI文档复制粘贴就能搞定,结果从路由守卫到样式污染,踩的坑比写的代码还多。今天就把这些&q…...

从桌游到代码:用Python模拟《展翅翱翔》AI对手,手把手教你实现策略算法

从桌游到代码:用Python模拟《展翅翱翔》AI对手,手把手教你实现策略算法 桌游与编程的碰撞总能产生奇妙的火花。当《展翅翱翔》这款以鸟类生态为主题的策略桌游遇上Python,我们不仅能体验游戏的乐趣,还能深入探索AI决策的奥秘。本文…...

如何实现i茅台自动预约:Java Spring Boot实战部署与优化指南

如何实现i茅台自动预约:Java Spring Boot实战部署与优化指南 【免费下载链接】campus-imaotai i茅台app自动预约,每日自动预约,支持docker一键部署(本项目不提供成品,使用的是已淘汰的算法) 项目地址: ht…...

Visual Syslog Server:Windows环境下的3分钟专业日志监控方案

Visual Syslog Server:Windows环境下的3分钟专业日志监控方案 【免费下载链接】visualsyslog Syslog Server for Windows with a graphical user interface 项目地址: https://gitcode.com/gh_mirrors/vi/visualsyslog 在Windows服务器和网络设备管理中&…...

核心代码编程-文档特征提取-100分

题目描述: 一篇文档由多个文本片段组成(这里假定每个片段由小写英文字母组成,不包含其他内容),需要针对该文档的多个片段进行特征提取,提取方法如下1、特征提取处理时首先找出所有片段中都包含的字母&#…...

别再只让ChatGPT写诗了!用这5个真实开发场景,让它成为你的编程副驾

5个ChatGPT实战开发场景:让AI成为你的智能编程副驾 当大多数开发者还在用ChatGPT写诗或生成段子时,前沿技术团队早已将它深度整合进开发工作流。作为一款基于GPT-3.5架构的对话式AI,ChatGPT在代码理解、问题诊断和方案设计方面展现出的能力&a…...

用Silvaco调参实战:如何精准控制NMOS的阈值电压Vt?从工艺注入到器件仿真的完整分析

Silvaco工艺调参实战:NMOS阈值电压Vt的精准控制与多参数协同优化 在半导体器件设计中,NMOS晶体管的阈值电压(Vt)是决定器件开关特性的核心参数。对于工艺工程师而言,如何通过Silvaco仿真平台精确调控Vt值,并理解各工艺参数间的耦合…...

音频变压器核心技术解析:噪声隔离、阻抗匹配与信号平衡转换

引言在专业音频系统、广播设备、会议系统以及Hi-Fi音响中,音频变压器往往是一个不起眼却至关重要的元件。它利用电磁耦合原理传输信号,同时实现输入与输出之间的电气隔离。与普通的电力变压器不同,音频变压器针对20Hz~20kHz的人耳可听频段进行…...

5个步骤掌握Happy Island Designer:从新手到岛屿设计大师的终极指南

5个步骤掌握Happy Island Designer:从新手到岛屿设计大师的终极指南 【免费下载链接】HappyIslandDesigner "Happy Island Designer (Alpha)",是一个在线工具,它允许用户设计和定制自己的岛屿。这个工具是受游戏《动物森友会》(Ani…...

Minecraft光影革命:Photon Shader从入门到精通的完整指南

Minecraft光影革命:Photon Shader从入门到精通的完整指南 【免费下载链接】photon A gameplay-focused shader pack for Minecraft 项目地址: https://gitcode.com/gh_mirrors/photon3/photon 厌倦了Minecraft原版单调的视觉效果?想要将你的方块世…...

Realsense D435i多相机标定后,如何用Kalibr结果文件(camchain.yaml)做实际应用?

Realsense D435i多相机标定结果实战:从camchain.yaml到SLAM落地的完整指南 当你完成Kalibr标定并拿到camchain.yaml文件时,真正的挑战才刚刚开始。这份看似简单的YAML文件里藏着多相机系统的空间关系密码,但90%的用户只停留在"标定完成&…...

PyTorch实现单层神经网络:从原理到实践

1. 从零开始理解单层神经网络 第一次接触神经网络时,我被那些复杂的数学公式吓得不轻。直到有一天,我决定用PyTorch从最简单的单层神经网络开始实践,才发现原来神经网络的核心思想如此直观。单层神经网络(也称为感知机&#xff09…...

RTK定位中的RTCM3.2:GPS、BDS、Galileo多系统MSM电文(1074/1124等)配置与避坑指南

RTK定位中的RTCM3.2:GPS、BDS、Galileo多系统MSM电文配置实战 在无人机航测、自动驾驶高精定位和精准农业机械控制等场景中,工程师们常遇到这样的困境:明明使用了多模GNSS接收机,RTK固定率却始终达不到预期。去年我们在新疆某智慧…...

WinSpy++深度解析:5个实战技巧助你高效调试Windows窗口界面

WinSpy深度解析:5个实战技巧助你高效调试Windows窗口界面 【免费下载链接】winspy WinSpy 项目地址: https://gitcode.com/gh_mirrors/wi/winspy WinSpy是一款专业的Windows窗口探查工具,专为开发者和技术爱好者设计,能够深入分析、调…...

别再硬啃BladeX源码了!从它的starter包结构,我总结了一套企业级微服务技术选型清单

企业级微服务技术选型实战指南:从BladeX starter看架构设计精髓 当技术团队面临微服务架构选型时,往往陷入两难:既要保证技术栈的前瞻性和扩展性,又要确保组件的稳定性和团队上手成本。BladeX框架通过精心设计的starter包结构&…...

Python实现办公自动化的数据可视化与报表生成

引言:在现代办公环境中,数据处理和报表生成是一项重要的任务。然而,手动处理大量数据和生成报表是一项繁琐且容易出错的工作。幸运的是,Python提供了强大的工具和库,可以帮助我们实现办公自动化,从而提高工…...