0

0

实战 | 某OJ渗透测试记录

星夢妙者

星夢妙者

发布时间:2025-08-29 08:33:01

|

337人浏览过

|

来源于php中文网

原创

并没有什么技术含量,纯粹就是玩个黑盒的过程。挺有意思的,所以就写下来了。

起因

群里说,他们那有个 OJ 是用 win­dows

实战 | 某OJ渗透测试记录

当然二话不说上来看看咯。

开整之前大致想出流程,

判断是否容器判断是否出网

第一因为是用 win­dows 所以有点希望,就来验证第二个看看。

bypass

先找个时间长点的题目

实战 | 某OJ渗透测试记录

上去提交代码。能用的有 C/C++/G++/JAVA/C# 以及 PAS­CAL

实战 | 某OJ渗透测试记录

试了一下,C/C++ 没有 win­dows.h,基本的 sys­tem 等函数就直接 re­set 了。

估计有一些防火墙。

运气好,发现 C# 能执行 api???

这下好说了,shell­code 走起。

直接参考这个

提交,运行,之后 cs 上线了

实战 | 某OJ渗透测试记录

但是 10s 一过就被 k 了。

原本是想找个能自动复制的 shell­code,或者是干脆直接 ex­e2shell­code 然后编码到代码里提交上去写出

结果提交代码有长度限制,最多 6kb,只能继续在 shell­code 上整活了。

那么继续,我们换个思路。

我们把自己复制一个,然后用 api 把自己运行不就行了?

经过测试之后,发现,Cre­ateProcess 这个 api 可以用,shellEx­e­cute 这些倒是被 re­set 了。

那么接下来就简单了

实战 | 某OJ渗透测试记录

测试之后发现,只有本体线程上线了。。。复制之后的那个没上线?这就很尴尬。

现在有 3 个猜测

Temp 文件夹没权限CreateProcess 并不能运行本体不是 exe 而是某种动态执行的东西,所以复制本体出去压根不是正确的 PE 文件

总体来说就这三种情况,那么我们该怎么排查呢?

伪黑盒测测

oj 也不是完全黑盒,oj 也是有返回结果的

实战 | 某OJ渗透测试记录

其中我们只需要关注

Judge Status
Exe.Time
,
Exe.Memory
这些就行

前两个我们是可以手动控制结果,后面一个 Mem­ory 是判断我们程序是否正确运行。

那么接下来就简单了。我们可以手动一个选择支 (if),达成某种目标,就给出正确答案,或者超时等等。

我们先判断程序是否复制到了 Temp 文件夹下面,如果复制到了那么就直接 Sleep 到超时。

代码语言:javascript代码运行次数:0运行复制
if (File.Exists("C:\\WINDOWS\\Temp\\asd.exe"))                {                    System.Threading.Thread.Sleep(2000);                    return;                }else{return;}

经过测试之后发现,文件不存在。程序并没有超时,直接 re­turn 了。

继续判断扩展名

代码语言:javascript代码运行次数:0运行复制
string filename = System.IO.Path.GetFileName(szPath); if(Path.GetExtension(fileName)==".exe"){System.Threading.Thread.Sleep(2000);}

发现超时,说明文件确实被编译成 exe 了。

那么既然 temp 目录没有权限,那么我们就直接复制到本地目录不就行了嘛。

经过修改代码之后,提交运行。这次倒是上线了两个。

但是依旧是过了 10s,这两个程序同时掉线了。预测是被 k 了。

这就很奇怪了。

难道 TMD 学 360 还能判断进程链?还是说有什么组策略?

既然这样,我们就换个方法,既然它会 k 进程链,那么我们就注入到不是我们创建的进程不就行了嘛?

经过测试,Process 这个关键字没被拦截,那么

Process[] processes = Process.GetProcessesByName(processName);
这个方法应该也不会被拦截,试了一下果不其然。

Runway
Runway

Runway是一个AI创意工具平台,它提供了一系列强大的功能,旨在帮助用户在视觉内容创作、设计和开发过程中提高效率和创新能力。

下载

