`
eric_hwp
  • 浏览: 126955 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

ActiviteMQ分析

 
阅读更多

消息示例

1、ActiviteMQ消息有3种形式

 

JMS 公共

点对点域

发布/订阅域

ConnectionFactory

QueueConnectionFactory

TopicConnectionFactory

Connection

QueueConnection

TopicConnection

Destination

Queue

Topic

Session

QueueSession

TopicSession

MessageProducer

QueueSender

TopicPublisher

MessageConsumer

QueueReceiver

TopicSubscriber

(1)、点对点方式(point-to-point)

点 对点的消息发送方式主要建立在 Message Queue,Sender,reciever上,Message Queue 存贮消息,Sneder 发送消息,receive接收消息.具体点就是Sender Client发送Message Queue ,而 receiver Cliernt从Queue中接收消息和"发送消息已接受"到Quere,确认消息接收。消息发送客户端与接收客户端没有时间上的依赖,发送客户端可以在 任何时刻发送信息到Queue,而不需要知道接收客户端是不是在运行

(2)、发布/订阅 方式(publish/subscriber Messaging)

发 布/订阅方式用于多接收客户端的方式.作为发布订阅的方式,可能存在多个接收客户端,并且接收端客户端与发送客户端存在时间上的依赖。一个接收端只能接收 他创建以后发送客户端发送的信息。作为subscriber ,在接收消息时有两种方法,destination的receive方法,和实现message listener 接口的onMessage 方法。

2、ActiviteMQ接收和发送消息基本流程

image

发送消息的基本步骤:

(1)、创建连接使用的工厂类JMS ConnectionFactory

(2)、使用管理对象JMS ConnectionFactory建立连接Connection,并启动

(3)、使用连接Connection 建立会话Session

(4)、使用会话Session和管理对象Destination创建消息生产者MessageSender

(5)、使用消息生产者MessageSender发送消息

 

消息接收者从JMS接受消息的步骤

(1)、创建连接使用的工厂类JMS ConnectionFactory

(2)、使用管理对象JMS ConnectionFactory建立连接Connection,并启动

(3)、使用连接Connection 建立会话Session

(4)、使用会话Session和管理对象Destination创建消息接收者MessageReceiver

(5)、 使用消息接收者MessageReceiver接受消息,需要用setMessageListener将MessageListener接口绑定到 MessageReceiver消息接收者必须实现了MessageListener接口,需要定义onMessage事件方法。

 

 

五、 代码示例

在代码开始,我们先建一个project,在这个project中添加如下jar包

image

添加完jar包后就可以开始实际的代码工作了。

1、 使用JMS方式发送接收消息

消息发送者

package com.wsheng.mq.jms;
 
import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.DeliveryMode;
import javax.jms.Destination;
import javax.jms.MessageProducer;
import javax.jms.Session;
import javax.jms.TextMessage;
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;
 
/**
 * <b>function:</b> 消息发送者
 * @author Josh, Wang(Sheng)
 * @file MessageSender.java
 * @package com.wsheng.mq.jms
 * @project ActiveMQ-5.8
 * @email josh_wang23@hotmail.com
 * @version 1.0
 */
public class MessageSender {
 
    // 发送次数
    public static final int SEND_NUM = 5;
    // tcp 地址
    public static final String BROKER_URL = "tcp://localhost:61616";
    // 目标,在ActiveMQ管理员控制台创建 http://localhost:8161/admin/queues.jsp
    public static final String DESTINATION = "wsheng.mq.queue";
    
   
    public static void sendMessage(Session session, MessageProducer producer) throws Exception {
        for (int i = 0; i < SEND_NUM; i++) {
            String message = "发送消息第" + (i + 1) + "条";
            TextMessage text = session.createTextMessage(message);
            
            System.out.println(message);
            producer.send(text);
        }
    }
    
    public static void run() throws Exception {
        
        Connection connection = null;
        Session session = null;
        try {
            // 创建链接工厂
            ConnectionFactory factory = new ActiveMQConnectionFactory(ActiveMQConnection.DEFAULT_USER, ActiveMQConnection.DEFAULT_PASSWORD, BROKER_URL);
            // 通过工厂创建一个连接
            connection = factory.createConnection();
            // 启动连接
            connection.start();
            // 创建一个session会话
            session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
            // 创建一个消息队列
            Destination destination = session.createQueue(DESTINATION);
            // 创建消息制作者
            MessageProducer producer = session.createProducer(destination);
            // 设置持久化模式
            producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
            sendMessage(session, producer);
            // 提交会话
            session.commit();
            
        } catch (Exception e) {
            throw e;
        } finally {
            // 关闭释放资源
            if (session != null) {
                session.close();
            }
            if (connection != null) {
                connection.close();
            }
        }
    }
    
    public static void main(String[] args) throws Exception {
        MessageSender.run();
    }
}

 

接受者

package com.wsheng.mq.jms;
 
import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.Session;
import javax.jms.TextMessage;
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;
 
/**
 * <b>function:</b> 消息接收者
 * @author Josh, Wang(Sheng)
 * @file MessageSender.java
 * @package com.wsheng.mq.jms
 * @project ActiveMQ-5.8
 * @email josh_wang23@hotmail.com
 * @version 1.0
 */
public class MessageReceiver {
 
    // tcp 地址
    public static final String BROKER_URL = "tcp://localhost:61616";
    // 目标,在ActiveMQ管理员控制台创建 http://localhost:8161/admin/queues.jsp
    public static final String DESTINATION = "wsheng.mq.queue";
    
    
    public static void run() throws Exception {
        
        Connection connection = null;
        Session session = null;
        try {
            // 创建链接工厂
            ConnectionFactory factory = new ActiveMQConnectionFactory(ActiveMQConnection.DEFAULT_USER, ActiveMQConnection.DEFAULT_PASSWORD, BROKER_URL);
            // 通过工厂创建一个连接
            connection = factory.createConnection();
            // 启动连接
            connection.start();
            // 创建一个session会话
            session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
            // 创建一个消息队列
            Destination destination = session.createQueue(DESTINATION);
            // 创建消息制作者
            MessageConsumer consumer = session.createConsumer(destination);
            
            while (true) {
                // 接收数据的时间(等待) 100 ms
                Message message = consumer.receive(1000 * 100);
                
                TextMessage text = (TextMessage) message;
                if (text != null) {
                    System.out.println("接收:" + text.getText());
                } else {
                    break;
                }
            }
            
            // 提交会话
            session.commit();
            
        } catch (Exception e) {
            throw e;
        } finally {
            // 关闭释放资源
            if (session != null) {
                session.close();
            }
            if (connection != null) {
                connection.close();
            }
        }
    }
    
    public static void main(String[] args) throws Exception {
        MessageReceiver.run();
    }
}

 

2、 Queue队列方式发送点对点消息数据

发送方

packagecom.wsheng.mq.jms;
 
import javax.jms.DeliveryMode;
import javax.jms.MapMessage;
import javax.jms.Queue;
import javax.jms.QueueConnection;
import javax.jms.QueueConnectionFactory;
import javax.jms.QueueSession;
import javax.jms.Session;
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;
 
/**
 * <b>function:</b> Queue 方式消息发送者
 * @author Josh, Wang(Sheng)
 * @file MessageSender.java
 * @package com.wsheng.mq.jms
 * @project ActiveMQ-5.8
 * @email josh_wang23@hotmail.com
 * @version 1.0
 */
public class QueueSender {
    
    // 发送次数
    public static final int SEND_NUM = 5;
    // tcp 地址
    public static final String BROKER_URL = "tcp://localhost:61616";
    // 目标,在ActiveMQ管理员控制台创建 http://localhost:8161/admin/queues.jsp
    public static final String DESTINATION = "wsheng.mq.queue";
    
    /**
     * <b>function:</b> 发送消息
     * @createDate 2013-6-19 下午12:05:42
     * @param session
     * @param sender
     * @throws Exception
     */    
    public static void sendMessage(QueueSession session, javax.jms.QueueSender sender) throws Exception {
        for (int i = 0; i < SEND_NUM; i++) {
            String message = "发送消息第" + (i + 1) + "条";
            
            MapMessage map = session.createMapMessage();
            map.setString("text", message);
            map.setLong("time", System.currentTimeMillis());
            System.out.println(map);
            
            sender.send(map);
        }
    }
    
    public static void run() throws Exception {
        
        QueueConnection connection = null;
        QueueSession session = null;
        try {
            // 创建链接工厂
            QueueConnectionFactory factory = new ActiveMQConnectionFactory(ActiveMQConnection.DEFAULT_USER, ActiveMQConnection.DEFAULT_PASSWORD, BROKER_URL);
            // 通过工厂创建一个连接
            connection = factory.createQueueConnection();
            // 启动连接
            connection.start();
            // 创建一个session会话
            session = connection.createQueueSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
            // 创建一个消息队列
            Queue queue = session.createQueue(DESTINATION);
            // 创建消息发送者
            javax.jms.QueueSender sender = session.createSender(queue);
            // 设置持久化模式
            sender.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
            sendMessage(session, sender);
            // 提交会话
            session.commit();
            
        } catch (Exception e) {
            throw e;
        } finally {
            // 关闭释放资源
            if (session != null) {
                session.close();
            }
            if (connection != null) {
                connection.close();
            }
        }
    }
    
    public static void main(String[] args) throws Exception {
        QueueSender.run();
    }
}

接收方

package com.wsheng.mq.queue;
 
import javax.jms.JMSException;
import javax.jms.MapMessage;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.Queue;
import javax.jms.QueueConnection;
import javax.jms.QueueConnectionFactory;
import javax.jms.QueueSession;
import javax.jms.Session;
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;
 
/**
 * <b>function:</b> 消息接收者; 依赖hawtbuf-1.9.jar
 * @author Josh, Wang(Sheng)
 * @file MessageSender.java
 * @package ccom.wsheng.mq.queue
 * @project ActiveMQ-5.8
 * @email josh_wang23@hotmail.com
 * @version 1.0
 */
public class QueueReceiver {
 
    // tcp 地址
    public static final String BROKER_URL = "tcp://localhost:61616";
    // 目标,在ActiveMQ管理员控制台创建 http://localhost:8161/admin/queues.jsp
    public static final String TARGET = "wsheng.mq.queue";
    
    
    public static void run() throws Exception {
        
        QueueConnection connection = null;
        QueueSession session = null;
        try {
            // 创建链接工厂
            QueueConnectionFactory factory = new ActiveMQConnectionFactory(ActiveMQConnection.DEFAULT_USER, ActiveMQConnection.DEFAULT_PASSWORD, BROKER_URL);
            // 通过工厂创建一个连接
            connection = factory.createQueueConnection();
            // 启动连接
            connection.start();
            // 创建一个session会话
            session = connection.createQueueSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
            // 创建一个消息队列
            Queue queue = session.createQueue(TARGET);
            // 创建消息制作者
            javax.jms.QueueReceiver receiver = session.createReceiver(queue);
            
            receiver.setMessageListener(new MessageListener() { 
                public void onMessage(Message msg) { 
                    if (msg != null) {
                        MapMessage map = (MapMessage) msg;
                        try {
                            System.out.println(map.getLong("time") + "接收#" + map.getString("text"));
                        } catch (JMSException e) {
                            e.printStackTrace();
                        }
                    }
                } 
            }); 
            // 休眠100ms再关闭
            Thread.sleep(1000 * 100); 
            
            // 提交会话
            session.commit();
            
        } catch (Exception e) {
            throw e;
        } finally {
            // 关闭释放资源
            if (session != null) {
                session.close();
            }
            if (connection != null) {
                connection.close();
            }
        }
    }
    
    public static void main(String[] args) throws Exception {
        QueueReceiver.run();
    }
}

 

3、 Topic主题发布和订阅消息

消息发送方

package com.wsheng.mq.topic;
 
import javax.jms.DeliveryMode;
import javax.jms.MapMessage;
import javax.jms.Session;
import javax.jms.Topic;
import javax.jms.TopicConnection;
import javax.jms.TopicConnectionFactory;
import javax.jms.TopicPublisher;
import javax.jms.TopicSession;
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;
 
 
/**
 * <b>function:</b> Queue 方式消息发送者
 * @author Josh, Wang(Sheng)
 * @file MessageSender.java
 * @package com.wsheng.mq.jms
 * @project ActiveMQ-5.8
 * @email josh_wang23@hotmail.com
 * @version 1.0
 */
public class TopicSender {
    
    // 发送次数
    public static final int SEND_NUM = 5;
    // tcp 地址
    public static final String BROKER_URL = "tcp://localhost:61616";
    // 目标,在ActiveMQ管理员控制台创建 http://localhost:8161/admin/queues.jsp
    public static final String DESTINATION = "wsheng.mq.topic";
    
    /**
     * <b>function:</b> 发送消息
     * @author Josh, Wang(Sheng)
     * @createDate 2013-6-19 下午12:05:42
     * @param session 会话
     * @param publisher 发布者
     * @throws Exception
     */    
    public static void sendMessage(TopicSession session, TopicPublisher publisher) throws Exception {
        for (int i = 0; i < SEND_NUM; i++) {
            String message = "发送消息第" + (i + 1) + "条";
            
            MapMessage map = session.createMapMessage();
            map.setString("text", message);
            map.setLong("time", System.currentTimeMillis());
            System.out.println(map);
            
            publisher.send(map);
        }
    }
    
    public static void run() throws Exception {
        
        TopicConnection connection = null;
        TopicSession session = null;
        try {
            // 创建链接工厂
            TopicConnectionFactory factory = new ActiveMQConnectionFactory(ActiveMQConnection.DEFAULT_USER, ActiveMQConnection.DEFAULT_PASSWORD, BROKER_URL);
            // 通过工厂创建一个连接
            connection = factory.createTopicConnection();
            // 启动连接
            connection.start();
            // 创建一个session会话
            session = connection.createTopicSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
            // 创建一个消息队列
            Topic topic = session.createTopic(DESTINATION);
            // 创建消息发送者
            TopicPublisher publisher = session.createPublisher(topic);
            // 设置持久化模式
            publisher.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
            sendMessage(session, publisher);
            // 提交会话
            session.commit();
            
        } catch (Exception e) {
            throw e;
        } finally {
            // 关闭释放资源
            if (session != null) {
                session.close();
            }
            if (connection != null) {
                connection.close();
            }
        }
    }
    
    public static void main(String[] args) throws Exception {
        TopicSender.run();
    }
}

接收方

package com.wsheng.mq.topic;
 
import javax.jms.JMSException;
import javax.jms.MapMessage;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.Session;
import javax.jms.Topic;
import javax.jms.TopicConnection;
import javax.jms.TopicConnectionFactory;
import javax.jms.TopicSession;
import javax.jms.TopicSubscriber;
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;
 
/**
 * <b>function:</b> 消息接收者; 依赖hawtbuf-1.9.jar
 * @author Josh, Wang(Sheng)
 * @file MessageSender.java
 * @package com.wsheng.mq.jms
 * @project ActiveMQ-5.8
 * @email josh_wang23@hotmail.com
 * @version 1.0
 */
public class TopicReceiver {
 
    // tcp 地址
    public static final String BROKER_URL = "tcp://localhost:61616";
    // 目标,在ActiveMQ管理员控制台创建 http://localhost:8161/admin/queues.jsp
    public static final String TARGET = "wsheng.mq.topic";
    
    
    public static void run() throws Exception {
        
        TopicConnection connection = null;
        TopicSession session = null;
        try {
            // 创建链接工厂
            TopicConnectionFactory factory = new ActiveMQConnectionFactory(ActiveMQConnection.DEFAULT_USER, ActiveMQConnection.DEFAULT_PASSWORD, BROKER_URL);
            // 通过工厂创建一个连接
            connection = factory.createTopicConnection();
            // 启动连接
            connection.start();
            // 创建一个session会话
            session = connection.createTopicSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
            // 创建一个消息队列
            Topic topic = session.createTopic(TARGET);
            // 创建消息制作者
            TopicSubscriber subscriber = session.createSubscriber(topic);
            
            subscriber.setMessageListener(new MessageListener() { 
                public void onMessage(Message msg) { 
                    if (msg != null) {
                        MapMessage map = (MapMessage) msg;
                        try {
                            System.out.println(map.getLong("time") + "接收#" + map.getString("text"));
                        } catch (JMSException e) {
                            e.printStackTrace();
                        }
                    }
                } 
            }); 
            // 休眠100ms再关闭
            Thread.sleep(1000 * 100); 
            
            // 提交会话
            session.commit();
            
        } catch (Exception e) {
            throw e;
        } finally {
            // 关闭释放资源
            if (session != null) {
                session.close();
            }
            if (connection != null) {
                connection.close();
            }
        }
    }
    
    public static void main(String[] args) throws Exception {
        TopicReceiver.run();
    }
}

 

4、 整合Spring实现消息发送和接收,在整合之前我们需要添加jar包,需要的jar包如下

image

这些jar包可以在D:\apache-activemq-5.8.0\lib这个lib目录中找到,添加完jar包后就开始编码工作。

消息发送者

package com.wsheng.mq.spring.support;
 
import java.util.Date;
import javax.jms.JMSException;
import javax.jms.MapMessage;
import javax.jms.Message;
import javax.jms.Session;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.FileSystemXmlApplicationContext;
import org.springframework.jms.core.JmsTemplate;
import org.springframework.jms.core.MessageCreator;
 
/**
 * <b>function:</b> Spring JMSTemplate 消息发送者
 * @author Josh, Wang(Sheng)
 * @file MessageSender.java
 * @package com.wsheng.mq.jms
 * @project ActiveMQ-5.8
 * @email josh_wang23@hotmail.com
 * @version 1.0
 */
public class Sender {
 
    public static void main(String[] args) {
        ApplicationContext ctx = new FileSystemXmlApplicationContext("classpath:applicationContext-*.xml");
        JmsTemplate jmsTemplate = (JmsTemplate) ctx.getBean("jmsTemplate");
 
        jmsTemplate.send(new MessageCreator() {
            public Message createMessage(Session session) throws JMSException {
                MapMessage message = session.createMapMessage();
                message.setString("message", "current system time: " + new Date().getTime());
                
                return message;
            }
        });
    }
}

消息接收者

package com.wsheng.mq.spring.support;
 
import java.util.Map;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.FileSystemXmlApplicationContext;
import org.springframework.jms.core.JmsTemplate;
 
/**
 * <b>function:</b> Spring JMSTemplate 消息接收者
 * @author Josh, Wang(Sheng)
 * @file MessageSender.java
 * @package com.wsheng.mq.jms
 * @project ActiveMQ-5.8
 * @email josh_wang23@hotmail.com
 * @version 1.0
 */
public class Receiver {
 
    @SuppressWarnings("unchecked")
    public static void main(String[] args) {
        ApplicationContext ctx = new FileSystemXmlApplicationContext("classpath:applicationContext-*.xml");  
          
        JmsTemplate jmsTemplate = (JmsTemplate) ctx.getBean("jmsTemplate");  
        while(true) {  
            Map<String, Object> map =  (Map<String, Object>) jmsTemplate.receiveAndConvert();  
            
            System.out.println("收到消息:" + map.get("message"));  
        }  
    }
}

这里主要是用到了JmsTemplate这个消息模板,这个对象在spring的IoC容器中管理,所以要从spring的容器上下文中获取。下面看看spring的配置文件applicationContext-beans.xml内容:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://www.springframework.org/schema/beans 
    http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
    http://www.springframework.org/schema/context
    http://www.springframework.org/schema/context/spring-context-3.1.xsd">
    
    <!-- 连接池  -->
    <bean id="pooledConnectionFactory" class="org.apache.activemq.pool.PooledConnectionFactory" destroy-method="stop">  
        <property name="connectionFactory">  
            <bean class="org.apache.activemq.ActiveMQConnectionFactory">  
                <property name="brokerURL" value="tcp://localhost:61616" />  
            </bean>  
        </property>  
    </bean>  
      
    <!-- 连接工厂 -->
    <bean id="activeMQConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">  
        <property name="brokerURL" value="tcp://localhost:61616" />  
    </bean>  
    
    <!-- 配置消息目标 -->
    <bean id="destination" class="org.apache.activemq.command.ActiveMQQueue">  
        <!-- 目标,在ActiveMQ管理员控制台创建 http://localhost:8161/admin/queues.jsp -->
        <constructor-arg index="0" value="wsheng.mq.queue" />  
    </bean>  
 
    <!-- 消息模板 -->
    <bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate">  
        <property name="connectionFactory" ref="activeMQConnectionFactory" />  
        <property name="defaultDestination" ref="destination" />  
        <property name="messageConverter">  
            <bean class="org.springframework.jms.support.converter.SimpleMessageConverter" />
        </property>  
    </bean>  
</beans>

这里的整合就比较简单了,如果你是web工程,那你在需要用jms的时候,只需用注入jmsTemplate即可。

 

分享到:
评论

相关推荐

    activiteMq

    在“activiteMq”这个主题中,我们主要关注如何将ActiveMQ与Spring框架进行整合,以实现高效的消息通信。首先,我们需要理解以下关键概念: 1. **JMS(Java Message Service)**:JMS是Java平台中用于处理消息的...

    MQ文件传输.rar

    IBM MQ,全称为IBM WebSphere MQ,是一种企业级的消息中间件,它允许应用程序之间通过网络进行可靠的消息交换,尤其在处理大文件传输时表现出色。本文将深入探讨IBM MQ在大文件传输中的应用、工作原理以及相关的编程...

    ActiveMQ JDBC集群总结

    ### ActiveMQ JDBC 集群总结 #### 一、ActiveMQ版本及环境信息 - **ActiveMQ 版本**:5.9.0 - **安装环境**:JDK 1.6,Linux 操作系统,MySQL 5.6 - **服务器信息**: - 服务器1:IP地址 192.168.1.188 ...

    AIMP2 .NET 互操作插件

    AIMP2 .NET 互操作插件允许使用托管代码(C#、VB 等)为 AIMP2 编写插件。

    工厂垂直提升机sw14可编辑全套技术资料100%好用.zip

    工厂垂直提升机sw14可编辑全套技术资料100%好用.zip

    ssm-vue-智慧城市实验室主页系统-源码工程-32页从零开始全套图文详解-34页参考论文-27页参考答辩-全套开发环境工具、文档模板、电子教程、视频教学资源.zip

    资源说明: 1:csdn平台资源详情页的文档预览若发现'异常',属平台多文档混合解析和叠加展示风格,请放心使用。 2:32页图文详解文档(从零开始项目全套环境工具安装搭建调试运行部署,保姆级图文详解)。 3:34页范例参考毕业论文,万字长文,word文档,支持二次编辑。 4:27页范例参考答辩ppt,pptx格式,支持二次编辑。 5:工具环境、ppt参考模板、相关教程资源分享。 6:资源项目源码均已通过严格测试验证,保证能够正常运行,本项目仅用作交流学习参考,请切勿用于商业用途。 7:项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通。 内容概要: 本系统基于 B/S 网络结构,在IDEA中开发。服务端用 Java 并借 ssm 框架(Spring+SpringMVC+MyBatis)搭建后台。前台采用支持 HTML5 的 VUE 框架。用 MySQL 存储数据,可靠性强。 能学到什么: 学会用ssm搭建后台,提升效率、专注业务。学习 VUE 框架构建交互界面、前后端数据交互、MySQL管理数据、从零开始环境搭建、调试、运行、打包、部署流程。

    安卓开发-连连看小游戏Android-作业-设计-Android studio

    这是一款基于Android studio开发的连连看小游戏,使用了动物之森作为主题。 主要实现的功能有: 难度设置 打乱重排 排行榜 背景音乐和消除音效 主要应用的技术: fragment 事件处理 选项菜单 自定义view Java反射 handler 广播的发送与接收 多线程 preference SQLite

    微电网 能量优化管理 电力系统 微电网能源管理优化 微电网的能源管理优化模型,考虑了各种可再生能源、能量存储和碳捕集技术,以最小化运行成本,同时满足电力和热能需求 该优化模型有助于做出微电网组件的

    微电网 能量优化管理 电力系统 微电网能源管理优化。 微电网的能源管理优化模型,考虑了各种可再生能源、能量存储和碳捕集技术,以最小化运行成本,同时满足电力和热能需求。 该优化模型有助于做出微电网组件的运营和控制决策,以实现成本高效和可持续的能源供应。 目标是在满足电力和热能需求的前提下,最小化微电网的总运行成本。 微电网包含多种能源发电和储能技术,包括太阳能光伏电池板、风力涡轮机、热电联产装置、燃气锅炉、电锅炉和能量存储系统。 此外,微电网还包括碳捕集和储存设备,用于捕集热电联产和燃气锅炉产生的二氧化碳排放。 方法: 效果:在解决优化问题后,代码展示了每种能源发电和储能技术的最佳运行状态,以及不同部分成本的成本细分。 它还绘制了每天每个小时的功率输出和功率平衡情况。

    无刷直流电机BLDC sinulink仿真 无刷直流电机双闭环PId控制 1)主要由DC直流源、三相逆变桥、无刷直流电机、PWM发生器、霍尔位置解码模块、驱动信号模块、PID、示波器等构成 2)采用

    无刷直流电机BLDC sinulink仿真 无刷直流电机双闭环PId控制 1)主要由DC直流源、三相逆变桥、无刷直流电机、PWM发生器、霍尔位置解码模块、驱动信号模块、PID、示波器等构成。 2)采用转速环、电流环双闭环控制算法; 3)转速环采用PID控制; 4)电流环采用PID控制;

    【毕业设计】双目视觉的物体体积测量算法matlab源码+代码注释.zip

    【毕业设计】双目视觉的物体体积测量算法matlab源码+代码注释.zip

    【无人机通信】基于matlab无人机辅助NOMA无线网络中生成资源协调【含Matlab源码 10934期】复现.zip

    Matlab领域上传的视频是由对应的完整代码运行得来的,完整代码皆可运行,亲测可用,适合小白; 1、从视频里可见完整代码的内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主; 4.1 博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作

    【课程设计】基于Labview的转子动平衡测控系统源码+文档说明.zip

    【课程设计】基于Labview的转子动平衡测控系统源码+文档说明.zip

    使用python开发的一款客户端聊天窗口

    使用python开发的一款客户端聊天窗口,具备如下功能 1、用户可以配置API接口轻松实现机器人对话 2、跨平台 3、学习交流 Python是一种面向对象、解释型的高级程序设计语言,具有简洁、易读、易维护的语法特点,适用于多种领域,如web开发、数据科学、人工智能等。 以下是Python的一些特点: 1. 语法简洁清晰:Python的语法简洁易懂,代码可读性高,易于维护和调试。 2. 可移植性:Python可以运行在多种操作系统上,包括Windows、Mac OS和Linux等。 3. 多样的编程风格:Python支持面向过程、面向对象、函数式等不同的编程风格。 4. 丰富的标准库:Python标准库提供了大量的模块和函数,包含了Web开发、数据处理、网络编程、GUI编程等方面。 5. 第三方库丰富:Python社区拥有庞大的第三方库,能够满足不同领域应用的开发需求。 6. 互动性:Python解释器可直接交互运行,方便进行调试和测试。 7. 功能强大:Python支持众多高级功能,例如。内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。

    摆头台式电风扇.docx

    设计一款可以实现摆头、调档、定时等功能的小风扇:1.扇叶可采用小直流电机带动。2.可以通过按键调节挡位、定时时间,具备显示功能能。3.可以通过遥控器控制风扇的工作模式 MSP430

    【毕业设计】基于yolov3+kcf实现安全帽检测和追踪tensorflow源码+模型+使用说明.zip

    【毕业设计】基于yolov3+kcf实现安全帽检测和追踪tensorflow源码+模型+使用说明.zip

    一个Java GUI 图书借阅系统源码

    源码 一个Java GUI 图书借阅系统源码. 一个Java GUI 图书借阅系统源码.

    SAP FICO新总账凭证分割技术详解及其应用场景

    内容概要:本文档详细介绍了SAP FICO中新总账凭证分割的概念、目的及操作流程,特别强调了凭证分割在多维度财务报表生成中的重要作用。文档涵盖了被动分割、主动分割以及零余额分割的应用情景,并提供了具体的案例,如客户发票、供应商汇票过账及其清账处理。通过执行相关SAP事务码,能够有效地对会计凭证进行拆分,从而实现更为灵活和精准的财务管理。此外,还探讨了与之相关联的数据表变化及系统配置细节,确保分割后的新总账科目能够反映实际业务状况。这不仅提升了财务管理效率,而且提高了报表的准确性和及时性。 适合人群:适用于正在使用或计划实施SAP系统的财务管理人员,特别是那些需要掌握如何利用新技术提高财务数据准确度的人士。 使用场景及目标:适用于需要对不同层次(如利润中心、部门、业务范围等)出具独立或综合财报的企业机构,旨在帮助企业实现精细化管理和高效决策。其核心在于支持复杂的财务结构下快速准确地生成多种视角的财务报告,满足内部管理及外部法规的要求。

    分布式光伏接入电网simulink仿真模型 光伏电池板并网matlab2014版本 simulink仿真模型 输入光伏电池板 boost升压电路采用mppt控制策略 控制直流输出电压为600伏 加入

    分布式光伏接入电网simulink仿真模型 光伏电池板并网matlab2014版本 simulink仿真模型 输入光伏电池板 boost升压电路采用mppt控制策略 控制直流输出电压为600伏 加入三相锁相环pll 直流逆变三相并网采取电压电流双闭环控制策略 模型图 结果图见下

    覆膜机 韩国 液晶行业sw18可编辑全套技术资料100%好用.zip

    覆膜机 韩国 液晶行业sw18可编辑全套技术资料100%好用.zip

Global site tag (gtag.js) - Google Analytics