1 首先下载并安装ActiveMQ
http://www.apache.org/dyn/closer.cgi?path=/activemq/apache-activemq/5.9.0/apache-activemq-5.9.0-bin.zip
1)解压后,将webapps-demo目录下的demo复制到webapps目录下
2)执行bin/activemq.bat,启动ActiveMQ服务
3)打开http://localhost:8161/demo,运行自带的Web sockets example进行测试
2 在X5中创建应用demo/activeMQ
1)编写用于发送ActiveMQ消息的动作
下载http://central.maven.org/maven2/org/apache/activemq/activemq-all/5.9.0/activemq-all-5.9.0.jar
放入/BIZ/demo/activeMQ/logic/code/lib文件夹中
编写动作代码(动作模型文件参见/BIZ/demo/activeMQ/logic/action/activeMQ.action.m)
import org.apache.activemq.transport.stomp.StompConnection; public class ActiveMQ { public static void activeMQSendMessage(String message) throws Exception { StompConnection conn = new StompConnection(); try { conn.open("127.0.0.1", 61613); conn.connect("guest", "guest"); conn.begin("StompTransaction"); conn.send("/topic/test", message); conn.commit("StompTransaction"); } finally { conn.close(); } } }
2)创建功能process,引用上面的动作,并创建功能页面
功能页面实现两个功能:
发送消息
编辑框+按钮,调用上面的动作实现消息发送
mainActivity.btnSendClick = function(event){ if ($("#inputText").val() == "") return; var params = new justep.Request.ActionParam(); params.setString("message", window.escape($("#inputText").val())); justep.Request.sendBizRequest2({ "action": "activeMQSendMessage", "parameters": params, "callback": function(callbackData) { callbackData.ignoreError = false; if (callbackData.state) { $("#inputText").val(""); } } }); };
接收消息
引用ActiveMQ WebSocket案例中自带的stomp.js,stomp.js 是使用 HTML5 Web Socket API 实现的 Stomp 客户端。
页面中用Stomp实现消息接收
mainActivity.model1Load = function(event){ var client = Stomp.client("ws://localhost:61614/stomp"); client.connect("guest", "guest", function(frame) { client.subscribe("/topic/test", function(msg) { $("#textReceiver").val(window.unescape(msg.body) + "\n" + $("#textReceiver").val()); }); }); $("#textReceiver").val("Receiving.....\n"); };
注意:ActiveMQ需要jdk 1.6,而X5开发版自带的是jdk 1.5,需要下载 32位的jdk1.6 替换X5中的jdk
由于jdk版本问题,动作的代码在studio中编译会报错,但是运行时编译运行都是正常的。
请用IE10以上版本或Chrome、Firefox浏览器
X5_DEMO_activeMQ.zip
由于附件大小限制,示例资源中没有包含lib下的activemq-all-5.9.0.jar
本文由WeX5君整理,WeX5一款开源免费的html5开发工具,H5 App开发就用WeX5!
阅读其他app 开发相关文章:http://doc.wex5.com/?p=3443
评一波