-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsocket_udp.js
More file actions
118 lines (108 loc) · 3.6 KB
/
socket_udp.js
File metadata and controls
118 lines (108 loc) · 3.6 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
const dgram = require('dgram');
const fs = require("fs");
const server = dgram.createSocket('udp4');
var sd = require('silly-datetime');
var mysql = require('mysql');
var connection = mysql.createConnection({
host: '59647813aaa48.sh.cdb.myqcloud.com',
user: 'test_user',
password: 'Jinx0007',
port: '15955',
database: 'test',
});
server.on('error', (err) => {
console.log(`服务器异常:\n${err.stack}`);
server.close();
});
server.on('message', (msg, rinfo) => {
try {
msg = buffToStr(msg)
var _msg = JSON.stringify(msg);
console.log('服务器收到原始数据:'+_msg+'来自'+rinfo.address+':'+rinfo.port);
msg = getJson(msg);
var time = sd.format(new Date(), 'YYYY-MM-DD HH:mm:ss');
msg = '<b style="color: red;">' + time + '</b></br>'+JSON.stringify(msg) + '\n';
fs.appendFile('log.txt', msg, 'utf8', function (err) {
if (err) {
console.log(err);
}
});
console.log(`服务器收到状态:${msg} 来自 ${rinfo.address}:${rinfo.port}`);
// if('48'==msg.type&&'30'==msg.method) {
// insertIoT(msg, function (data) {
// if (data) {
// var time = sd.format(new Date(), 'YYYY-MM-DD HH:mm:ss');
// msg = JSON.stringify(msg) + '----' + time + '\n';
// fs.appendFile('log.txt', msg, 'utf8', function (err) {
// if (err) {
// console.log(err);
// }
// });
// console.log(`服务器收到状态:${msg} 来自 ${rinfo.address}:${rinfo.port}`);
// }
// });
// }
}catch (e){
console.log('服务器接收出错:'+e);
}
});
server.on('listening', () => {
const address = server.address();
console.log(`服务器监听 ${address.address}:${address.port}`);
});
function buffToStr(buff) {
let hex_str = '';
for (let i = 0; i < buff.length; i++) {
let val = buff[i].toString(16);
if (val.length == 1) {
val = '0' + val;
}
hex_str = hex_str + val;
}
return hex_str;
}
function getJson(msg) {
var mac = '', type = '', method = '', value = '';
for (var i = 0; i < 16; i++) {
mac += msg[i];
}
for (var i = 16; i < 18; i++) {
type += msg[i];
}
for (var i = 20; i < 22; i++) {
method += msg[i];
}
for (var i = 24; i < 26; i++) {
value += parseInt(msg[i]);
}
return {mac: mac, type: type, method: method, value:parseInt(value)};
}
function insertIoT(obj,callback){
var time = sd.format(new Date(), 'YYYY-MM-DD HH:mm:ss');
var _addSql = 'INSERT INTO tbl_sensor_operationlog(available,mac,change_time,create_time) VALUES(?,?,?,?)';
var _addParams = [obj.value, obj.mac,time,time];
connection.query(_addSql,_addParams,function (err, result) {
if(err){
console.log('[INSERT ERROR] - ',err.message);
return;
}
console.log('-------INSERT----------');
callback(result);
});
}
function handleDisconnect(connection) {
connection.on('error', function (err) {
if (!err.fatal) {
return;
}
if (err.code !== 'PROTOCOL_CONNECTION_LOST') {
throw err;
}
console.log('Re-connecting lost connection: ' + err.stack);
connection = mysql.createConnection(connection.config);
handleDisconnect(connection);
connection.connect();
});
}
handleDisconnect(connection);
server.bind(59983);