Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/regex/19.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
错误处理在WSO2ESB中不起作用_Wso2_Wso2esb_Wso2dss - Fatal编程技术网

错误处理在WSO2ESB中不起作用

错误处理在WSO2ESB中不起作用,wso2,wso2esb,wso2dss,Wso2,Wso2esb,Wso2dss,我的配置如下: <?xml version="1.0" encoding="UTF-8"?> <proxy xmlns="http://ws.apache.org/ns/synapse" name="tReadingMobile" transports="https http" startOnLoad="true" trace="disable"> <description/> <tar

我的配置如下:

<?xml version="1.0" encoding="UTF-8"?>
<proxy xmlns="http://ws.apache.org/ns/synapse"
       name="tReadingMobile"
       transports="https http"
       startOnLoad="true"
       trace="disable">
   <description/>
   <target>
      <inSequence onError="fault">
         <property name="ouid"
                   expression="//WorkOUId//text()"
                   scope="default"
                   type="STRING"/>
         <property name="Time"
                   expression="get-property('SYSTEM_TIME')"
                   scope="default"
                   type="STRING"/>
         <property name="entrymode"
                   expression="//entrymode/text()"
                   scope="default"
                   type="STRING"/>
         <property name="deviceid"
                   expression="//DeviceId/text()"
                   scope="default"
                   type="STRING"/>
         <property name="partybranchid"
                   expression="//PartyBranchId/text()"
                   scope="default"
                   type="STRING"/>
         <property name="userid"
                   expression="//userid/text()"
                   scope="default"
                   type="STRING"/>
         <property name="ReadingDateTime"
                   expression="//ReadingDateTime/text()"
                   scope="default"
                   type="STRING"/>
         <property name="remarks"
                   expression="//Remarks/text()"
                   scope="default"
                   type="STRING"/>
         <property name="taskid"
                   expression="//TaskId/text()"
                   scope="default"
                   type="STRING"/>
         <property name="activityid"
                   expression="//activityid/text()"
                   scope="default"
                   type="STRING"/>
         <property name="assetid"
                   expression="//AssetId/text()"
                   scope="default"
                   type="STRING"/>
         <property name="parametersetid"
                   expression="//ParametersetId/text()"
                   scope="default"
                   type="STRING"/>
         <property name="Reading"
                   expression="//ReadingsLiteTaildto"
                   scope="default"
                   type="STRING"/>
         <enrich>
            <source clone="true" xpath="//ReadingsLiteTaildto"/>
            <target type="property" property="Reading"/>
         </enrich>
         <log level="custom">
            <property name="Reading" expression="get-property('Reading')"/>
         </log>
         <payloadFactory>
            <format>
               <p:insert_taction_operation xmlns:p="http://ws.wso2.org/dataservice">
                  <xs:ouid xmlns:xs="http://ws.wso2.org/dataservice">$1</xs:ouid>
                  <xs:biztransactiontypeid xmlns:xs="http://ws.wso2.org/dataservice">1</xs:biztransactiontypeid>
                  <xs:transactionnumber xmlns:xs="http://ws.wso2.org/dataservice">-1</xs:transactionnumber>
                  <xs:transactiondate xmlns:xs="http://ws.wso2.org/dataservice">$2</xs:transactiondate>
                  <xs:referencenumber xmlns:xs="http://ws.wso2.org/dataservice">-1</xs:referencenumber>
                  <xs:referencedate xmlns:xs="http://ws.wso2.org/dataservice">$3</xs:referencedate>
                  <xs:entrymode xmlns:xs="http://ws.wso2.org/dataservice">$4</xs:entrymode>
                  <xs:deviceid xmlns:xs="http://ws.wso2.org/dataservice">$5</xs:deviceid>
                  <xs:partybranchid xmlns:xs="http://ws.wso2.org/dataservice">$6</xs:partybranchid>
                  <xs:personid xmlns:xs="http://ws.wso2.org/dataservice">$7</xs:personid>
                  <xs:periodfrom xmlns:xs="http://ws.wso2.org/dataservice">$8</xs:periodfrom>
                  <xs:periodto xmlns:xs="http://ws.wso2.org/dataservice">$9</xs:periodto>
                  <xs:remarks xmlns:xs="http://ws.wso2.org/dataservice">$10</xs:remarks>
                  <xs:tags xmlns:xs="http://ws.wso2.org/dataservice">0</xs:tags>
                  <xs:status xmlns:xs="http://ws.wso2.org/dataservice">1</xs:status>
                  <xs:version xmlns:xs="http://ws.wso2.org/dataservice">0</xs:version>
                  <xs:createdbyid xmlns:xs="http://ws.wso2.org/dataservice">$11</xs:createdbyid>
                  <xs:createdon xmlns:xs="http://ws.wso2.org/dataservice">$12</xs:createdon>
                  <xs:modifiedbyid xmlns:xs="http://ws.wso2.org/dataservice">$13</xs:modifiedbyid>
                  <xs:modifiedon xmlns:xs="http://ws.wso2.org/dataservice">$14</xs:modifiedon>
               </p:insert_taction_operation>
            </format>
            <args>
               <arg expression="get-property('ouid')"/>
               <arg expression="get-property('Time')"/>
               <arg expression="get-property('Time')"/>
               <arg expression="get-property('entrymode')"/>
               <arg expression="get-property('deviceid')"/>
               <arg expression="get-property('partybranchid')"/>
               <arg expression="get-property('userid')"/>
               <arg expression="get-property('ReadingDateTime')"/>
               <arg expression="get-property('ReadingDateTime')"/>
               <arg expression="get-property('remarks')"/>
               <arg expression="get-property('userid')"/>
               <arg expression="get-property('ReadingDateTime')"/>
               <arg expression="get-property('userid')"/>
               <arg expression="get-property('ReadingDateTime')"/>
            </args>
         </payloadFactory>
         <send receive="tActionid_Seq">
            <endpoint>
               <address uri="http://localhost:9764/services/taction_DataService/"
                        format="soap11"/>
            </endpoint>
         </send>
      </inSequence>
      <outSequence onError="fault">
         <send/>
      </outSequence>
   </target>
