XML不通过Java Transformer在远程服务器上缩进

时间:2015-12-08 12:54:32

标签: java xml xslt

我们在Java应用程序中遇到问题,我们使用javax.xml.transform.Transformer缩进XML字符串。

问题是它在本地计算机上运行正常,但在远程计算机上部署时,会忽略缩进。我们在本地和服务器上使用相同的服务器(Wildfly 8.2)和相同的Java(1.8)。

执行缩进的方法:

public static String transToXMLString(Document doc) {
        try {
            StreamResult sw = new StreamResult(new StringWriter());
            TransformerFactory tf = TransformerFactory.newInstance();
            Transformer transformer;

            transformer = tf.newTransformer();

            transformer.setOutputProperty(OutputKeys.OMIT_XML_DECLARATION, "no");
            transformer.setOutputProperty(OutputKeys.METHOD, "xml");
            transformer.setOutputProperty(OutputKeys.INDENT, "yes");
            transformer.setOutputProperty("{http://xml.apache.org/xslt}indent-amount", "2");
            transformer.setOutputProperty(OutputKeys.ENCODING, "UTF-8");

            transformer.transform(new DOMSource(doc), sw);

            return sw.getWriter().toString();
        } catch (TransformerException e) {
            e.printStackTrace();
        }

        return null;
    }

本地机器上的结果:

13:45:30,583 INFO  [stdout] (default task-6) <?xml version="1.0" encoding="UTF-8" standalone="no"?>

13:45:30,583 INFO  [stdout] (default task-6) <workflow URI="">

13:45:30,583 INFO  [stdout] (default task-6)   <output ID="" URI="#out1"/>

13:45:30,583 INFO  [stdout] (default task-6)   <input ID="sessionToken" URI="#sessionToken"/>

13:45:30,583 INFO  [stdout] (default task-6)   <services>

13:45:30,584 INFO  [stdout] (default task-6)     <sequence>

13:45:30,584 INFO  [stdout] (default task-6)       <service URI="">

13:45:30,584 INFO  [stdout] (default task-6)         <input ID="" URI=""/>

13:45:30,584 INFO  [stdout] (default task-6)         <input URI="" value=""/>

13:45:30,584 INFO  [stdout] (default task-6)         <output ID="" URI=""/>

13:45:30,584 INFO  [stdout] (default task-6)       </service>

13:45:30,584 INFO  [stdout] (default task-6)     </sequence>

13:45:30,584 INFO  [stdout] (default task-6)   </services>

13:45:30,584 INFO  [stdout] (default task-6) </workflow>

13:45:30,584 INFO  [stdout] (default task-6) 

远程服务器上的结果:

2015-12-08 13:47:36,577 INFO  [stdout] (default task-6) Client : close()......
2015-12-08 13:47:36,599 INFO  [stdout] (default task-6) <?xml version="1.0" encoding="UTF-8"?><workflow URI="">
2015-12-08 13:47:36,600 INFO  [stdout] (default task-6) <output ID="" URI="#out1"/>
2015-12-08 13:47:36,600 INFO  [stdout] (default task-6) <input ID="sessionToken" URI="#sessionToken"/>
2015-12-08 13:47:36,602 INFO  [stdout] (default task-6) <services>
2015-12-08 13:47:36,605 INFO  [stdout] (default task-6) <sequence>
2015-12-08 13:47:36,605 INFO  [stdout] (default task-6) <service URI="">
2015-12-08 13:47:36,606 INFO  [stdout] (default task-6) <input ID="" URI=""/>
2015-12-08 13:47:36,607 INFO  [stdout] (default task-6) <input URI="" value=""/>
2015-12-08 13:47:36,608 INFO  [stdout] (default task-6) <output ID="" URI=""/>
2015-12-08 13:47:36,608 INFO  [stdout] (default task-6) </service>
2015-12-08 13:47:36,609 INFO  [stdout] (default task-6) </sequence>
2015-12-08 13:47:36,609 INFO  [stdout] (default task-6) </services>
2015-12-08 13:47:36,610 INFO  [stdout] (default task-6) </workflow>
2015-12-08 13:47:36,610 INFO  [stdout] (default task-6)

我在网页上的textarea中显示这个xml,我需要在那里缩进,我很奇怪它在本地机器上的行为与远程不同,CSS是相同的,tje java版本是相同。在我看来,Transformes类在本地的行为与远程服务器上的行为不同。

我还尝试将Transformer输出写入文件以避免clonsole和日志设置的差异。

localhost上的文件如下所示:

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<workflow URI="">
  <output ID="" URI="#out1"/>
  <input ID="sessionToken" URI="#sessionToken"/>
  <services>
    <sequence>
      <service URI="">
        <input ID="" URI=""/>
        <input URI="" value=""/>
        <output ID="" URI=""/>
      </service>
    </sequence>
  </services>
</workflow>

在远程服务器上看起来(所以没有缩进):

<?xml version="1.0" encoding="UTF-8"?><workflow URI="">
<output ID="" URI="#out1"/>
<input ID="sessionToken" URI="#sessionToken"/>
<services>
<sequence>
<service URI="">
<input ID="" URI=""/>
<input URI="" value=""/>
<output ID="" URI=""/>
</service>
</sequence>
</services>
</workflow>

所以对我来说,它看起来像Transformer方法的不同行为......但它怎么可能?

3 个答案:

答案 0 :(得分:1)

问题不在于XSLT,而在于记录器的配置。远程机器正在修剪每条线;本地机器不是。调整服务器的配置文件以匹配本地计算机的配置文件,或者将transToXMLString()的结果直接写入文件而不是通过记录器。

答案 1 :(得分:0)

对于XML,没有必要进行缩进。它只能包含一个包含所有数据的字符串。所以没关系。可能是某些环境设置不允许在终端

中进行缩进

答案 2 :(得分:0)

我选择了DOM4J来格式化xml,它在localy和remote上的工作方式相同。这是我的代码:

public static String prettyPrintXml(String xml) {

        final StringWriter sw;

        try {
            final OutputFormat format = OutputFormat.createPrettyPrint();
            format.setSuppressDeclaration(true);
            final org.dom4j.Document document = DocumentHelper.parseText(xml);
            sw = new StringWriter();
            final XMLWriter writer = new XMLWriter(sw, format);
            writer.write(document);
        } catch (Exception e) {
            throw new RuntimeException("Error pretty printing xml:\n" + xml, e);
        }
        return sw.toString();
    }