1

在 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 转义对 < 符号不起作用。有什么原因这不起作用吗?还是我错过了什么?当 QueryText 只是“dDocTitle”时,代码有效并且响应包含 ucm 中所有文档的详细信息,但是过滤条件不起作用。

4

1 回答 1

0

< 和 > 可能是问题所在,但还有另一个问题 - 引号不正确。在查询中将 '(撇号)替换为 `(反引号)。

于 2018-05-30T13:39:09.980 回答