应用软件安全编程--05预防 XML 注入

如果用户有能力使用结构化XML 文档作为输入,那么他能够通过在数据字段中插入 XML 标签来 重写这个 XML 文档的内容。 XML 解析器会将这些标签按照正常标签进行解析。下面是一段在线商 店的 XML 代码,主要用于查询后台数据库。

XML 复制代码
<item)

<description>Widget</description)

<price)500.0</price>

<quantity>1</quantity)

</item)

恶意用户可以在<quantity)元素中输入以下字符串:1</quantity)<price>1.0</price〉<quantity>1 会生成以下的 XML 文档:

XML 复制代码
<item)

<description>Widget</description)

<price)500.0</price>

<quantity)1</quantity)<price)1.0</price 〉<quantity)1</quantity)

</item)

通过使用简单的API 解析器(org.xml.sax and javax.xml.parsers.SAXParser)可以解析该 XML 文 件,如果解析XML 的代码获取的是最后一个元素<price)的值,那么商品价格就被设置为1.0。

对于预防 XML 注入的情况,示例1给出了不规范用法(Java 语言)示例。示例2给出了规范用法 (Java 语言)示例。

java 复制代码
示例1:

public class OnlineStore {

private static void createXMLStreamBad(final BufferedOutputStreamoutStream, final String quantity) throws IO- Exception {

String xmlString ="<item 〉\n(description>Widget</description)\n"

+"<price)500</price 〉\n"+"<quantity)"+ +"</quantity)</item)";

outStream.write(xmlString.getBytes());

outStream.flush();

}

} 

上面的代码样例中,一个方法简单的使用了字符串拼接来创建一个 XML 查询,然后将其发送到服务器。在这时就有可能出现XML注入问题,因为这个方法没有进行任何输入验证。

当XML可能已经载入还未处理的输入数据时,一般情况下使用XML模板或者DTD验证 XML。如果还没有创建这样的XML字符串,那么应在创建 XML之前处理输入,这种方式性能较高。

java 复制代码
示例2(输入验证):

public class OnlineStore {

private static void createXMLStream(final BufferedOutputStreamoutStream,

final String quantity) throws IOException, NumberFormatException {

// Write XML string only if quantity is an unsigned integer(count).

int count = Integer.parseUnsignedInt(quantity);

String xmlString ="<item 〉\n(description>Widget</description)\n"

+"<price)500(/price 〉\n"+"〈quantity)"+         count+"</quantity)</item)";

outStream.write(xmlString.getBytes());

outStream.flush();

 }

 }

代码的解决方案是验证 quantity 是一个无符号整数。

相关推荐
@yanyu66613 分钟前
idea中配置tomcat
java·mysql·tomcat
2501_9167665415 分钟前
【项目部署】JavaWeb、MavenJavaWeb项目部署至 Tomcat 的实现方式
java·tomcat
RoboWizard26 分钟前
扩容刚需 金士顿新款Canvas Plus存储卡
java·spring·缓存·电脑·金士顿
lang2015092841 分钟前
Spring Boot 入门:5分钟搭建Hello World
java·spring boot·后端
失散131 小时前
分布式专题——47 ElasticSearch搜索相关性详解
java·分布式·elasticsearch·架构
serve the people1 小时前
LangChain 表达式语言核心组合:Prompt + LLM + OutputParser
java·langchain·prompt
想ai抽1 小时前
深入starrocks-多列联合统计一致性探查与策略(YY一下)
java·数据库·数据仓库
武子康1 小时前
Java-152 深入浅出 MongoDB 索引详解 从 MongoDB B-树 到 MySQL B+树 索引机制、数据结构与应用场景的全面对比分析
java·开发语言·数据库·sql·mongodb·性能优化·nosql
杰克尼1 小时前
JavaWeb_p165部门管理
java·开发语言·前端
数字供应链安全产品选型1 小时前
国家级!悬镜安全入选两项“网络安全国家标准应用实践案例”
人工智能·安全·web安全