</proxy>

$1
1.
-1
$2
-1
$3
$4
$5
$6
$7
$8
$9
$10
0
1.
0
$11
$12
$13
$14
我的序列文件是:

<?xml version="1.0" encoding="UTF-8"?>
<sequence xmlns="http://ws.apache.org/ns/synapse" name="tActionid_Seq" onError="fault">
   <property xmlns:ns="http://org.apache.synapse/xsd"
             xmlns:s="http://ws.wso2.org/dataservice"
             name="ActionID"
             expression="//s:actionid/text()"
             scope="default"
             type="STRING"/>
   <filter xmlns:ns="http://org.apache.synapse/xsd"
           xpath="get-property('taskid')='0' or get-property('taskid')='-1'">
      <then>
         <property name="actiontype" value="1"/>
      </then>
      <else>
         <property name="actiontype" value="0"/>
      </else>
   </filter>
   <log level="custom">
      <property xmlns:ns="http://org.apache.synapse/xsd"
                name="kk"
                expression="get-property('ActionID')"/>
   </log>
   <property xmlns:ns="http://org.apache.synapse/xsd"
             name="kk"
             expression="get-property('ActionID')"
             scope="default"
             type="STRING"/>
   <payloadFactory>
      <format>
         <p:insert_tactiondetail_operation xmlns:p="http://ws.wso2.org/dataservice">
            <xs:actionid xmlns:xs="http://ws.wso2.org/dataservice">$1</xs:actionid>
            <xs:slno xmlns:xs="http://ws.wso2.org/dataservice">1</xs:slno>
            <xs:actiontype xmlns:xs="http://ws.wso2.org/dataservice">$2</xs:actiontype>
            <xs:taskid xmlns:xs="http://ws.wso2.org/dataservice">$3</xs:taskid>
            <xs:partybranchid xmlns:xs="http://ws.wso2.org/dataservice">$4</xs:partybranchid>
            <xs:activityid xmlns:xs="http://ws.wso2.org/dataservice">$5</xs:activityid>
            <xs:assetid xmlns:xs="http://ws.wso2.org/dataservice">$6</xs:assetid>
            <xs:parametersetid xmlns:xs="http://ws.wso2.org/dataservice">$7</xs:parametersetid>
            <xs:actionstatus xmlns:xs="http://ws.wso2.org/dataservice">1</xs:actionstatus>
            <xs:reasonid xmlns:xs="http://ws.wso2.org/dataservice">-1</xs:reasonid>
            <xs:remarks xmlns:xs="http://ws.wso2.org/dataservice">$8</xs:remarks>
            <xs:periodfrom xmlns:xs="http://ws.wso2.org/dataservice">$9</xs:periodfrom>
            <xs:periodto xmlns:xs="http://ws.wso2.org/dataservice">$10</xs:periodto>
            <xs:duration xmlns:xs="http://ws.wso2.org/dataservice">0</xs:duration>
            <xs:alerts xmlns:xs="http://ws.wso2.org/dataservice">1</xs:alerts>
         </p:insert_tactiondetail_operation>
      </format>
      <args>
         <arg xmlns:ns="http://org.apache.synapse/xsd" expression="get-property('kk')"/>
         <arg xmlns:ns="http://org.apache.synapse/xsd"
              expression="get-property('actiontype')"/>
         <arg xmlns:ns="http://org.apache.synapse/xsd"
              expression="get-property('taskid')"/>
         <arg xmlns:ns="http://org.apache.synapse/xsd"
              expression="get-property('partybranchid')"/>
         <arg xmlns:ns="http://org.apache.synapse/xsd"
              expression="get-property('activityid')"/>
         <arg xmlns:ns="http://org.apache.synapse/xsd"
              expression="get-property('assetid')"/>
         <arg xmlns:ns="http://org.apache.synapse/xsd"
              expression="get-property('parametersetid')"/>
         <arg xmlns:ns="http://org.apache.synapse/xsd"
              expression="get-property('remarks')"/>
         <arg xmlns:ns="http://org.apache.synapse/xsd"
              expression="get-property('ReadingDateTime')"/>
         <arg xmlns:ns="http://org.apache.synapse/xsd"
              expression="get-property('ReadingDateTime')"/>
         <arg xmlns:ns="http://org.apache.synapse/xsd"
              expression="get-property('Message')"/>
      </args>
   </payloadFactory>
   <send receive="tActiondetailid_Seq">
      <endpoint>
         <address uri="http://localhost:9764/services/tactiondetail_DataService/"
                  format="soap11"/>
      </endpoint>
   </send>
