springboot整合weblogic jms实现异步消息发送和同步消息发送

项目背景1:网络分为外联网、内网。外联网不能直接请求内网,只能将请求以消息形式发送到jms server服务器上,内网去监听外联网的jms server服务器,实现内外网信息交互。同步
项目背景2:用户支付完成后,需要调用第三方系统(支付宝、微信等)接口,得到支付状态后进行操作。异步

废话不多说,直接撸他。。。。。。

  1. 安装weblogic,这个请自行百度。
  2. 部署jms服务器,请参看:https://blog.csdn.net/gxlstone/article/details/41378949
  3. springboot整合welobic jms代码
    3.1 本文参考了几个博主,感谢几位博主的贡献。因为只能填写一个转载地址,各位博主请不要介意。。。。
    慕课网spring整合activemq,代码基本类似:https://www.imooc.com/learn/856
    jms理论知识讲解:https://blog.csdn.net/zhangzikui/article/details/24837999
    weblogic jms的简单使用:https://blog.csdn.net/elim168/article/details/72674355
    jms的几种监听器区别:https://blog.csdn.net/zylzb/article/details/40511047

3.2 到这里正文开始,各位猿们,上菜。

pom.xml配置,一个jms的包,两个weblogic客户端的包。weblogic客户端的包请自行查看我发的以上博主的链接。

    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-jms</artifactId>
        <version>4.3.11.RELEASE</version>
    </dependency>

    <dependency>
        <groupId>wlfullclient</groupId>
        <artifactId>wlfullclient.jar</artifactId>
        <version>12c</version>
        <scope>system</scope>
        <systemPath>/worktools/apache-maven-jar/weblogic/wlfullclient.jar</systemPath>
    </dependency>
    <dependency>
        <groupId>wlclient</groupId>
        <artifactId>wlclient.jar</artifactId>
        <version>12c</version>
        <scope>system</scope>
        <systemPath>/worktools/apache-maven-jar/weblogic/wlclient.jar</systemPath>
    </dependency>

bean配置类

package com.alipay.tyzf.jms;

import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.jms.connection.CachingConnectionFactory;
import org.springframework.jms.core.JmsTemplate;
import org.springframework.jndi.JndiObjectFactoryBean;
import org.springframework.jndi.JndiTemplate;
import javax.jms.ConnectionFactory;
import java.util.Properties;

/**
 * @author HuRongHua
 * @describe
 * @date 2021/2/7 3:55 下午
 */
@Configuration
public class JsmConfig {

    @Bean
    public JndiTemplate jndiTemplate() {
        Properties properties = new Properties();
        properties.setProperty("java.naming.factory.initial", "weblogic.jndi.WLInitialContextFactory");
        properties.setProperty("java.naming.provider.url", "t3://localhost:7001");
        JndiTemplate jndiTemplate = new JndiTemplate();
        jndiTemplate.setEnvironment(properties);
        return jndiTemplate;
    }

    //weblogic jms提供的连接工厂
    @Bean
    public JndiObjectFactoryBean jmsConnectionFactory() {
        JndiObjectFactoryBean jndiObjectFactoryBean = new JndiObjectFactoryBean();
        //连接工厂的JNDI名
        jndiObjectFactoryBean.setJndiName("ConnectionFactoryJNDI-0");
        jndiObjectFactoryBean.setJndiTemplate(jndiTemplate());
        return jndiObjectFactoryBean;
    }

    //weblogic jms消息目的地
    @Bean("queueSend")
    public JndiObjectFactoryBean jmsQueue() {
        JndiObjectFactoryBean jndiObjectFactoryBean = new JndiObjectFactoryBean();
        //队列的JNDI名
        jndiObjectFactoryBean.setJndiName("DistributedQueueJNDI-0");
        jndiObjectFactoryBean.setJndiTemplate(jndiTemplate());
        return jndiObjectFactoryBean;
    }

    //spring提供的连接池
    public ConnectionFactory getcachingConnectionFactory(){
        CachingConnectionFactory connectionFactory=new CachingConnectionFactory();
        //将jms的连接池注入到spring的连接池中,由spring进行管理
        connectionFactory.setTargetConnectionFactory((ConnectionFactory) jmsConnectionFactory().getObject());
        return connectionFactory;
    }

