在给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
时间: 2024-12-21 16:17:51