Log Forging (FORTIFY.Log_Forging)解决办法

Log Forging (FORTIFY.Log_Forging)解决办法下列Web应用程序代码会尝试从一个请求对象中读取整数值

下列 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

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

 

修复方案,过滤引起Log Forging漏洞的敏感字符的公共方法

 

	/**
	 * Log Forging漏洞校验
	 * @param logs
	 * @return
	 */
	public static String vaildLog(String logs) {
		List<String> list=new ArrayList<String>();
		list.add("%0d");
		list.add("%0a");
        list.add("%0A");
		list.add("%0D");
		list.add("\r");
		list.add("\n");
		String normalize = Normalizer.normalize(logs, Normalizer.Form.NFKC);
		for (String str : list) {
			normalize=normalize.replace(str, "");
		}
		return normalize;
	}

 

 

今天的文章Log Forging (FORTIFY.Log_Forging)解决办法分享到此就结束了,感谢您的阅读。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/61682.html

(0)
编程小号编程小号

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注