gpt4 book ai didi

java - 将生成的 XSLT 数据保存到 XML 文件

转载 作者:数据小太阳 更新时间:2023-10-29 02:31:08 25 4
gpt4 key购买 nike

我在尝试使用 XSLT 将一些数据保存到 XML 时遇到了问题。所以问题是似乎一切正常,没有抛出异常,日志文件也很干净,但我看不到 XML 文件有任何变化。我不能这是我将输出保存到文件的代码

    Transformer transformer = XslTemplatesPool.getTransformer(SAVE_ITEM, realPath);
setCategoryAndSubcateory(transformer, request);

String name = request.getParameter(NAME);
/*retrieving some more parameters*/
String price = request.getParameter(PRICE);

transformer.setParameter(NAME, name);
/*...*/
transformer.setParameter(XML_PATH, "E:/xslt/WebContent/xml/shop.xml");

if (price == null) {
price = "";
}
transformer.setParameter(PRICE, price);
if (notInStock == null) {
notInStock = "";
}
/*
* out is an instance of PrintWriter
* PrintWriter out = httpServletResponse.getWriter()
*/
transformer.setParameter(NOT_IN_STOCK, notInStock);
executeWrite(out, readWriteLock, transformer);


protected void executeWrite(PrintWriter out, ReadWriteLock readWriteLock, Transformer transformer) throws HandledException {

Source xmlSource = new StreamSource("E:/xslt/WebContent/xml/shop.xml");
StreamResult result = new StreamResult(out);
Lock writeLock = readWriteLock.writeLock();
writeLock.lock();

try {
transformer.transform(xmlSource, result);
} catch (TransformerException e) {
ExceptionHandler.logAndThrow(e, logger);
} finally {
writeLock.unlock();
}
}

从 XSLT 生成的表单 addItem(在这个阶段我需要的所有信息都变得非常顺利)我检索了一些数据并尝试使用模板 saveItem 将它添加到 xml 文件

<?xml version="1.0" encoding="UTF-8"?>

<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:xs="http://www.example.org/products"
xmlns:redirect="http://xml.apache.org/xalan/redirect"
extension-element-prefixes="redirect"
xmlns:validation="xalan://com.xslt.util.Validator"
exclude-result-prefixes="validation redirect">

<xsl:import href="addItem.xsl" />
<xsl:import href="productsList.xsl" />

<xsl:param name="categoryName" />
<xsl:param name="subcategoryName" />
<xsl:param name="name" />
<xsl:param name="producer" />
<xsl:param name="model" />
<xsl:param name="date-of-issue" />
<xsl:param name="color" />
<xsl:param name="not-in-stock" />
<xsl:param name="price" />
<xsl:param name="xmlPath"/>
<xsl:param name="isValid" select="validation:validate($name, $producer, $model, $date-of-issue, $color, $price, $not-in-stock)" />
<xsl:param name="nameError" select="validation:getNameError()" />
<xsl:param name="producerError" select="validation:getProducerError()" />
<xsl:param name="modelError" select="validation:getModelError()" />
<xsl:param name="dateError" select="validation:getDateError()" />
<xsl:param name="priceError" select="validation:getPriceError()" />
<xsl:param name="colorError" select="validation:getColorError()" />

<xsl:template match="/" priority="2">
<xsl:choose>
<xsl:when test="not($isValid)">
<xsl:call-template name="addItem">
<xsl:with-param name="nameError" select="$nameError" />
<xsl:with-param name="producerError" select="$producerError" />
<xsl:with-param name="modelError" select="$modelError" />
<xsl:with-param name="dateError" select="$dateError" />
<xsl:with-param name="priceError" select="$priceError" />
<xsl:with-param name="colorError" select="$colorError" />
<xsl:with-param name="not-in-stock" select="$not-in-stock" />
</xsl:call-template>
</xsl:when>
<xsl:otherwise>
<redirect:write select="$xmlPath">
<xsl:call-template name="saveItem" />
</redirect:write>
<xsl:call-template name="returnToProducts" />
</xsl:otherwise>
</xsl:choose>
</xsl:template>

