GET_SEARCH_RESULTS webservice响应表示无效的QueryText

时间:2018-05-29 12:57:36

标签: xml web-services soa oracle-fusion-middleware oracle-ucm

在xml请求下方使用以获取UCM中文档的详细信息:

<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:ucm="http://www.oracle.com/UCM">
   <soapenv:Header/>
   <soapenv:Body>
      <ucm:GenericRequest webKey="cs"> <!-- Fixed value -->
         <ucm:Service IdcService="GET_SEARCH_RESULTS"><!--  -->

            <ucm:Document>
                <ucm:Field name="SearchEngineName">database</ucm:Field>

               <ucm:Field name="QueryText">dDocTitle &lt;contains&gt; 'Test' </ucm:Field>

            </ucm:Document>
         </ucm:Service>
      </ucm:GenericRequest>
   </soapenv:Body>
</soapenv:Envelope>

回复是:

    <env:Envelope xmlns:env="http://schemas.xmlsoap.org/soap/envelope/">
       <env:Header/>
       <env:Body>
          <ns2:GenericResponse xmlns:ns2="http://www.oracle.com/UCM">
             <ns2:Service IdcService="GET_SEARCH_RESULTS">
                <ns2:Document>
                   <ns2:Field name="StatusCode">-1</ns2:Field>
                   <ns2:Field name="IdcService">GET_SEARCH_RESULTS</ns2:Field>
                   <ns2:Field name="SortOrder">Desc</ns2:Field>
                   <ns2:Field name="SearchEngineIsDefault">1</ns2:Field>
                   <ns2:Field name="validateSearchQuery">false</ns2:Field>
                   <ns2:Field name="StatusMessageKey">!csUnableToRetrieveSearchResults!csSearchInvalidQueryText</ns2:Field>
                   <ns2:Field name="EnterpriseSearchMaxRows">4</ns2:Field>
                   <ns2:Field name="idcToken"/>
                   <ns2:Field name="FullRequest">&amp;QueryText=dDocTitle+%3ccontains%3e+%27Test%27&amp;SortField=dInDate&amp;SortOrder=Desc&amp;SearchEngineName=database</ns2:Field>
                   <ns2:Field name="localizedForResponse">1</ns2:Field>
                   <ns2:Field name="useOnlyLocalForDpTrigger">1</ns2:Field>
                   <ns2:Field name="SearchEngineName">database</ns2:Field>
                   <ns2:Field name="SortField">dInDate</ns2:Field>
                   <ns2:Field name="UnparsedQueryText">dDocTitle &lt;contains> 'Test'</ns2:Field>
                   <ns2:Field name="OriginalUnencodedQueryText">dDocTitle &lt;contains> 'Test'</ns2:Field>
                   <ns2:Field name="queryDefinitionLabel">DATABASE.METADATA.ORACLE</ns2:Field>
                   <ns2:Field name="ComputedSearchEngineName">DATABASE.METADATA</ns2:Field>
                   <ns2:Field name="OriginalQueryText">dDocTitle+%3ccontains%3e+%27Test%27</ns2:Field>
                   <ns2:Field name="refreshMonikers"/>
                   <ns2:Field name="refreshSubMonikers"/>
                   <ns2:Field name="changedMonikers"/>
                   <ns2:Field name="IsOracle">1</ns2:Field>
                   <ns2:Field name="StatusMessage">Unable to retrieve search results. The query text is invalid.</ns2:Field>
                   <ns2:Field name="QueryText">dDocTitle &lt;contains> 'Test'</ns2:Field>
                   <ns2:Field name="escapeReservedStringsInSearch">false</ns2:Field>

似乎xml转义不适用于&lt;符号。有什么理由不行吗?还是我错过了什么? 当QueryText只是“dDocTitle”时,代码工作,响应包含ucm中的文档的详细信息但是,过滤条件不起作用。

1 个答案:

答案 0 :(得分:0)

&lt;和&gt;可能是问题,但还有另一个问题 - 报价不正确。替换&#39; (撇号)在查询中带有`(后退)。