首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Java安全风险?

Java安全风险?
EN

Security用户
提问于 2016-05-19 05:30:12
回答 2查看 800关注 0票数 -3

为什么这个代码被认为是危险的或脆弱的?

代码语言:javascript
复制
String sFileName = request.getParameter("fName");
if (sFileName.toLowerCase().endsWith(".pdf"))
// open file
else
// don’t open the file
EN

回答 2

Security用户

发布于 2016-05-19 06:42:12

除了路径遍历攻击之外,该代码还容易受到Null-Byte注入的攻击。有关更多信息,请阅读

更新:

正如Maarten所指出的那样,这一点从1.7.0_40开始就得到了修正。不过,我记得这是1.6中的一个漏洞。无论如何,当您查看File类的源代码时,您会发现添加了isInvalid()方法,该方法进行空字节检查:

代码语言:javascript
复制
final boolean isInvalid() {
    if (status == null) {
        status = (this.path.indexOf('\u0000') < 0) ? PathStatus.CHECKED
                                                   : PathStatus.INVALID;
    }
    return status == PathStatus.INVALID;
}

还请参阅堆栈过流上的这篇文章。

票数 1
EN

Security用户

发布于 2016-05-20 07:29:52

现在,我看到这段代码有两个问题,取决于上下文。

  • 文件名以.pdf结尾这一事实并不意味着它是一个PDF文件。可能会引发各种麻烦。
  • 恶意代码可以隐藏在PDF文件的宏中。

但就像我说的,一切都取决于背景。

票数 0
EN
页面原文内容由Security提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://security.stackexchange.com/questions/123694

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档