</sequence> 

$1
1.
$2
$3
$4
$5
$6
$7
1.
-1
$8
$9
$10
0
1.
这是我的WSO2DSS

 <sql>INSERT INTO public.taction(ouid,biztransactiontypeid,transactionnumber,transactiondate,referencenumber,referencedate,entrymode,deviceid,partybranchid,personid,periodfrom,periodto,remarks,tags,status,version,createdbyid,createdon,modifiedbyid,modifiedon) VALUES(?,?,?,(SELECT TIMESTAMP WITH TIME ZONE 'epoch' + ?/1000 * INTERVAL '1 second'),?,(SELECT TIMESTAMP WITH TIME ZONE 'epoch' + ?/1000 * INTERVAL '1 second'),?,?,?,?,(SELECT TIMESTAMP WITH TIME ZONE 'epoch' + ?/1000 * INTERVAL '1 second'),(SELECT TIMESTAMP WITH TIME ZONE 'epoch' + ?/1000 * INTERVAL '1 second'),?,?,?,?,?,(SELECT TIMESTAMP WITH TIME ZONE 'epoch' + ?/1000 * INTERVAL '1 second'),?,(SELECT TIMESTAMP WITH TIME ZONE 'epoch' + ?/1000 * INTERVAL '1 second'))</sql>
      <result element="GeneratedKeys" rowName="Entry" useColumnNumbers="true">
         <element column="1" name="actionid" xsdType="BIGINT"/>
      </result>
      <param name="ouid" ordinal="1" sqlType="INTEGER"/>
      <param name="biztransactiontypeid" ordinal="2" sqlType="INTEGER"/>
      <param name="transactionnumber" ordinal="3" sqlType="STRING"/>
      <param name="transactiondate" ordinal="4" sqlType="BIGINT"/>
      <param name="referencenumber" ordinal="5" sqlType="STRING"/>
      <param name="referencedate" ordinal="6" sqlType="BIGINT"/>
      <param name="entrymode" ordinal="7" sqlType="SMALLINT"/>
      <param name="deviceid" ordinal="8" sqlType="INTEGER"/>
      <param name="partybranchid" ordinal="9" sqlType="INTEGER"/>
      <param name="personid" ordinal="10" sqlType="INTEGER"/>
      <param name="periodfrom" ordinal="11" sqlType="BIGINT"/>
      <param name="periodto" ordinal="12" sqlType="BIGINT"/>
      <param name="remarks" ordinal="13" sqlType="STRING"/>
      <param name="tags" ordinal="14" sqlType="STRING"/>
      <param name="status" ordinal="15" sqlType="SMALLINT"/>
      <param name="version" ordinal="16" sqlType="SMALLINT"/>
      <param name="createdbyid" ordinal="17" sqlType="INTEGER"/>
      <param name="createdon" ordinal="18" sqlType="BIGINT"/>
      <param name="modifiedbyid" ordinal="19" sqlType="INTEGER"/>
      <param name="modifiedon" ordinal="20" sqlType="BIGINT"/>
   </query>
   <query id="update_taction_query" useConfig="default">
