CoAP与物联网系统之返回JSON

在给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,古老的榕树,5-wow.com

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。