1.引入mqtt的js库,地址链接https://blog.csdn.net/qq_28877125/article/details/78360170
<script src="./static/js/mqttws31.js" type="text/javascript"></script>
出现format报错的话引入如下js,问题是由于ES6中取消了new Date的format()方法,所以要使用此js引入到依赖中。
(function () {
// Defining locale
Date.shortMonths = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec']
Date.longMonths = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December']
Date.shortDays = ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat']
Date.longDays = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday']
// Defining patterns
var replaceChars = {
// Day
d: function () { var d = this.getDate(); return (d < 10 ? '0' : '') + d },
D: function () { return Date.shortDays[this.getDay()] },
j: function () { return this.getDate() },
l: function () { return Date.longDays[this.getDay()] },
N: function () { var N = this.getDay(); return (N === 0 ? 7 : N) },
S: function () { var S = this.getDate(); return (S % 10 === 1 && S !== 11 ? 'st' : (S % 10 === 2 && S !== 12 ? 'nd' : (S % 10 === 3 && S !== 13 ? 'rd' : 'th'))) },
w: function () { return this.getDay() },
z: function () { var d = new Date(this.getFullYear(), 0, 1); return Math.ceil((this - d) / 86400000) },
// Week
W: function () {
var target = new Date(this.valueOf())
var dayNr = (this.getDay() + 6) % 7
target.setDate(target.getDate() - dayNr + 3)
var firstThursday = target.valueOf()
target.setMonth(0, 1)
if (target.getDay() !== 4) {
target.setMonth(0, 1 + ((4 - target.getDay()) + 7) % 7)
}
var retVal = 1 + Math.ceil((firstThursday - target) / 604800000)
return (retVal < 10 ? '0' + retVal : retVal)
},
// Month
F: function () { return Date.longMonths[this.getMonth()] },
m: function () { var m = this.getMonth(); return (m < 9 ? '0' : '') + (m + 1) },
M: function () { return Date.shortMonths[this.getMonth()] },
n: function () { return this.getMonth() + 1 },
t: function () {
var year = this.getFullYear()
var nextMonth = this.getMonth() + 1
if (nextMonth === 12) {
year = year++
nextMonth = 0
}
return new Date(year, nextMonth, 0).getDate()
},
// Year
L: function () { var L = this.getFullYear(); return (L % 400 === 0 || (L % 100 !== 0 && L % 4 === 0)) },
o: function () { var d = new Date(this.valueOf()); d.setDate(d.getDate() - ((this.getDay() + 6) % 7) + 3); return d.getFullYear() },
Y: function () { return this.getFullYear() },
y: function () { return ('' + this.getFullYear()).substr(2) },
// Time
a: function () { return this.getHours() < 12 ? 'am' : 'pm' },
A: function () { return this.getHours() < 12 ? 'AM' : 'PM' },
B: function () { return Math.floor((((this.getUTCHours() + 1) % 24) + this.getUTCMinutes() / 60 + this.getUTCSeconds() / 3600) * 1000 / 24) },
g: function () { return this.getHours() % 12 || 12 },
G: function () { return this.getHours() },
h: function () { var h = this.getHours(); return ((h % 12 || 12) < 10 ? '0' : '') + (h % 12 || 12) },
H: function () { var H = this.getHours(); return (H < 10 ? '0' : '') + H },
i: function () { var i = this.getMinutes(); return (i < 10 ? '0' : '') + i },
s: function () { var s = this.getSeconds(); return (s < 10 ? '0' : '') + s },
v: function () { var v = this.getMilliseconds(); return (v < 10 ? '00' : (v < 100 ? '0' : '')) + v },
// Timezone
e: function () { return Intl.DateTimeFormat().resolvedOptions().timeZone },
I: function () {
var DST = null
for (var i = 0; i < 12; ++i) {
var d = new Date(this.getFullYear(), i, 1)
var offset = d.getTimezoneOffset()
if (DST === null) DST = offset
else if (offset < DST) { DST = offset; break } else if (offset > DST) break
}
return (this.getTimezoneOffset() === DST) | 0
},
O: function () { var O = this.getTimezoneOffset(); return (-O < 0 ? '-' : '+') + (Math.abs(O / 60) < 10 ? '0' : '') + Math.floor(Math.abs(O / 60)) + (Math.abs(O % 60) === 0 ? '00' : ((Math.abs(O % 60) < 10 ? '0' : '')) + (Math.abs(O % 60))) },
P: function () { var P = this.getTimezoneOffset(); return (-P < 0 ? '-' : '+') + (Math.abs(P / 60) < 10 ? '0' : '') + Math.floor(Math.abs(P / 60)) + ':' + (Math.abs(P % 60) === 0 ? '00' : ((Math.abs(P % 60) < 10 ? '0' : '')) + (Math.abs(P % 60))) },
T: function () { var tz = this.toLocaleTimeString(navigator.language, {timeZoneName: 'short'}).split(' '); return tz[tz.length - 1] },
Z: function () { return -this.getTimezoneOffset() * 60 },
// Full Date/Time
c: function () { return this.Format('Y-m-d\\TH:i:sP') },
r: function () { return this.toString() },
U: function () { return Math.floor(this.getTime() / 1000) }
}
// Simulates PHP's date function
Date.prototype.Format = function (format) {
var date = this
return format.replace(/(\\?)(.)/g, function (_, esc, chr) {
return (esc === '' && replaceChars[chr]) ? replaceChars[chr].call(date) : chr
})
}
}).call(this)
3.发布主题与订阅主题
export default {
data() {
return {
data:{}//用于接收返回的数据
clientId:"",
userName: "",
password: "",
deviceid:"",
cmd:'search',
topic_get: '订阅的主题',
topic_send: '发布的主题',
client: {},
options: {},
count: 0,
time:'',
devlist_data_one:'',
};
},
mixins:[clientIp],
created(){
console.log(this.hostname)this.client = new Paho.MQTT.Client(
this.hostname,
this.port,
this.clientId
);
let that=this
console.log(this.client);
this.options = {
invocationContext: {
host:this.hostname,
port:this.port,
path:this.client.path,
clientId:this.clientId
},
userName:this.userName,
password:this.password,
onSuccess: function() {//连接成功
console.log("onSuccess")
that.send();
},
onFailure: function(e) {//连接失败
console.log("onFailure")
console.log(e);
}
};
this.client.connect(this.options); //连接服务器并注册连接成功处理事件
this.client.onConnectionLost = this.onConnectionLost; //注册连接断开处理事件
this.client.onMessageArrived = this.onMessageArrived; //注册消息接收处理事件
},
methods: {
jumpNum(val){
this.$router.push({path:'/devinfo/devstate',query:{devId:val.number}})
},
onMessageArrived(message) {
this.data=message.payloadString;
console.log(this.data);//返回的数据
},
onConnectionLost(responseObject) {
if (responseObject.errorCode !== 0) {
console.log("onConnectionLost:" + responseObject);
console.log(responseObject);
console.log("连接已断开");
}
},
send:function(){
this.time=this.fromDate(new Date())
let device_id=JSON.stringify(this.deviceid)
var sendMsg = '{"device_id":"' + this.deviceid + '","cmd":"'+this.cmd+'","time":"'+this.time+'","from":"web console"}';
console.log(sendMsg)
var message = new Paho.MQTT.Message(sendMsg);
message.destinationName = this.topic_send;//发送主题
this.client.subscribe(this.topic_get);//订阅主题
this.client.send(message);
},
fromDate(date) {
// var date = new Date(parseInt(timestamp, 10));
var date= new Date(Date.parse(date));
var Y = date.getFullYear() ;
var M = (date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1);
var D = date.getDate() ;
var h = date.getHours() < 10 ? '0' + date.getHours() : date.getHours() ;
var m = date.getMinutes() < 10 ? '0' + date.getMinutes() : date.getMinutes();
var s = date.getSeconds() < 10 ? '0' + date.getSeconds() : date.getSeconds();
return Y + '-' + M + '-' + D + ' ' + h + ':' + m + ':' + s;
}
}
注:1.mqtt为短连接,要想实时更新可使用定时器执性send()函数。
2.this.options中还有其他参数,需要的话自行查找
3.发送数据为json格式,可用JSON.stringify()转换字符串,文中是拼接的。