插入public.taction(ouid、biztransactiontypeid、transactionnumber、transactiondate、referencenumber、referencedate、entrymode、deviceid、partybranchid、personid、periodfrom、periodto、备注、标记、状态、版本、createdbyid、createdon、modifiedbyid、modifiedon)值(?,(选择时区为“历元”+/1000*间隔为“1秒”)的时间戳,?,(选择带有时区“epoch”+?/1000*间隔“1秒”)的时间戳,,,,,,,,,,(选择带有时区“epoch”+?/1000*间隔“1秒”的时间戳,,(选择带有时区“epoch”+?/1000*间隔“1秒”的时间戳,,,,,,,,,,,(选择带有时区“epoch”+?/1000*间隔“1秒”的时间戳,?,(选择时区为“历元”+?/1000*间隔为“1秒”)的时间戳)

虽然我提供了正确的数据,但它仍在工作。但发生了一个无法处理的错误。我添加了默认的故障序列,但它不工作。请帮助我。

像这样尝试;向代理添加故障序列

 <target faultSequence="fault">


为什么所有的大写字母?听起来很粗鲁。thanx..回答很抱歉,我不清楚我可以按照你的建议在代理中添加两个目标..让mew知道我有点困惑。我的代理错误是错误-NativeWorkerPool Uncaught exception org.apache.axiom.om.OmeException:com.ctc.wstx.exc.wstParsingException:非法处理指令目标(“xml”);xml(不区分大小写)由规范保留。at[row,col{unknown source}]:[1167]如果dss中出现错误,如primarykey voilation,则故障不起作用。我们可以使用故障序列处理wso2esb中的wso2dss错误。否则,我们只能在wso2dss级别处理。请让我知道我不清楚。任何机构都知道这一点,我正在等待答案