    //jmsTemplate,消息发送器
    @Bean("jmsTemplate")
    @ConditionalOnMissingBean
    public JmsTemplate jmsTemplate() {
        JmsTemplate jmsTemplate = new JmsTemplate();
        //注入spring提供的连接池
        jmsTemplate.setConnectionFactory(getcachingConnectionFactory());
        //设置消息超时时间
        jmsTemplate.setReceiveTimeout(3000);
        return jmsTemplate;
    }
    
	//消息监听容器
    @Bean
    public DefaultMessageListenerContainer getWeblogicJsmSessionAwareConsumer(){
        DefaultMessageListenerContainer defaultMessageListenerContainer=new DefaultMessageListenerContainer();
        defaultMessageListenerContainer.setConnectionFactory(getcachingConnectionFactory());
        //消息监听器
        defaultMessageListenerContainer.setMessageListener(new JsmSessionAwareConsumer());
        //监听地址
        defaultMessageListenerContainer.setDestination((Destination) Objects.requireNonNull(jmsQueue().getObject()));
        //设置动态线程,加快获取速度
        defaultMessageListenerContainer.setConcurrency("2-4");
        return defaultMessageListenerContainer;
    }

}

外联网的生产者,CommonResult为前后台交互的类,可自行修改。

package com.alipay.tyzf.jms;

import com.alibaba.fastjson.JSONObject;
import com.alipay.tyzf.util.CommonResult;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jms.core.JmsTemplate;
import org.springframework.jms.core.MessageCreator;
import org.springframework.stereotype.Component;

import javax.jms.*;
import java.util.HashMap;

/**
 * @author HuRongHua
 * @describe
 * @date 2021/2/7 3:55 下午
 */
@Component
public class JsmProducer {

    private static JmsTemplate jmsTemplate;

    //消息目的地
    private static Queue destination;

    //使用构造方法注入,将bean注入到静态对象里
    @Autowired
    private JsmProducer(JmsTemplate jmsTemplate, Queue destination) {
        JsmProducer.jmsTemplate = jmsTemplate;
        JsmProducer.destination = destination;
    }

    //异步消息
    public void send(final String userinfo) throws JMSException {
        //发送异步消息
        jmsTemplate.send(destination,new MessageCreator() {
            @Override
            public Message createMessage(Session session) throws JMSException {
                return session.createTextMessage(userinfo);
            }
        });
    }

    //同步消息
    //因为内外网交互的类必须是一致,包括包名。所以采用HashMap传递,String接收
    public static CommonResult sendAndReceive(final HashMap mapInfo){
    	//该类是交互类,可自行定义
        CommonResult commonResult = new CommonResult();
        try {
            //发送同步消息
            Message message = jmsTemplate.sendAndReceive(destination,new MessageCreator() {
                @Override
                public Message createMessage(Session session) throws JMSException {
                    return session.createObjectMessage(mapInfo);
                }
            });
                String objectMessage = (String) ((ObjectMessage) message).getObject();
                commonResult = JSONObject.parseObject(objectMessage, CommonResult.class);
        } catch (JMSException e) {
            e.printStackTrace();
        }
        return commonResult;
    }

}

内网消息监听器,因为内网项目已经成型,无法进行改造,只能去适应它。onMessage监听方法中部分代码为业务操作,可自行舍弃。

package org.app.pay.inside.jms;

import com.alibaba.fastjson.JSON;
import org.app.pay.core.dto.RestResponse;
import org.app.pay.external.api.sbf.Sbf_Sy_Inf_Controller;
import org.app.pay.inside.dto.InPayDto;
import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.jms.listener.SessionAwareMessageListener;
import org.springframework.jms.support.JmsUtils;
import org.springframework.stereotype.Component;
import javax.jms.*;
import java.util.HashMap;

/**
 * @author HuRongHua
 * @describe
 * @date 2021/2/3 9:29 下午
 */
//监听外网发送的消息容器
public class JsmSessionAwareConsumer implements SessionAwareMessageListener<Message> {

