我正在使用BeSimpleSoapBundle在Symfony 2中生成Web服务。 retrieveOrders方法的响应应该在工作流引擎中使用。
生成的webservice响应是:
<SOAP-ENV:Envelope xmlns:SOAP-ENV="..." xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<SOAP-ENV:Body>
<ns1:retrieveOrdersResponse>
<return>
<item>
<id>1</id>
<lieferdatum>2013-07-03T10:53:38+00:00</lieferdatum>
<tatsaechlichesLieferdatum xsi:nil="true" />
<bestellpositionen />
</item>
<item id="ref1">
<id>10</id>
<lieferdatum>2013-07-03T10:53:38+00:00</lieferdatum>
<tatsaechlichesLieferdatum xsi:nil="true" />
<bestellpositionen>
<item>
<id>6</id>
<liefermenge>3</liefermenge>
<bestellung href="#ref1" />
<produkt id="ref3">
<id>1</id>
<bezeichnung>test</bezeichnung>
</produkt>
<abweichungen />
</item>
</bestellpositionen>
</item>
<item id="ref2">
<id>11</id>
<lieferdatum>2013-07-03T10:53:38+00:00</lieferdatum>
<tatsaechlichesLieferdatum xsi:nil="true" />
<bestellpositionen>
<item>
<id>7</id>
<liefermenge>3</liefermenge>
<bestellung href="#ref2" />
<produkt href="#ref3" />
<abweichungen />
</item>
</bestellpositionen>
</item>
<item id="ref4">
<id>12</id>
<lieferdatum>2013-07-03T10:53:38+00:00</lieferdatum>
<tatsaechlichesLieferdatum xsi:nil="true" />
<bestellpositionen>
<item>
<id>8</id>
<liefermenge>3</liefermenge>
<bestellung href="#ref4" />
<produkt href="#ref3" />
<abweichungen />
</item>
</bestellpositionen>
</item>
<item id="ref5">
<id>13</id>
<lieferdatum>2013-07-03T10:53:38+00:00</lieferdatum>
<tatsaechlichesLieferdatum xsi:nil="true" />
<bestellpositionen>
<item>
<id>9</id>
<liefermenge>3</liefermenge>
<bestellung href="#ref5" />
<produkt href="#ref3" />
<abweichungen />
</item>
</bestellpositionen>
</item>
<item id="ref6">
<id>14</id>
<lieferdatum>2013-07-03T10:53:38+00:00</lieferdatum>
<tatsaechlichesLieferdatum xsi:nil="true" />
<bestellpositionen>
<item>
<id>10</id>
<liefermenge>3</liefermenge>
<bestellung href="#ref6" />
<produkt href="#ref3" />
<abweichungen />
</item>
</bestellpositionen>
</item>
<item>
<id>15</id>
<lieferdatum>2013-12-07T07:00:00+00:00</lieferdatum>
<tatsaechlichesLieferdatum xsi:nil="true" />
<bestellpositionen />
</item>
<item>
<id>16</id>
<lieferdatum>2013-12-07T07:00:00+00:00</lieferdatum>
<tatsaechlichesLieferdatum xsi:nil="true" />
<bestellpositionen />
</item>
<item id="ref7">
<id>17</id>
<lieferdatum>2013-12-07T07:00:00+00:00</lieferdatum>
<tatsaechlichesLieferdatum xsi:nil="true" />
<bestellpositionen>
<item>
<id>11</id>
<liefermenge>2</liefermenge>
<bestellung href="#ref7" />
<produkt href="#ref3" />
<abweichungen />
</item>
</bestellpositionen>
</item>
<item id="ref8">
<id>18</id>
<lieferdatum>2013-12-17T07:00:00+00:00</lieferdatum>
<tatsaechlichesLieferdatum xsi:nil="true" />
<bestellpositionen>
<item>
<id>12</id>
<liefermenge>2</liefermenge>
<bestellung href="#ref8" />
<produkt href="#ref3" />
<abweichungen />
</item>
</bestellpositionen>
</item>
</return>
</ns1:retrieveOrdersResponse>
如您所见,BeSimpleSoapBundle已生成以前输出的XML-Elements链接。
而不是再次定义产品#ref3,它由<produkt href="#ref3" />
引用。
但是如何通过Xpath访问引用元素的属性/节点? 具体如何:我如何获得第一个产品名称('bezeichnung')?
以下Xpath查询无效:
/SOAP-ENV:Envelope/SOAP-ENV:Body/ns1:retrieveOrdersResponse/return/item[id=18]/bestellpositionen/item[id=12]/produkt/bezeichnung
我的问题是:
提前谢谢!
更新
我的一个朋友告诉我,有一个If-then-else结构,允许我 解决这样的结构:
(if(orders/item[id=18]/bestellpositionen/item[id=12]/produkt/@href)
then(orders/item/bestellpositionen/item/produkt[@id= fn:substring(/orders/item[id=18] /bestellpositionen/item[id=12]/produkt/@href, 2) ])
else (orders/item[id=18]/bestellpositionen/item[id=12]/produkt))/bezeichnung
虽然它并不完美,但仍有效。如果有一个简化逻辑的专用函数,请告诉我!
答案 0 :(得分:1)
像这样的XPath应该可以工作:
orders/item[id = 18]/bestellpositionen/item[id = 12]/produkt/bezeichnung |
orders/item/bestellpositionen/item/produkt[id =
substring-after(../../../../item[id = 18]/bestellpositionen/item[id = 12]
/produkt/@href, '#')]
您可以做的另一件事是使用这个简单的XSLT来解析所有引用:
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" indent="yes" omit-xml-declaration="yes" />
<xsl:key name="kRefTarget" match="*[@id]" use="@id"/>
<xsl:template match="@* | node()">
<xsl:copy>
<xsl:apply-templates select="@* | node()"/>
</xsl:copy>
</xsl:template>
<!-- The [not(substring-after(@href, '#') = ancestor::*/@id)] portion prevents
infinite recursion on <bestellung> and anything else that references its
own ancestor. -->
<xsl:template match="*[@href]
[not(substring-after(@href, '#') = ancestor::*/@id)]">
<xsl:apply-templates select="key('kRefTarget', substring-after(@href, '#'))" />
</xsl:template>
</xsl:stylesheet>
在样本输入上运行此项后,项目18的XML看起来像:
<item id="ref8">
<id>18</id>
<lieferdatum>2013-12-17T07:00:00+00:00</lieferdatum>
<tatsaechlichesLieferdatum xsi:nil="true" />
<bestellpositionen>
<item>
<id>12</id>
<liefermenge>2</liefermenge>
<bestellung href="#ref8" />
<produkt id="ref3">
<id>1</id>
<bezeichnung>test</bezeichnung>
</produkt>
<abweichungen />
</item>
</bestellpositionen>
</item>