java安全问题_JAVA常见安全问题复现

地址来源于乌云知识库,作者z_zz_zzz

0x01 任意文件下载

web.xml的配置:

DownloadAction

DownloadAction

com.oboi.DownloadAction.DownloadAction

DownloadAction

/DownloadAction

其中的servlet类要换下。类的代码如下:

public class DownloadAction extends HttpServlet {

@Override

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

String rootPath = this.getServletContext().getRealPath("/");

String filename = request.getParameter("filename");

if (filename == null)

filename = "";

filename = filename.trim();

InputStream inStream = null;

byte[] b = new byte[1024];

int len = 0;

try {

if (filename == null) {

return;

}

// 读到流中

// 本行代码未对文件名参数进行过滤,存在任意文件下载漏洞

//如果有指定后缀名好像也不能截断

inStream = new FileInputStream(rootPath + "/" + filename);

// 设置输出的格式

response.reset();

response.setContentType("application/x-msdownload");

response.addHeader("Content-Disposition", "attachment; filename=\""

+ filename + "\"");

// 循环取出流中的数据

while ((len = inStream.read(b)) > 0) {

response.getOutputStream().write(b, 0, len);

}

response.getOutputStream().close();

inStream.close();

} catch (Exception e) {

e.printStackTrace();

}

}

}

JDK1.5-1.7存在0x00导致的文件名截断问题,与操作系统无关。冒号在Windows环境会导致文件名截断问题,与JAVA无关。

如果要修复这种漏洞的话,可以用文章中讲的。

在生成File对象后,使用getCanonicalPath获取当前文件的真实路径,判断文件是否在允许下载的目录中,若发现文件不在允许下载的目录中,则拒绝下载。

if (!pathname.getCanonicalPath().startsWith(rootPath)){

System.out.println("禁止目录穿越下载");

}

这里记录一下,如果是JAVA写的网站遇到任意文件读取,怎么扩大战果?下载配置文件,有框架的话下载框架配置文件。比如:WEB-INF/web.xml

通过下载的配置文件去读class文件,然后通过jad反编译出代码来。

22bac388f2d62727a4a5c72e3e96ce36.png

读到servlet-class 以后通过WEB-INF/classes/com/oboi/DownloadAction/DownloadAction.class 就能读到类了。

0x02 恶意文件上传

未完待续。。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值