    @Override
    public void onMessage(Message message, Session session) throws JMSException {
        ObjectMessage textMessage = (ObjectMessage) message;
        //接受外网发送的消息
        HashMap<String,String> mapInfo = (HashMap) textMessage.getObject();
        InPayDto inPayDto=new InPayDto();
        //组装请求信息
        inPayDto.setTran_id(mapInfo.get(""));
        inPayDto.setChannelId(mapInfo.get(""));
        inPayDto.setData(mapInfo.get(""));
        //获取公共请求类
        Inf_Controller service = SpringUtil.getBean(Inf_Controller.class);
        ObjectMessage response = null;
        try {
            //发起请求
            RestResponse restResponse = service.unpayment(inPayDto);
            //返回消息用string,外网用string去接受
            String strResq = JSON.toJSONString(restResponse);
            response = session.createObjectMessage(strResq);
        } catch (Exception e) {
            e.printStackTrace();
        }
        //建立消息消费者(需要返回信息),设置消息目的地
        MessageProducer producer = session.createProducer(message.getJMSReplyTo());
        assert response != null;
        //这一步是设置消息的id,不设置消息无法返回
        response.setJMSCorrelationID(message.getJMSCorrelationID());
        //返回消息
        producer.send(response);
        //关闭连接
        JmsUtils.closeMessageProducer(producer);
    }


    @Component
    public static class SpringUtil implements ApplicationContextAware {

        private static ApplicationContext applicationContext;

        //获取applicationContext
        public static ApplicationContext getApplicationContext() {
            return applicationContext;
        }

        //通过name获取 Bean.
        public static Object getBean(String name) {
            return getApplicationContext().getBean(name);
        }

        //通过class获取Bean
        public static <T> T getBean(Class<T> clazz) {
            return getApplicationContext().getBean(clazz);
        }

        //通过name,以及Clazz返回指定的Bean
        public static <T> T getBean(String name, Class<T> clazz) {
            return getApplicationContext().getBean(name, clazz);
        }

        @Override
        public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
            if (SpringUtil.applicationContext == null) {
                SpringUtil.applicationContext = applicationContext;
            }
        }
    }
}

使用方法:
异步消息发送:JsmProducer.send(String);
同步消息发送:JsmProducer.sendAndReceive(HashMap);

几个注意的点:

  1. 消息发送者和消息监听者交互的类必须为相同包路径+类名的类,且需要继承Serializable,不然会报错,因为消息发送和接收需要对消息进行序列化。本文交互的类为HashMap。
  2. 生产者和消费者发送的消息必须类型一致,如本文使用的消息类型ObjectMessage。还有其他几种请自行查看,若用的不一致,在接收到消息的时候就会报错。
  3. 本文使用的spring-jms版本为4.3.11.RELEASE,低版本的jms可能会没有jmsTemplate.sendAndReceive这个方法。

到这里springBoot整合weblogic jms就算结束了。

本文代码应该还有优化的地方,还请各位大佬留情。如果本文对大家有所帮助,帮忙点个赞,谢谢。。。。。

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot 是一种用于创建基于 Java 的独立、产品级的应用程序的框架。它提供了许多简化开发过程的特性,让开发者能够快速搭建应用程序。 在整合 Spring Boot 和 WebLogic JMS 时,我们可以通过以下步骤实现: 1. 添加依赖:在项目的 pom.xml 文件中,添加 WebLogic JMS 的依赖。可以使用 Maven 或 Gradle 等构建工具来管理依赖。 2. 配置连接工厂:在 application.properties 文件或 application.yml 文件中,配置 WebLogic JMS 的连接工厂信息。这些信息包括 WebLogic 服务器的地址、端口、用户名和密码等。 3. 配置 JMS 消息队列:通过编写代码或者配置文件的方式,创建 JMS 消息队列,以便应用程序可以向队列发送消息或从队列接收消息。 4. 编写发送和接收消息的代码:使用 Spring Boot 提供的 JmsTemplate 类来发送和接收消息JmsTemplate 提供了一些方便的方法,比如 send、convertAndSend、receive 等,可以简化与 JMS 的交互。 5. 启动应用程序:使用 Spring Boot 提供的嵌入式服务器,如 Tomcat 或 Jetty,来运行应用程序。可以使用命令行或 IDE 中的运行按钮来启动应用程序。 整合完成后,我们可以使用 Spring Boot 的自动配置功能来简化配置工作。同时,Spring Boot 还提供了一些监控和管理功能,可以帮助开发者更好地了解应用程序的运行状态,并进行故障诊断和性能优化。 总的来说,通过整合 Spring Boot 和 WebLogic JMS,我们可以更方便地开发和管理基于 JMS 的应用程序。这种整合可以帮助我们提高开发效率,并提供更好的用户体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值