<xsl:template name="saveItem" match="@*|node()" priority="2">
<xsl:copy>
<xsl:apply-templates select="@*|node()" />
</xsl:copy>
</xsl:template>

<xsl:template match="/xs:shop/xs:category[@name=$categoryName]/xs:subcategory[@name=$subcategoryName]">
<xsl:copy>
<xsl:apply-templates select="@*|node()" />
<xsl:element name="xs:product">
<xsl:attribute name="name">
<xsl:value-of select="$name" />
</xsl:attribute>
<xsl:attribute name="producer">
<xsl:value-of select="$producer" />
</xsl:attribute>
<xsl:attribute name="model">
<xsl:value-of select="$model" />
</xsl:attribute>
<xsl:element name="xs:date-of-issue">
<xsl:value-of select="$date-of-issue" />
</xsl:element>
<xsl:element name="xs:color">
<xsl:value-of select="$color" />
</xsl:element>
<xsl:choose>
<xsl:when test="$not-in-stock">
<xsl:element name="xs:not-in-stock" />
</xsl:when>
<xsl:otherwise>
<xsl:element name="xs:price">
<xsl:value-of select="$price" />
</xsl:element>
</xsl:otherwise>
</xsl:choose>
</xsl:element>
</xsl:copy>
</xsl:template>

<xsl:template name="returnToProducts">
<html>
<head>
<meta http-equiv="refresh" content="0;url=controller.do?command=productsList&amp;categoryName={$categoryName}&amp;subcategoryName={$subcategoryName}" />
</head>
</html>
</xsl:template>

</xsl:stylesheet>

我的 XML 文件示例

<xs:shop xmlns:xs="http://www.example.org/products" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.example.org/products shop.xsd">    
<xs:category name="bicycle">
<xs:subcategory name="frame">
<xs:product name="Soda FR" producer="NS" model="fr445">
<xs:date-of-issue>10-05-2012</xs:date-of-issue>
<xs:color>white</xs:color>
<xs:price>520$</xs:price>
</xs:product>
<xs:product name="Nucleon" producer="Nicolai" model="nc428">
<xs:date-of-issue>10-05-2012</xs:date-of-issue>
<xs:color>dark grey</xs:color>
<xs:not-in-stock/>
</xs:product>
</xs:subcategory>
</xs:category>
</xs:shop>

最佳答案

所以...最后我做到了。还有一个小bug

SystemId Unknown; Line #-1; Column #-1; Premature end of file.

但我希望它不是很难修复。

正如您在下面看到的,输出流现在被写入 StringWriter,然后 StringWriter 被写入 XML 文件。如果将文件传递给 StreamResult,我仍然不明白为什么没有结果(文件刚刚被清除)。可能只是我的手长错地方了。也许我明天会做一点研究。

因此,方法 executeWrite(...) 发生了很大变化

    protected void executeWrite(PrintWriter out, ReadWriteLock readWriteLock, Transformer transformer)
throws HandledException {

Lock readLock = readWriteLock.readLock();
StringWriter outWriter = new StringWriter();
Transformer t = null;
try {
readLock.lock();
StreamSource xmlStream = new StreamSource(/*path to XML*/);
t = transformer;
t.transform(xmlStream, new StreamResult(outWriter));
} catch (TransformerException e) {
ExceptionHandler.logAndThrow(e, logger);
} finally {
readLock.unlock();
}

Lock writeLock = readWriteLock.writeLock();
FileWriter fileWriter = null;
try {
writeLock.lock();
fileWriter = new FileWriter(new File(/*path to XML*/));
fileWriter.write(outWriter.toString());
} catch (IOException e) {
ExceptionHandler.logAndThrow(e, logger);
} finally {
if (fileWriter != null) {
try {
fileWriter.close();
} catch (IOException e) {
ExceptionHandler.logAndThrow(e, logger);
}
}
writeLock.unlock();
}
}

关于java - 将生成的 XSLT 数据保存到 XML 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14855312/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com