Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/spring/14.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
Java 使用MUX为所有传入请求创建另一个自定义打包程序。我发出的请求没有问题_Java_Spring_Iso8583_Jpos_Iso8583 1993 - Fatal编程技术网

Java 使用MUX为所有传入请求创建另一个自定义打包程序。我发出的请求没有问题

Java 使用MUX为所有传入请求创建另一个自定义打包程序。我发出的请求没有问题,java,spring,iso8583,jpos,iso8583-1993,Java,Spring,Iso8583,Jpos,Iso8583 1993,我有一个发送和接收iso消息的jpos实现。它首先需要登录,然后再做其他事情。 作为一个客户端,我能够发送请求(customized.xml packager)并成功接收响应,没有任何问题 但是,当另一方向我发送请求时,同一个打包程序(customized.xml packager)无法解包收到的请求 为了尝试解决传入请求的问题,我决定创建一个新的定制打包程序(customized2.xml),但我注意到所有传入请求仍然引用旧的打包程序(customized.xml)。 我该如何处理这个问题,或

我有一个发送和接收iso消息的jpos实现。它首先需要登录,然后再做其他事情。 作为一个客户端,我能够发送请求(customized.xml packager)并成功接收响应,没有任何问题

但是,当另一方向我发送请求时,同一个打包程序(customized.xml packager)无法解包收到的请求

为了尝试解决传入请求的问题,我决定创建一个新的定制打包程序(customized2.xml),但我注意到所有传入请求仍然引用旧的打包程序(customized.xml)。 我该如何处理这个问题,或者最好的做法是什么

我的配置:

10_mychannel.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <channel-adaptor name="mychannel-channel" logger="Q2">
       <channel class="org.jpos.iso.channel.ASCIIChannel" type="client" connect="yes" logger="Q2" realm="post-channel" packager="org.jpos.iso.packager.GenericPackager">
          <property name="packager-config" value="cfg/customized.xml" />
          <property name="packager-logger" value="Q2" />
          <property name="packager-realm" value="custom-packager" />
          <property name="host" value="14.101.333.111" />
          <property name="port" value="7777" />
          <property name="length-digits" value="6" />
          <property name="connection-timeout" value="30000" />
          <property name="timeout" value="300000" />
       </channel>
       <in>my-channel-send</in>
      <out>my-channel-receive</out>
       <reconnect-delay>10000</reconnect-delay>
       <keep-alive>yes</keep-alive>
    </channel-adaptor>

我认为XMLChannel不能与GenericPackager一起使用。也许您也希望在该服务器上使用ASCIIChannel。谢谢您。您好,Andres,谢谢您的支持和时间。我已按照建议将通用打包程序从XMLChannel更新为ASCIIChannel。我还将记录器添加到打包机,并更正了一些需要修复的字段。我已要求第三方启动新请求。我将回复结果状态。我已获得第三方发送新请求。启用logger属性后,我现在可以看到传入的ISO请求,但不幸的是,我的侦听器类没有选择要处理的消息。我已经按照建议更新了频道和服务器xml。我认为XMLChannel与GenericPackager不兼容。也许您也希望在该服务器上使用ASCIIChannel。谢谢您。您好,Andres,谢谢您的支持和时间。我已按照建议将通用打包程序从XMLChannel更新为ASCIIChannel。我还将记录器添加到打包机,并更正了一些需要修复的字段。我已要求第三方启动新请求。我将回复结果状态。我已获得第三方发送新请求。启用logger属性后,我现在可以看到传入的ISO请求,但不幸的是,我的侦听器类没有选择要处理的消息。我已按照建议更新了频道和服务器xml。
    <mux class="org.jpos.q2.iso.QMUX" logger="Q2" name="my-mux">
    <in>my-channel-receive</in>
    <out>my-channel-send</out>
    <ready>my-channel.ready</ready>
    </mux>
    <qbean name='LogonManager' class='com.my.processor.LogonManager' />
    <server class="org.jpos.q2.iso.QServer" logger="Q2" name="xml-server-7777" realm="xml-server-7777">
      <attr name="port" type="java.lang.Integer">7777</attr>
      <channel class="org.jpos.iso.channel.ASCIIChannel" packager="org.jpos.iso.packager.GenericPackager" type="server" logger="Q2" realm="xml-server-7777">
      <property name="packager-config" value="cfg/customized2.xml" />
      <property name="timeout" value="180000"/>
      </channel>
      <request-listener class="com.my.processor.myListener" logger="Q2" realm="incoming-request-listener" />
    </server>
    public class myListener implements ISORequestListener{

        private static final String FTREQUEST = "1200";
        private static final String REVADVICE = "1420";
        private static final String NETWORKREQ = "1804";

        Log log1;

        @Override
        public boolean process(ISOSource source, ISOMsg m) {
            System.out.println("::::: Waiting :::::");
            log.info("::::: Inside  Listener :::::");
            try {
                String mti = m.getMTI();
                System.out.println("mti ::: " + mti);
                log.info("mti ::: " + mti);
                switch (mti) {
                    case FTREQUEST:
                        log.info("Inside Financial Transaction Request");
                        //implementation here 

                        m.setMTI("1210");
                        m.set(2, m.getString(2));
                        m.set(3, m.getString(3));
                        m.set(4, m.getString(4));
                        m.set(11, m.getString(11));
                        m.set(12, m.getString(12));
                        m.set(39, "100");
                        source.send(m);

                        break;
                    case REVADVICE:
                        log.info("Reversal Advice");
                        break;
                    case NETWORKREQ:
                        log.info("Network Management Request");
                        break;
                }

            } catch (Exception ex) {
                ex.printStackTrace(System.out);
            }
            return true;
        }
    }