java - 如何强制 javax xslt 转换器使用 utf-8 而不是 html 实体对国家字符进行编码?

标签 java xslt utf-8 entities transformer-model

我正在研究应该使用某些样式表转换输出的过滤器。代码的重要部分如下所示:

PrintWriter out = response.getWriter();
...
StringReader sr = new StringReader(content);
Source xmlSource = new StreamSource(sr, requestSystemId);
transformer.setOutputProperty(OutputKeys.ENCODING, "UTF-8");
transformer.setParameter("encoding", "UTF-8");
//same result when using ByteArrayOutputStream xo = new java.io.ByteArrayOutputStream();
StringWriter xo = new StringWriter();
StreamResult result = new StreamResult(xo);
transformer.transform(xmlSource, result);
out.write(xo.toString());

问题是国家字符被编码为 html 实体,而不是使用 UTF。有没有办法强制转换器使用 UTF-8 而不是实体?

最佳答案

您需要将输出方法设置为 text 而不是(默认)xml

transformer.setOutputProperty(OutputKeys.METHOD, "text");

但是,您还应该预先设置响应编码:

response.setCharacterEncoding("UTF-8");

并指示网络浏览器使用相同的编码:

response.setContentType("text/html;charset=UTF-8");

关于java - 如何强制 javax xslt 转换器使用 utf-8 而不是 html 实体对国家字符进行编码?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3029400/

相关文章:

XSLT:添加节点内部文本

c# - UTF8 文件开头字符正在破坏序列化器和读取器

java - 如何将PDF中的文本提取到word?

c# - 过滤 XML 文档部分的有效方法

java - 比较方法违反了它的一般契约——但我可能想这样做?

java - 以编程方式在 Java/Android 中进行 Saxon XSLT 转换

string - 以字符串形式访问 Vec<&[u8]> 的正确方法

ios - 为什么我不能将 secureTextEntry 与 UTF-8 键盘一起使用?

java - ResourceAccessException 内 SocketTimeout 异常的 Junit 代码覆盖率

java - Java 中的类是如何实例化的?