BizTalk - 使用具有多个命名空间的 xpath 提取元素值
BizTalk - Extract element value using xpath with multiple namespaces
我在 BizTalk 中有一条员工消息。在编排中,我试图获取字段的值 (IBKT_SYSID_PK) 但它返回的是空值。请协助。
员工留言:
<ns1:Employee xmlns:ns2="http://purl.org/dc/elements/1.1/" xmlns:ns3="http://www.w3.org/XML/1998/namespace" xmlns:ns4="http://www.w3.org/2000/09/xmldsig#">
<EmployeeHeader>
<State>tobeProcessedbySubOrch</State>
<GUID>4a569a18-5b6a-4b90-9c0c-324cbdcf78e8</GUID>
<EmployeeStatus>update</EmployeeStatus>
<Vendor>A</Vendor>
<Destination>K</Destination>
<Errors>
<ErrorType>Business</ErrorType>
<ErrorCorrection />
<Error><FldName>EMPL-59637</FldName><Code>302</Code><Msg>Modified Date Mismatch, data might be out of sync between K and A</Msg></Error></Errors>
<ErrorInd>true</ErrorInd>
<WarningInd>false</WarningInd>
<TransactionID>40047965</TransactionID>
<LogicalKey>59637</LogicalKey>
<ReceivedTS>2020-02-26T03:42:03</ReceivedTS>
<SkipValidation>true</SkipValidation>
<BatchID />
<Action>EMPLUPD</Action>
<ProcessType>generic</ProcessType>
<CorrelationID>59637-update</CorrelationID>
<ProcessingInstanceID>061b2b42-64c1-4a06-98de-f297949e4c06</ProcessingInstanceID>
<RetryCount>1</RetryCount>
<PreventResubmissionInd>true</PreventResubmissionInd>
</EmployeeHeader>
<ns0:NewHire>
<ns0:TypeOfHire xmlns:xsi="http://www.w3.org/2001/XMLSchemainstance">
<ns0:NonStandardValue>E_EMPLUPD</ns0:NonStandardValue>
</ns0:TypeOfHire>
<ns0:EmployeeInfo xmlns:xsi="http://www.w3.org/2001/XMLSchemainstance">
<ns0:PersonName>
<ns0:GivenName>some</ns0:GivenName>
<ns0:PreferredGivenName />
<ns0:FamilyName>newone</ns0:FamilyName>
<ns0:MiddleName />
<ns0:Affix type="salutation" />
</ns0:PersonName>
<IBKT_SYSID_PK xmlns:xsi="http://www.w3.org/2001/XMLSchemainstance">1234</IBKT_SYSID_PK>
</ns0:NewHire>
</ns1:Employee>
编排内部使用的 Xpath:
sIBKTSysIDPK = xpath(msgEmployeeIn.msgEmployeeIn, "string(/*[local-name()='Employee' and namespace-uri()='http://Common_Employee_Schemas.Employee']/*[local-name()='NewHire' and namespace-uri()='http://ns.hr-xml.org/2007-04-15']/*[local-name()='IBKT_SYSID_PK' and namespace-uri()='http://www.w3.org/2001/XMLSchemainstance'][1])");
字段 sIBKTSysIDPK returns 每次都是空的。需要获取其值 1234 并将其存储在变量中。
你的 Xpath 不太正确IBKT_SYSID_PK 有一个空命名空间(没有命名空间前缀),所以正确的 Xpath 是
/*[local-name()='KellyEmployee' and namespace-uri()='http://ECI.KellyCommon_Employee_Schemas.KellyEmployee']/*[local-name()='NewHire' and namespace-uri()='http://ns.hr-xml.org/2007-04-15']/*[local-name()='IBKT_SYSID_PK' and namespace-uri()=''][1]
所以你的代码应该是
sIBKTSysIDPK = xpath(msgKellyEmployeeIn.msgKellyEmployeeIn, "string(/*[local-name()='KellyEmployee' and namespace-uri()='http://ECI.KellyCommon_Employee_Schemas.KellyEmployee']/*[local-name()='NewHire' and namespace-uri()='http://ns.hr-xml.org/2007-04-15']/*[local-name()='IBKT_SYSID_PK' and namespace-uri()=''][1])");
我在 BizTalk 中有一条员工消息。在编排中,我试图获取字段的值 (IBKT_SYSID_PK) 但它返回的是空值。请协助。
员工留言:
<ns1:Employee xmlns:ns2="http://purl.org/dc/elements/1.1/" xmlns:ns3="http://www.w3.org/XML/1998/namespace" xmlns:ns4="http://www.w3.org/2000/09/xmldsig#">
<EmployeeHeader>
<State>tobeProcessedbySubOrch</State>
<GUID>4a569a18-5b6a-4b90-9c0c-324cbdcf78e8</GUID>
<EmployeeStatus>update</EmployeeStatus>
<Vendor>A</Vendor>
<Destination>K</Destination>
<Errors>
<ErrorType>Business</ErrorType>
<ErrorCorrection />
<Error><FldName>EMPL-59637</FldName><Code>302</Code><Msg>Modified Date Mismatch, data might be out of sync between K and A</Msg></Error></Errors>
<ErrorInd>true</ErrorInd>
<WarningInd>false</WarningInd>
<TransactionID>40047965</TransactionID>
<LogicalKey>59637</LogicalKey>
<ReceivedTS>2020-02-26T03:42:03</ReceivedTS>
<SkipValidation>true</SkipValidation>
<BatchID />
<Action>EMPLUPD</Action>
<ProcessType>generic</ProcessType>
<CorrelationID>59637-update</CorrelationID>
<ProcessingInstanceID>061b2b42-64c1-4a06-98de-f297949e4c06</ProcessingInstanceID>
<RetryCount>1</RetryCount>
<PreventResubmissionInd>true</PreventResubmissionInd>
</EmployeeHeader>
<ns0:NewHire>
<ns0:TypeOfHire xmlns:xsi="http://www.w3.org/2001/XMLSchemainstance">
<ns0:NonStandardValue>E_EMPLUPD</ns0:NonStandardValue>
</ns0:TypeOfHire>
<ns0:EmployeeInfo xmlns:xsi="http://www.w3.org/2001/XMLSchemainstance">
<ns0:PersonName>
<ns0:GivenName>some</ns0:GivenName>
<ns0:PreferredGivenName />
<ns0:FamilyName>newone</ns0:FamilyName>
<ns0:MiddleName />
<ns0:Affix type="salutation" />
</ns0:PersonName>
<IBKT_SYSID_PK xmlns:xsi="http://www.w3.org/2001/XMLSchemainstance">1234</IBKT_SYSID_PK>
</ns0:NewHire>
</ns1:Employee>
编排内部使用的 Xpath:
sIBKTSysIDPK = xpath(msgEmployeeIn.msgEmployeeIn, "string(/*[local-name()='Employee' and namespace-uri()='http://Common_Employee_Schemas.Employee']/*[local-name()='NewHire' and namespace-uri()='http://ns.hr-xml.org/2007-04-15']/*[local-name()='IBKT_SYSID_PK' and namespace-uri()='http://www.w3.org/2001/XMLSchemainstance'][1])");
字段 sIBKTSysIDPK returns 每次都是空的。需要获取其值 1234 并将其存储在变量中。
你的 Xpath 不太正确IBKT_SYSID_PK 有一个空命名空间(没有命名空间前缀),所以正确的 Xpath 是
/*[local-name()='KellyEmployee' and namespace-uri()='http://ECI.KellyCommon_Employee_Schemas.KellyEmployee']/*[local-name()='NewHire' and namespace-uri()='http://ns.hr-xml.org/2007-04-15']/*[local-name()='IBKT_SYSID_PK' and namespace-uri()=''][1]
所以你的代码应该是
sIBKTSysIDPK = xpath(msgKellyEmployeeIn.msgKellyEmployeeIn, "string(/*[local-name()='KellyEmployee' and namespace-uri()='http://ECI.KellyCommon_Employee_Schemas.KellyEmployee']/*[local-name()='NewHire' and namespace-uri()='http://ns.hr-xml.org/2007-04-15']/*[local-name()='IBKT_SYSID_PK' and namespace-uri()=''][1])");