Freemarker的prase函数可以解析xml文件,将xml文档树解析为map结构,这样我们就可以用xml作为数据源了。这在Freemarker对xml文件的增量更新中用处很大。
但是当xml带有dtd校验时,如下一段xml文件:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN"
"http://www.springframework.org/dtd/spring-beans.dtd">
<beans default-autowire="byName">
。。。
prase函数会去网络上下载DTD文件来对xml进行校验,如果拔掉网线,prase函数就会抛出异常,www.springframework.org未知域名。
因为涉及到网络通信,prase函数执行的会很慢。
去掉DTD校验解决方法:
可以到
http://www.docjar.com/html/api/freemarker/ext/dom/NodeModel.java.html
查看prase函数的源代码。Freemarker并没有解决方法,那么只有重写NodeModel这个类了。
解决示例:
1. 重写prase函数
public abstract class NodeModelWithoutDtd extends NodeModel {
protected NodeModelWithoutDtd(Node node) {
super(node);
}
public static NodeModel parse(InputSource is) throws SAXException,
IOException, ParserConfigurationException {
return parse(is, true, true);
}
public static NodeModel parse(InputSource is, boolean removeComments,
boolean removePIs) throws SAXException, IOException,
ParserConfigurationException {
DocumentBuilder builder = getDocumentBuilderFactory()
.newDocumentBuilder();
//设置成空的DTD校验
NullEntityResolver nullEntityResolver = new NullEntityResolver();
builder.setEntityResolver(nullEntityResolver);
Document doc = builder.parse(is);
if (removeComments && removePIs) {
NodeModel.simplify(doc);
}
else {
if (removeComments)
NodeModel.removeComments(doc);
if (removePIs)
NodeModel.removePIs(doc);
NodeModel.mergeAdjacentText(doc);
}
return NodeModel.wrap(doc);
}
}
2. 空DTD校验类
public class NullEntityResolver implements EntityResolver {
static String emptyDtd = "";
static ByteArrayInputStream byteIs = new ByteArrayInputStream(emptyDtd.getBytes());
public InputSource resolveEntity(String publicId, String systemId)
throws SAXException, IOException {
return new InputSource(byteIs);
}
}
然后用NodeModelWithoutDtd.prase("")就可以了~
分享到:
相关推荐
给初学者一个简单的利用freemarker生成xml文件的例子
使用freemarker解析成pdf
freemarker大致原理是:将页面中所需要的样式放入FreeMarker文件中,然后将页面所需要的数据动态绑定,并放入Map中,通过调用FreeMarker模板文件解析类process()方法完成静态页面的生成。了解了上面的原理,接下来我...
Freemarker + XML 生成word 文档 。具体步骤先用word做好模板,然后另存为xml 2003 版本的,修改后缀为.ftl文件。在文件中加入需要处理的循环标签 。一般是在开始的前面。
基于Freemarker模板的代码生成器实体映射xml的ftl模板文件
Spring配置Freemarker视图解析器,配置多个视图解析器
ant + freemarker + excel解析
文件包含关于java解析freemarker内容的相关源码和工具类
Freemarker动态生成word,包含文字替换,freemarker嵌入自定义java函数,动态生成表格列,插入图片的示例,同时使用spire将wordxml格式转换成word文档(doc格式),还包含文件下载示例
Spring配置Freemarker视图解析器,前台页面全部使用freemarker渲染
freemarker.jar freemarker架包 freemarker生成excel、word、html、xml简单例子freemarker生成excel、word、html、xml简单例子
NULL 博文链接:https://hongyabing.iteye.com/blog/1156172
freemarker+xml生成word里面有要用到的jar包和使用方法
第一步都会将word转换为xml格式文件,解析成xml文件经常会出现(个别、很多)字段占位符、变量值被分离,被分离的字段少的还好能手动改改,字段多了能让你直接发疯,此代码脚本轻松解决占位符、变量值被分离的问题,...
freemarker+xml动态模板生成doc文件技术,比jacob更加好用,不存在系统兼容性问题,但是依赖于word2003以上的版本才能解析
大致的思路是先用office2003或者2007编辑好word的样式,然后另存为xml,将xml翻译为FreeMarker模板,最后用java来解析FreeMarker模板并输出‘.doc’ word文档。经测试这样方式生成的word文档完全符合office标准,...
freemarker相关介绍 根据xml批量生成java类,可自定义模版 例子可读取单个xml文件,也可读取指定目录下的多个xml文件 默认输出目录:D:\test_file\genrate_java 可在工具类CommonUtil中修改 关于freemarker的更多...
Word从2003开始支持XML格式,用XML+Freemarder还做就很简单了,大致的思路是先用office2003或者2007编辑好 word的样式,然后另存为xml,将xml翻译为FreeMarker模板,最后用java来解析FreeMarker模板并输出Doc。...
包括freemarker.jar,模板xml以及java调用代码