您的位置:首页 > 大数据 > 物联网

CoAP与物联网系统之返回JSON

2014-08-20 23:22 204 查看
在给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));
})
}并且全部都显示出来,设计得真是有点不行,不过现在已经差不多了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: