基于JPos的消息交换系统
消息交换系统需求解读
消息交换系统不不是一个具体的业务系统,而是业务系统的运转的基础框架;
他的运转是体现在报文交换上的;
要定义一个可被不同业务系统使用的报文规范;
报文格式
报文内容参考ISO8583(87版),传输使用XML形式。为不和标准冲突,目前吧自定义域放在87版的自定义域里。
具体定义可参考schema.xls。
系统运转机制
基于JPos的消息交换系统是一个自管理的服务框架。
JPos作为消息平台十分灵活,为统一流程我们将设计一套网银专用的消息交换机制。
系统将建立3个层次,接入层、业务层、收单链路层;
每个层都是一或多个平等的组件,相互间可以通过Socket调用;
-
一个标准的组件由下列几个模块组成
- 服务器的工作机制
作为一个服务程序它在启动后将监控一个部署目录,不断扫描并发现所有的XML配置文件。如果发现有新增或改动,就会用XML生成组件并加载到注册机里。 - 消息交换流程
- 客户端把消息发送到组件服务
- 服务监听将接收到的消息转给入口通道
- 入口通道顺序执行被配置在这里的处理器
- 经过入口通道后消息被转给路由器
- 路由器根据配置域的为消息匹配一个出口通道
- 消息被转给出口通道
- 出口通道顺序执行配置在这里的处理器
- 消息被发送出去
配置文件
<!-- 服务监听 --><server
class="org.jpos.q2.iso.QServer"
logger="Q2"
name="module"> <attr
name="port"
type="java.lang.Integer">9031</attr> <!-- 入口通道 --> <channel
class="org.jpos.iso.channel.XMLChannel"
logger="Q2" packager="org.jpos.iso.packager.XMLPackager"> <!-- 入口通道内的处理器,如果不需要要也可以不配置 --> <!-- 方向incoming:匹配消息进入,outgoing:匹配消息返回--> <filter
class="com.example.jpos.client.TestFilter"
direction="incoming"> <property
name="fields"
value="0 2 3"/> </filter> </channel> <!-- 路由器 --> <!-- 这里是根据32域匹配出口通道 --> <request-listener
class="org.jpos.apps.qsp.Q2Router"
logger="Q2"> <router
switch="${32}==01"
type="mux"
bounce="true"
destination="out1"
timeout="30000"
/> <router
switch="${32}==02"
type="mux"
bounce="true"
destination="out2"
timeout="30000"
/> </request-listener></server> |
<!-- 出口通道需要用mux链接 --><mux
class="org.jpos.q2.iso.QMUX"
logger="Q2"
name="out1"> <in>receive</in> <out>send</out></mux><channel-adaptor
name="channeladaptor" class="org.jpos.q2.iso.ChannelAdaptor"
logger="Q2"> <!-- 出口通道 --> <channel
name="channel"
class="org.jpos.iso.channel.XMLChannel"
logger="Q2"
packager="org.jpos.iso.packager.XMLPackager"> <property
name="host"
value="localhost"
/> <property
name="port"
value="9051"
/> </channel> <in>send</in> <out>receive</out> <reconnect-delay>1000</reconnect-delay></channel-adaptor> |