首先在spring配置文件中配置
@Overridepublic void sendMessage(String mobile) {this.sendMessage(loginDestination, mobile);}public void sendMessage(Destination loginDestination, String mobile) {jmsTemplate.send(loginDestination, new MessageCreator() {@Overridepublic Message createMessage(Session session) throws JMSException {ObjectMessage message = session.createObjectMessage(mobile);return message;}});} 以上代码要注意
出队类要继承 RouteBuilder然后实现方法 configure
<pre name="code" class="html"><bean id="activeMQConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">
<property name="brokerURL" value="tcp://localhost:61616" />
</bean>
<bean id="pooledConnectionFactory" class="org.apache.activemq.pool.PooledConnectionFactory"
destroy-method="stop" lazy-init="true">
<property name="connectionFactory" ref="activeMQConnectionFactory" />
</bean>
<bean id="connectionFaction"
class="org.springframework.jms.connection.SingleConnectionFactory">
<property name="targetConnectionFactory" ref="pooledConnectionFactory" />
</bean>
<bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate">
<property name="connectionFactory" ref="connectionFaction" />
<property name="defaultDestination" ref="queueDestination" />
<property name="receiveTimeout" value="600" />
</bean>
<bean id="queueDestination" class="org.apache.activemq.command.ActiveMQQueue">
<constructor-arg>
<value>queue</value>
</constructor-arg>
</bean>
<bean id="loginDestination" class="org.apache.activemq.command.ActiveMQQueue">
<constructor-arg>
<value>login</value>
</constructor-arg>
</bean>
以上配置是通过spring来管理activemq的。
active入队代码
<pre name="code" class="java">@Autowired
private Destination loginDestination;
@Overridepublic void sendMessage(String mobile) {this.sendMessage(loginDestination, mobile);}public void sendMessage(Destination loginDestination, String mobile) {jmsTemplate.send(loginDestination, new MessageCreator() {@Overridepublic Message createMessage(Session session) throws JMSException {ObjectMessage message = session.createObjectMessage(mobile);return message;}});} 以上代码要注意
@Autowired
private Destination loginDestination;
变量名(loginDestination)要和spring配置中的一致,然后就可以再<pre name="code" class="java">createMessage方法中处理传入的数据,然后出队。
出队代码
<pre name="code" class="java">public class LoginRouter extends RouteBuilder {
@Override
public void configure() throws Exception {
from("jms:login")
.process(new Processor() {
public void process(Exchange exchange) throws Exception {
String mobile = exchange.getIn().getBody(String.class);
exchange.getIn().setHeader("mobile", mobile);
}
})
.setHeader(Exchange.HTTP_QUERY, simple("${header.CamelHttpQuery}mobile=${header.mobile}"))
.to(ExchangePattern.InOnly,
"http://localhost:8080/myTest/login/afterLogin?bridgeEndpoint=true&throwExceptionOnFailure=false");
}
}
出队类要继承 RouteBuilder然后实现方法 configure
<span style="font-family: Arial, Helvetica, sans-serif;">注意:</span><span style="font-family: Arial, Helvetica, sans-serif;">from("jms:login") 中的”login“这个也要和配置的对应,然后在内部内里面处理数据,然后把处理后的数据当成参数传入到项目的</span><span style="font-family: Arial, Helvetica, sans-serif;">login/afterLogin这个Controller中,然后在这个Controller处理后续操作。</span>
虽然这样照葫芦画瓢配置好了,也能操作了,但里面的具体操作,参数的处理,传递还不是很懂,还要慢慢研究。