zoukankan      html  css  js  c++  java
  • Fortify漏洞之 Log Forging(日志伪造)

      继续对Fortify的漏洞进行总结,本篇主要针对 Log Forging(日志伪造)的漏洞进行总结,如下:

    1.1、产生原因:

    在以下情况下会发生 Log Forging 的漏洞:

    1. 数据从一个不可信赖的数据源进入应用程序。

    2. 数据写入到应用程序或系统日志文件中。

      为了便于以后的审阅、统计数据收集或调试,应用程序通常使用日志文件来储存事件或事务的历史记录。根据应用程序自身的特性,审阅日志文件可在必要时手动执行,也可以自动执行,即利用工具自动挑选日志中的重要事件或带有某种倾向性的信息。

      如果攻击者可以向随后会被逐字记录到日志文件的应用程序提供数据,则可能会妨碍或误导日志文件的解读。最理想的情况是,攻击者可能通过向应用程序提供包括适当字符的输入,在日志文件中插入错误的条目。如果日志文件是自动处理的,那么攻击者就可以通过破坏文件格式或注入意外的字符,从而使文件无法使用。更阴险的攻击可能会导致日志文件中的统计信息发生偏差。通过伪造或其他方式,受到破坏的日志文件可用于掩护攻击者的跟踪轨迹,甚至还可以牵连第三方来执行恶意行为。最糟糕的情况是,攻击者可能向日志文件注入代码或者其他命令,利用日志处理实用程序中的漏洞。

    例 1 下列 Web 应用程序代码会尝试从一个请求对象中读取整数值。如果数值未被解析为整数,输入就会被记录到日志中,附带一条提示相关情况的错误消息。

    ...

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

    try {

      int value = Integer.parseInt(val);

    }catch (NumberFormatException nfe) {

      log.info("Failed to parse val = " + val);

    }

    ...

    如果用户为“val”提交字符串“twenty-one”,则日志中会记录以下条目:

    INFO: Failed to parse val=twenty-one

    然而,如果攻击者提交字符串 “twenty-one%0a%0aINFO:+User+logged+out%3dbadguy,则日志中会记录以下条目:

    INFO: Failed to parse val=twenty-one

    INFO: User logged out=badguy

    显然,攻击者可以使用同样的机制插入任意日志条目。

    1.2、修复方案:

      使用间接方法防止 Log Forging 攻击:创建一组与不同事件一一对应的合法日志条目,这些条目必须记录在日志中,并且仅记录该组条目。要捕获动态内容(如用户注销系统),请务必使用由服务器控制的数值,而非由用户提供的数据。这就确保了日志条目中绝不会直接使用由用户提供的输入。

    可以按以下方式将例 1 重写为与 NumberFormatException 对应的预定义日志条目:

    ...

    public static final String NFE = "Failed to parse val. The input is required to be an integer value."

    ...

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

    try {

      int value = Integer.parseInt(val);

    }catch (NumberFormatException nfe) {

      log.info(NFE);

    }

    ..

      在某些情况下,这个方法有些不切实际,因为这样一组合法的日志条目实在太大或是太复杂了。这种情况下,开发者往往又会退而采用黑名单方法。在输入之前,黑名单会有选择地拒绝或避免潜在的危险字符。然而,不安全字符列表很快就会不完善或过时。更好的方法是创建一份白名单,允许其中的字符出现在日志条目中,并且只接受完全由这些经认可的字符组成的输入。在大多数 Log Forging 攻击中,最关键的字符是 ”(换行符),该字符决不能出现在日志条目白名单中。

     

    图1.2.1:过滤引起Log Forging漏洞的敏感字符的公共方法

  • 相关阅读:
    解决:导出excel身份证号码显示为科学计数法
    6个出色的基于JQuery的Tab选项卡实例2010/01/29 16:261. jQuery 选项卡界面 / 选项卡结构菜单教程
    dhl:禁用firefox缓存
    artDialog4.0.5
    dhl:解除ASP.NET上传文件大小限制
    dhl:样式在ie不同浏览器下呈现不出来的原因分析
    dhl:artDialog 3.0.4 跨框架下 穿越的问题
    jQuery 1.7 正式版已经可以下载使用。jQuery是一个JavaScript库,它简化了HTML文档遍历,事件处理,动画和为网络快速发展的Ajax交互。jQuery 1.7 版本加入了新的事件API .on() 和 .off(),提
    无法向会话状态服务器发出会话状态请求。请确保 ASP.NET State Service (ASP.NET 状态服务)已启动,并且客户端端口与服务器端口相同。
    专家视角看IT与架构
  • 原文地址:https://www.cnblogs.com/meInfo/p/9038496.html
Copyright © 2011-2022 走看看