Java安全基础——文件系统安全

前言:空字节截断漏洞漏洞在诸多编程语言中都存在,究其根本是Java在调用文件系统(C实现)读写文件时导致的漏洞,并不是Java本身的安全问题,不过好在高版本的JDK在处理文件时已经把空字节文件名进行了安全检测处理

1:我们先来熟悉常用的几个操作文件的类

字节流:

FileInputStream:从文件或其他外部源读取数据到jvm内存,一次只读一个字节

FileOutputStream:将jvm内存的数据写入文件或其他外部目标,一次只输出一个字节

BufferedInputStream:字节缓存流,一次读取一个或者指定的字节

BufferedOutputStream:字节缓存流,一次写入一个或者指定的字节

ObjectInputStream:序列化,将对象写入到文件

ObjectOutputStream:反序列化,将文件读取到jvm内存

字符流:

FileReader:从文件或其他外部源读取数据到jvm内存,一次只读一个字节,遇到中文读多个字节

FileWriter:写入在缓冲区中(长度为8192的字节的数组)

BufferedReader:字符缓冲流,特有的方法(readLine)读取一行

BufferedWriter:字符缓冲流,特有的方法(newLine)阔平台换行

InputStreamReader:把字节输入流转换成字符输入流

OutputStreamWriter:把字符输出流转换成字节输出流

2:缓存流的原理

缓存区先向文件中一次读取8192个字节,文件如果没有8192个字节,则有多少装多少,然后利用变量b去往缓冲区进行读取并写到缓冲输出流的缓冲区中,如果缓冲输出流的缓冲区装满了则会自动写入到目的地中,如果关流会检查缓冲区里面有没有数据,然后再把缓冲区的数据写到文件当中,数组是一样的原理

3:完整流程图

4:绕过WAF和RASP的检测

在Java SE中内置了两类文件系统:java.iojava.niojava.nio的实现是sun.nio,文件系统底层的API实现如下图:

如果WAF和RASP只检测了io包下的类,我们可以使用nio包下的类来进行绕过实现

5:JDK1.7.0.25之前的漏洞(空字节截断)

原理:

攻击者上传一个精心构造的文件名,例如:malicious.php\0.jpg。

关键点:这个文件名在Java层看起来是 "malicious.php\0.jpg"。

Java代码进行检查:"malicious.php\0.jpg".endsWith(".jpg") -> true,因为从Java的角度看,这个字符串确实以 .jpg 结尾。安全检查被绕过!

现在,Java代码试图将这个文件保存到磁盘,比如路径是 /uploads/malicious.php\0.jpg。

当Java通过JNI调用系统的 fopen 或 createFile 等C函数时,Java字符串 "/uploads/malicious.php\0.jpg" 被转换为C字符串

在C函数眼中,一旦读到 \0,它就认为路径是 /uploads/malicious.php,而后面的 .jpg 被完全忽略

最终,服务器上保存的不是 malicious.php\0.jpg,而是一个名为 malicious.php 的可执行脚本文件

相关推荐
潜创微科技4 小时前
IT6520:USB‑C 转 MIPI 芯片方案 4K@120Hz 高清显示
c语言·开发语言
言之。5 小时前
【Python】免费的中文 AI 配音方案
开发语言·人工智能·python
天天进步20156 小时前
Python全栈项目:从零手操一个高性能 API 网关
开发语言·python
Java面试题总结6 小时前
java高频面试题(2026最新)
java·开发语言·jvm·数据库·spring·缓存
网教盟人才服务平台6 小时前
全国政务网络安全能力提升行动启动,筑牢政务数据安全防线
安全·web安全·政务
黎阳之光6 小时前
黎阳之光:以视频孪生重构智能监盘,为燃机打造新一代智慧电厂大脑
大数据·人工智能·算法·安全·数字孪生
汽车仪器仪表相关领域6 小时前
Kvaser Hybrid Pro 2xCAN/LIN 双通道可编程CAN/LIN通讯接口:一机双模可编程,汽车车身混合总线测试专用设备
人工智能·功能测试·安全·fpga开发·汽车·压力测试
苦逼的猿宝6 小时前
学生心理咨询评估系统
java·毕业设计·springboot·计算机毕业设计
隔窗听雨眠6 小时前
doctype、charset、meta如何控制整个渲染流水线
java·服务器·前端
Bruce_Liuxiaowei6 小时前
2026年5月第4周网络安全形势周报
网络·人工智能·安全·web安全·网络安全·系统安全