我的物联网综合知识之创建服务端2

本节主要是结合实例代码,详细说明使用Node.js和Express创建服务端的方法。

服务端的主要功能

  • 连接数据库,并能和数据库交互;
  • 为数据库创建两个集合,分别用来存储传感器数据和LED灯的状态;
  • 接收来自传感器上传来的数据(以温度传感器为例),并保存到数据库中;
  • 从数据库中获取传感器的数据,形成JSON格式的数据,供客户端调用;
  • 修改LED灯的状态,实现开关灯。

服务端的创建步骤

1.在整个项目的文件夹iot中新建一个文件夹server,专门用来存放服务端的所有文件。
mkdir server
2.在server文件夹中,新建一个文件package.json,主要是列出一些必要的依赖。
文件内容参考如下:

{
  "name": "iot",
  "version": "0.1.0",
  "description": "A sample Node.js app using Express 4",
  "engines": {
    "node": "5.9.1"
  },
  "main": "server.js",
  "scripts": {
    "start": "node server.js"
  },
  "devDependencies": {
    "mongoose": "^4.6.2",
    "body-parser": "^1.15.2",
    "cors": "^2.8.0",
    "express": "^4.14.0",
    "method-override": "^2.3.6",
    "morgan": "^1.7.0",
    "silly-datetime": "^0.1.2"
  }
}

然后,执行下面的命令安装这些依赖。
npm install (如果安装有cnpm,用cnpm install)

有关依赖的作用说明:
  • Mongoose: 帮助我们和MongoDB进行交互
  • Express:用来创建API路由
  • Body Parser:帮助我们获取来自POST请求的信息
  • Method Override:提供了对DELETE和PUT的支持
  • Morgan:输出一些有用的调试信息
  • Cors:处理CORS (跨域资源共享,Cross Origin Resource Sharing)问题
  • silly-datetime:用来获取当前时间

3.创建服务端核心文件server.js,文件内容参考如下:

//Set up(设置)
var express=require('express');
var app=express();
var mongoose=require('mongoose');
var morgan=require('morgan');
var bodyParser=require('body-parser');
var methodOverride=require('method-override');
var cors=require('cors');
var sd=require('silly-datetime');

//Configuration(配置)
mongoose.connect('mongodb://localhost/iot');

app.use(morgan('dev'));
app.use(bodyParser.urlencoded({'extended':'true'}));
app.use(bodyParser.json());
app.use(bodyParser.json({type:'application/vnd.api+json'}));
app.use(methodOverride());
app.use(cors());
app.use(function(req,res,next){
    res.header("Access-Control-Allow-Origin","*");
    res.header("Access-Control-Allow-Headers","Origin,X-Requested-Width,Content-Type,Accept");
    next();
});

//Models(模型)
var sensorSchema=new mongoose.Schema({
   temperature:Number,
   date:String,
   time:String    
});
var ledSchema=new mongoose.Schema({
    status:{type:Boolean,default:false}
});
var sensorModel=mongoose.model('sensor',sensorSchema);
var ledModel=mongoose.model('led',ledSchema);
//Routes(路由)
app.get('/sensor',function(req,res){//从数据库中获取传感器数据
    sensorModel.find(function(err,data){
        if (err)
            res.send(err);
        res.json(data);
    });
});
app.post('/sensor',function(req,res){//获得新的传感器数据,存入数据库中
   var cdate=sd.format(new Date(),'YYYY-MM-DD');
   var ctime=sd.format(new Date(),'HH:mm'); 
   sensorModel.create({
                temperature:req.body.temperature,
                date:cdate,
                time:ctime
            },function(err,state){
            if (err)
                res.send(err);
            sensorModel.find(function(err,data){
                if (err){
                    res.send(err);
                }
                res.json(data);
            });
    });
});
app.put('/led',function(req,res){//更新Led灯的状态,实现开关灯
    ledModel.update({},{$set:{status:req.body.status}},{upsert:true},function(err,result){
       if(err){
         res.send(err);
       }else{
         ledModel.find(function(err,data){
            if (err){
              res.send(err);
            }
            res.json(data);
         });
       }
 });
});
//Listen(监听)
app.listen(3000);

然后,执行下面的命令运行服务端:
node server.js

