Java 使用MUX为所有传入请求创建另一个自定义打包程序。我发出的请求没有问题
我有一个发送和接收iso消息的jpos实现。它首先需要登录,然后再做其他事情。 作为一个客户端,我能够发送请求(customized.xml packager)并成功接收响应,没有任何问题 但是,当另一方向我发送请求时,同一个打包程序(customized.xml packager)无法解包收到的请求 为了尝试解决传入请求的问题,我决定创建一个新的定制打包程序(customized2.xml),但我注意到所有传入请求仍然引用旧的打包程序(customized.xml)。 我该如何处理这个问题,或者最好的做法是什么 我的配置: 10_mychannel.xmlJava 使用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)。 我该如何处理这个问题,或
<?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;
}
}