码迷,mamicode.com
首页 > Web开发 > 详细

CoAP与物联网系统之返回JSON

时间:2014-08-21 00:15:57      阅读:555      评论:0      收藏:0      [点我收藏+]

标签:数据库   callback   server   设计   sqlite3   

在给IoT CoAP添加了JSON支持之后,变得非常有意思,至少我们可以获得我们想要的结果。在上一篇中我们介绍了一些常用的工具——CoAP 命令行工具集

CoAP客户端代码示例

开始之前我们需要有一个客户端代码,以便我们的服务端可以返回正确的数据并解析

var coap = require(‘coap‘);
var requestURI = ‘coap://localhost/‘;
var url = require(‘url‘).parse(requestURI + ‘id/1/‘);
console.log("Request URL: " + url.href);
var req = coap.request(url);
var bl = require(‘bl‘);

req.setHeader("Accept", "application/json");
req.on(‘response‘, function(res) {
    res.pipe(bl(function(err, data) {
        var json = JSON.parse(data);
        console.log(json);
    }));

});

req.end();

代码有点长内容也有点多,但是核心是这句话:

req.setHeader("Accept", "application/json");

这样的话,我们只需要在我们的服务端一判断,

if(req.headers[‘Accept‘] == ‘application/json‘) {
     //do something
 };

这样就可以返回数据了。(转载保留:CoAP与物联网系统之返回JSON)

CoAP Server端代码

Server端的代码比较简单,判断一下

if (req.headers[‘Accept‘] == ‘application/json‘) {
        parse_url(req.url, function(result){
            res.end(result);
        });
        res.code = ‘2.05‘;
    }

请求的是否是JSON格式,再返回一个205,也就是Content,只是这时设计是请求一个URL返回对应的数据。如

 coap://localhost/id/1/

这时应该请求的是ID为1的数据,即

[ { id: 1, value: ‘is id 1‘, sensors1: 19, sensors2: 20 }]

而parse_url只是从数据库从读取相应的数据。

function parse_url(url ,callback) {
    var db = new sqlite3.Database(config["db_name"]);

    var result = [];
    db.all("SELECT * FROM basic;", function(err, rows) {
        callback(JSON.stringify(rows));
    })
}

并且全部都显示出来,设计得真是有点不行,不过现在已经差不多了。

CoAP与物联网系统之返回JSON,布布扣,bubuko.com

CoAP与物联网系统之返回JSON

标签:数据库   callback   server   设计   sqlite3   

原文地址:http://blog.csdn.net/phodal/article/details/38715863

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!