代码要点分析:
  • server.js文件包括5个部分,分别是设置、配置、模型、路由和监听;
  • 在设置部分,引入了所需要的模块,如express、mongoose等;
  • 在配置部分,用mongoose连接到数据库iot;
  • 在模型部分,用mongoose建立了两个集合,即sensors和leds,分别用来存储传感器数据和Led灯的状态;
  • 在路由部分,创建了三个API路由,分别用到了express的get、post和put方法,并相应用到了mongoose的find、create和update方法,分别实现了从数据库中获取传感器数据、将获得的传感器数据存入数据库以及更新Led灯的状态。
  • 在ledModel.update()方法中,upsert:true选项的意思是如果找到了匹配数据即更新,如果没有找到,即插入一条数据。

4.对服务端进行必要的测试:
首先,运行服务端。
运行服务端
然后,打开mongo命令行窗口,使用iot数据库,执行查询命令,查看文档内容为空。
mongo窗口
用curl命令进行路由的测试。
执行curl命令
在mongo窗口中,再次执行查询命令,可以看到刚才用curl命令插入或更新的文档内容。
再次执行查询
至此,服务端搭建完毕,接下来,我们就可以在客户端通过图形的方式实时地、直观地将传感器数据显示出来,并且可以实时改变Led的状态。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
我记录综合系统 1.6源码 站部分新增: 微博:微博功能增强,实现全功能微博 采集:新闻采集功能,包括定时采集、图片抓取和数据导入 wiki:将通用页面转化为可以多人协作编辑的wiki形式 群组:重新设计前台和后台界面 增加ip屏蔽功能 标签tag增强:前台增加 tag 搜索功能;后台增加 tag 管理功能;禁止过滤词作为tag 论坛上传图片增加到原图链接 在论坛附件中增加带进度条的上传功能 在编辑器中增加带进度条的上传功能 后台配置增加上传文件和图片的大小限制 用户空间首页加入微博发布框 配合ajaxLoader/frmLoader,门户区块增加了SectionData控制器,便于区块的混搭和嵌套 新闻评论之后,给投递人发通知; 解决删除下级论坛时未提示问题 用户空间增加空间名称,可修改 登录之后返回原始页面 解决论坛首页无图片+调试状态js报错的bug 菜单:解决添加本地abcd.html 多出abcd.html.aspx 后缀的问题 1.6新版特别推荐 微博功能: 1)支持优酷、土豆、ku6、56的视频,但要注意的是,视频必须是播放页的址,不是flash的址 2)支持at功能、话题功能、表情功能 3)支持评论、转发 采集功能: 1)先在线制作采集模板,要注意如果抓取结果为空,请检查是否有多余空格,编码是否正确。 2)然后制作导入计划,都是自动导入(也可以即时手动刷新导入),还可以设置是否需要审核。 3)采集和导入都是自动定时循环执行,间隔时间请到后台计划任务处设置。 4)和门户集成,可以直接导入门户app中。 框架部分新增 editor:工具栏增加flash按钮 mvc:增加验证码控件,简化验证码使用 mvc:美化弹窗效果,边框使用透明背景,优化了 loading 框 mvc:增加 ajaxDeleteCmd 删除效果 mvc:增加 frmLink (框架链接)增加无刷新切换效果 mvc:增加 frmLoader和ajaxLoader 控件,可以让页面嵌套,方便mashup mvc:增加 doubleClick 控件,双击某行进入址 mvc:增加简易 tab 效果支持 mvc:增加简易跑马灯效果 mvc:增加简易幻灯片效果 mvc:html过滤:允许属性id,允许img的border,width,height属性 mvc:修复了使用to针对textarea验证时无效的bug mvc:增加 ctx.PostDecimal/ctx.PostDouble 等的支持 ORM:增加了 decimal 批注对自定义精度的支持 ORM:修正了批量删除对mysql的支持 上传:增加带进度的flash上传支持 上传:解决英文系统下上传目录日期和年月颠倒问题 络:增加ip屏蔽功能 络:增加将文章中图片下载到本地功能 络:增加远程解析视频分享信息功能 框架改动:Link增加AppendPage方法,ObjectPage删除AppendPage方法 管理员测试帐号和密码均是:admin

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值