JavaScript 发消息示例__JavaScript 接入示例_MQTT 接入(物联)_消息队列 MQ-阿里云
本文主要介绍如何使用 JavaScript 客户端收发 MQTT 消息,并给出示例代码供前期开发测试参考。
注意:
本文给出的实例均基于 Eclipse Paho JavaScript SDK 实现,该 SDK 下载请参见MQTT 接入准备。如使用其他第三方的客户端,请适当修改。
1. 资源申请
使用 MQ 提供的 MQTT 服务,首先需要核实应用中使用的 Topic 资源是否已经申请,如果没有请先去控制台申请 Topic,Group ID 等资源。
申请资源时需要根据需求选择对应的 Region,例如,MQTT 需要使用华北2的接入点,那么 Topic 等资源就在华北2 申请,资源申请具体请参见申请 MQ 资源。
注意:MQTT 使用的多级子 Topic 不需要申请,代码里直接使用即可,没有限制。
2. MQTT 发送消息
本段示例代码演示如何使用 JavaScript 客户端收发 MQTT 消息。
config.js 文件
host = 'mqtt-test.cn-qingdao.aliyuncs.com';// MQTT公测Region的接入点域名,参考MQTT环境准备章节port = 80;//WebSocket协议服务端口topic = 'XXXXXXX';//需要操作的TopicuseTLS = false;//是否走加密TLS协议accessKey = 'XXXXXX';//账号的AccessKey,在阿里云控制台查看secretKey = 'XXXXXX=';//账号的的SecretKey,在阿里云控制台查看cleansession = true;groupId='GID_XXXX';clientId=groupId+'@@@XXXX';//GroupId@@@DeviceId,由控制台申请的Group ID和自己指定的Device ID组合构成
发送程序:
<?xml version="1.0" encoding="UTF-8" standalone="no"?><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="https://www.w3.org/1999/xhtml"><head><title>Aliyun Mqtt Websockets</title><meta name="viewport" content="width=device-width, initial-scale=1.0"><script src="mqttws31.js" type="text/javascript"></script><script src="config.js" type="text/javascript"></script><script src="crypto-js.js" type="text/javascript"></script><script type="text/javascript">var mqtt;var reconnectTimeout = 2000;var username =accessKey;var password=CryptoJS.HmacSHA1(groupId,secretKey).toString(CryptoJS.enc.Base64);function MQTTconnect() {mqtt = new Paho.MQTT.Client(host,//MQTT域名port,//WebSocket端口clientId//客户端ClientId);var options = {timeout: 3,onSuccess: onConnect,onFailure: function (message) {setTimeout(MQTTconnect, reconnectTimeout);}};mqtt.onConnectionLost = onConnectionLost;mqtt.onMessageArrived = onMessageArrived;if (username != null) {options.userName = username;options.password = password;}mqtt.connect(options);}function onConnect() {// Connection succeeded; subscribe to our topicmqtt.subscribe(topic, {qos: 0});message = new Paho.MQTT.Message("Hello mqtt!!");//set bodymessage.destinationName =topic;// set topicmqtt.send(message);}function onConnectionLost(response) {setTimeout(MQTTconnect, reconnectTimeout);};function onMessageArrived(message) {var topic = message.destinationName;var payload = message.payloadString;console.log("recv msg : "+topic+" "+payload);};MQTTconnect();</script></head></html>
最后更新:2016-12-19 15:59:50
上一篇:
Android 收发消息示例__Android 接入示例_MQTT 接入(物联)_消息队列 MQ-阿里云
下一篇:
MQ 客户端收发 MQTT 消息__Java 接入示例_MQTT 接入(物联)_消息队列 MQ-阿里云
步骤3:验证配置生效__快速入门(非网站业务)_DDoS 高防IP-阿里云
数加控制台帮助__平台介绍_数加平台介绍-阿里云
32T 块存储分区__扩容磁盘概览_磁盘_用户指南_云服务器 ECS-阿里云
禁止直播流推送__直播流操作接口_API 手册_CDN-阿里云
1.1 登陆ECS实例__ECS快速开始_云服务器ECS 体验_体验馆-阿里云
CPU__常用指标_使用手册_性能测试-阿里云
域名展示页常见问题FAQ___域名展示页_域名交易_域名-阿里云
设置日志__管理存储空间_控制台用户指南_对象存储 OSS-阿里云
简单深度学习离线训练__应用场景_产品简介_高性能计算-阿里云
获取联系人模板编号__附录_API文档_域名-阿里云
相关内容
常见错误说明__附录_大数据计算服务-阿里云
发送短信接口__API使用手册_短信服务-阿里云
接口文档__Android_安全组件教程_移动安全-阿里云
运营商错误码(联通)__常见问题_短信服务-阿里云
设置短信模板__使用手册_短信服务-阿里云
OSS 权限问题及排查__常见错误及排除_最佳实践_对象存储 OSS-阿里云
消息通知__操作指南_批量计算-阿里云
设备端快速接入(MQTT)__快速开始_阿里云物联网套件-阿里云
查询API调用流量数据__API管理相关接口_API_API 网关-阿里云
使用STS访问__JavaScript-SDK_SDK 参考_对象存储 OSS-阿里云