node.js+express+mysql+腾讯云服务器实现onenet平台对接与数据存储

做这个事情来自于实验室的需求,老板吩咐建立一套自己的气象监测站系统,能够通过NBIOT、2G、4G将本地数据传输到云平台,进行WEB显示与云端存储。Onenet(自行百度)很好的实现了本地到云端的对接,但问题在于没有开放数据库权限,只能通过API的形式,访问有限个数据点,不方便后期处理。但Onenet预留了一个第三方服务器接口,oennet可通过这个接口将实时接收到的数据点推送到第三方服务器。以下内容基于这个Data_push推送接口实现了第三方服务器明文模式的搭建,接收数据与mysql存储。

node.js+express+mysql+腾讯云服务器实现onenet平台对接与数据存储_第1张图片

                                                                            气象监测系统架构图

node.js+express+mysql+腾讯云服务器实现onenet平台对接与数据存储_第2张图片

在oenent平台的开发者中心任一一个类型的设备中,左侧栏都有第三方配置菜单,需要输入URL信息,包含公网的IP和端口。

第一步:使用了官方给的第三方对接SDK包https://open.iot.10086.cn/doc/art432.html#118,采用node.js语言。

         1.1、搭建node.js开发环境,我使用的是win10系统,安装node.js和vscode调试平台。安装好后,就可以用vscode调试node.js程序了。官方的给的SDK已经包括了URL验证与数据解析。对SDK分析以下。主要包括两大模块,一个是用GET方法进行URL验证。另一个是POST方法接收onenet推送的数据。具体协议请看https://open.iot.10086.cn/doc/art486.html#108

node.js+express+mysql+腾讯云服务器实现onenet平台对接与数据存储_第3张图片node.js+express+mysql+腾讯云服务器实现onenet平台对接与数据存储_第4张图片

在用node.js测试时,注意一个地方就是

node.js+express+mysql+腾讯云服务器实现onenet平台对接与数据存储_第5张图片

在onenet平台填写的端口号就是这里的port,默认是3000.

1.2、在本地用vscode调试时没有公网IP。为了能够在本地也能拥有本地ip,采用ngrok进行反代理。

node.js+express+mysql+腾讯云服务器实现onenet平台对接与数据存储_第6张图片

输入:ngrok http 80后,我们就在本地拥有了一个公网ip和端口,注意这里的端口是80端口。所以在node.js的port中定义成80,才能使用。

node.js+express+mysql+腾讯云服务器实现onenet平台对接与数据存储_第7张图片

得到的公网IP如红线所示,在oenent第三方配置输入后,如图。

node.js+express+mysql+腾讯云服务器实现onenet平台对接与数据存储_第8张图片

点击提交,就会通过验证。此时,本地这个服务器就可以接收设备传上来的实时数据了,至于接收后如何处理,就看用户的需求了。

第二步:node.js对接mysql

1.1、安装mysql(http://www.runoob.com/mysql/mysql-install.html)

   意安装mysql时,一定要用管理员的CMD! 按照提示安装就可以,但8.0以后的版本在安装时没有my文件,为此,可以自己建立一个my文件,内容复制以下即可,有个别地方根据自己的安装参数修改。

[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8
 
[mysqld]
# 设置3306端口
port = 3306
# 设置mysql的安装目录
basedir=C:\web\mysql-8.0.12
# 设置mysql数据库的数据的存放目录
datadir=C:\web\sqldata
# 允许最大连接数
max_connections=20
# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB

 2.2 mysql对接node.js(http://www.runoob.com/nodejs/nodejs-mysql.html)

  这里直接按照操作进行就可以了。

2.3将mysql数据管理与插入数据的相关代码插入到get推送模块的程序里,这是我的用于接收数据并存储在数据里的相关代码。

var mysql      = require('mysql');
var connection = mysql.createConnection({     
    host     : 'localhost',       
    user     : 'root',              
    password : '123456',       
    port: '3306',                   
    database: 'test', 
  }); 
  connection.connect();
app.post('/dataPort', function (req, res) {

     res.send({code: 200});
     console.log(req.body); 
     if(req.body.msg.ds_id=='3303_0_5700'){  
     kwendu=req.body.msg.value;
    //fs.appendFile('data/ceshi1.txt',req.body.msg.at+"\t"+req.body.msg.value+"\r\n", function (err) {
    //    if (err) throw err; });
    }
    if(req.body.msg.ds_id=='3303_1_5700'){  
        twendu=req.body.msg.value;
       }
    if(req.body.msg.ds_id=='3304_0_5700'){  
        kshidu=req.body.msg.value;
       }
    if(req.body.msg.ds_id=='3304_1_5700'){  
        tshidu=req.body.msg.value;
       }
    if(req.body.msg.ds_id=='3300_0_5700'){  
        fengsu=req.body.msg.value;
       }
    if(req.body.msg.ds_id=='3300_1_5700'){  
        fengxiang=req.body.msg.value;
       }
    if(req.body.msg.ds_id=='3300_2_5700'){  
        yuliang=req.body.msg.value;
       }
    if(req.body.msg.ds_id=='3300_3_5700'){  
        guangzhao1=req.body.msg.value;
       }
    if(req.body.msg.ds_id=='3300_4_5700'){
        var  addSql = 'INSERT INTO Dev_36829767(时间戳,空气温度,空气湿度,土壤温度,土壤湿度,风速,风向,雨量,光照1,光照2) VALUES(?,?,?,?,?,?,?,?,?,?)';
        var  addSqlParams = [req.body.msg.at,kwendu,kshidu,twendu,tshidu,fengsu,fengxiang,yuliang,guangzhao1,req.body.msg.value];
        connection.query(addSql,addSqlParams,function (err, result) {
            if(err){
             return;
                }        
            });  

    }

第三步:mysql远程可视化访问

老板说要远程带权限可视化的查看mysql数据。采用了Navicat Premium对数据库进行远程管理。可自行百度这个软件的使用指导。在这里只说明一下,8.0版本后的mysql用户加密方式发生变化,无法在Navicat Premium中登陆,会报错。可参考这个(https://www.cnblogs.com/xieshuang/p/9028362.html)修改用户加密方式即可。

最终效果如下:

node.js+express+mysql+腾讯云服务器实现onenet平台对接与数据存储_第9张图片

设备上传到onenet的数据,都可以在这里实时查看,可导出excel等格式,很方便数据的管理。既然数据已经到数据库了,下一步做web,做app就有数据根基了。

你可能感兴趣的:(node.js+express+mysql+腾讯云服务器实现onenet平台对接与数据存储)