这 oj 真的有做过滤嘛 emmm,不过能调用 api 本来也就很奇怪了吧。

依旧同样的方法,判断 ex­plorer.exe 是否存在,然后找到它的 pid。

这里要注意点,可能找到的不一定是 guest 用户的 ex­plorer 也许是其他用户的,我们不一定有权限注入。

所以是循环查找。

然后就是远程线程注入。

实战 | 某OJ渗透测试记录

很好,自信满满,提交运行。

结果:

实战 | 某OJ渗透测试记录

????

换了 x64/x32 的 shell­code 都不行,msf 的也试过了。全 TMD 都不行。

我本地测试一下也奇怪的奔溃了。但是用 C++ 写的那份却可以运行。怪事。

不得已,只能上 CPP 了,还是 CPP 用的顺手。

不过在此之前只能祈祷这上面能用内联汇编提交了个

代码语言:javascript代码运行次数:0运行复制
#include int main(){__asm{NOP;}return 0;}

上去,发现编译通过了!!!

不就是不能用

windows.h
嘛,小事。

之前想过,不能用 win­dows.h 最大的问题是什么?不能调用 winapi 嘛。

然而懂计算机的都知道,我们只需要知道函数的地址,然后手动 call 不就能调用了嘛。

和这种情况类似的有什么呢?对,就是 shell­code。直接 PEB 或者 SEH 查找 k32.dll 的地址然后再找到 Load­Li­brary 和 Get­P­ro­cAd­dress 的地址,那么 winapi 不就是随便用了吗?

因为仅仅是不能用

windows.h
,和我另外一篇 自己动手打造一份熊猫烧香 ,还是有点区别的,至少 str­cat 这些简单函数都能用,其他的都好说了。

为了节约代码长度,这次不用上一篇文章的那个方法整结构体了。直接参考

中的内联汇编代码,抄出来稍微改改就行

实战 | 某OJ渗透测试记录

然后就是定义 api 然后调用

实战 | 某OJ渗透测试记录

代码很长后面我就不截图了。有了 API 原理就和 C# 版本的一模一样

一样的注入 ex­plorer.exe,提交,运行。

感天动地,终于上线了。过了一分钟也没被 k。

收尾

现在就是判断系统版本,先判断系统版本,sys­tem­info 是不能用的,tasklist 也不行。因为是 guest 权限不是那些 IIS 权限,所以前段时间我用的很爽的各种土豆都用不了,这土豆是真滴好用。啊废话有点多。

用 C# 随便写一个判断系统版本的丢上去。

这时候确实是 C# 比较舒服。.net 库还是全的,如果是 CPP 整 winapi 还得弄一堆七七八八。

最后结果是 win7。虽然结果是这么写的,但是也有可能是 08 之类的东西。因为上传 shell­code 没被杀,所以确认是没有杀软,直接提交 exp 吧。

有了这个就很简单了,随便找个 1458 丢上去,运气好提权成功。

实战 | 某OJ渗透测试记录

用 1458 的时候还出了点小意外,详情可以看我博客里面有个 tgchan­nal。过于丢人就不说了,总之还是换了 8639,提权成功。

实战 | 某OJ渗透测试记录

接下来就是横向了,不过我只是为了日 OJ 而来,剩下的就索然无味了,横向还是日 tw 的 edu 好玩。又没有法律风险,难度也不是很高,他们的 web 一个个都可以是梦回 2008 年代的画风。但是意外的洞却不多,所以又简单的同时也有难度,啊又跑题了。

总之第一步随手看个

netstat -an
,以及
arp -a
,查看其他资产,有 mysql 连接,这种主机肯定存在 MySQL 配置,可以用来横向。

第二步当然是我们最爱的 ms17010 啦。

实战 | 某OJ渗透测试记录

em­mmm,这管理员真的有在管学校嘛。

剩下的没意思,溜了溜了

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

837

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

741

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

737

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

397

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

399

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16926

2023.08.03

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

11

2026.01.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 5.1万人学习

Rust 教程
Rust 教程

共28课时 | 4.6万人学习

Kotlin 教程
Kotlin 教程

共23课时 | 2.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号