社团课上与同学玩学校OJ 并尝试对评测机进行一些探索 为了方便就用python代码了
已知学校OJ使用的是氦星人系统 评测机禁用了os模块 导致一开始没法进行系统调用 遂尝试读写文件 发现居然是可以的
socket模块依赖os模块 导致暂时只能通过OJ的测试功能获取代码输出)
先尝试硬写大量数据以搞爆评测机 发现会报File too large错误 于是放弃
根据平时使用经验(做题时的报错)得知评测机为Linux系统 使用Python3.8
然后尝试向/tmp目录写文件 发现可以持久化保存 并且另一位同学也能读取到(顺便根据多次实验发现能读取到的概率大约50% 推测有两个评测机负载均衡)
之后尝试读取/proc等以获取系统信息 如下

信息 来源
CPU /proc/cpuinfo Intel® Xeon® Gold 5120 CPU @ 2.20GHz
内存 /proc/meminfo 16GB
硬盘分区 /proc/partitions 104857600 blocks (sda)… (按1KB/block则为100GB)
启动镜像 /proc/cmdline vmlinuz-3.10.0-1127.10.1.el7.x86_64
内核版本 /proc/version Linux version 3.10.0-1127.10.1.el7.x86_64 ([email protected])
GCC版本 /proc/version gcc version 4.8.5 20150623 (Red Hat 4.8.5-39) (GCC)
运行时间 /proc/uptime 运行:788.4天;空闲:784.2天/核心(空闲率99.46%)

回家后同学发现可以使用posix模块进行系统调用 并且该模块没有被禁用 于是打开新世界的大门

首先肯定是是ls 当前目录包含sourcesource.cinputcore.xxxxx等文件
其中source就是python代码的源文件 cat后发现评测时会在提交的python代码前加上如下代码:

1
2
3
import random
import sys
sys.modules["os"] = None

source.ccore.xxxxx分别是C++程序的源代码和编译后的程序
input则为测试输入

…/…/…/rwl/okcall.h -> HUSTOJ

后记:
C++没禁用系统调用 这下舍近求远了