车流量 Restful API

RESTful是什么

RESTful,是目前最为流行的一种互联网软件架构。因为它结构清晰、符合标准、易于理解、扩展方便,所以正得到越来越多网站的采用。学习RESTful,首先要学习REST。

REST

  • 资源(Resources) REST是"表现层状态转化",其实REST省略了主语。"表现层"其实指的是"资源"的"表现层"。一张图片、一个文档、一个视频等。这些资源我们通过URI来定位,也就是一个URI表示一个资源。

  • 表现层(Representation)
    资源是做一个具体的实体信息,他可以有多种的展现方式。例如一个txt文本信息,他可以输出成html、json、xml等格式,一个图片他可以jpg、png等方式展现
    URI确定一个资源,但是如何确定它的具体表现形式呢?应该在HTTP请求的头信息中用Accept和Content-Type字段指定,这两个字段才是对"表现层"的描述。

  • 状态转化(State Transfer)
    访问一个网站,就代表了客户端和服务器的一个互动过程。在这个过程中,肯定涉及到数据和状态的变化。而HTTP协议是无状态的,那么这些状态肯定保存在服务器端,所以如果客户端想要通知服务器端改变数据和状态的变化,肯定要通过HTTP来通知它。具体来说,就是HTTP协议里面,四个表示操作方式的动词:GET、POST、PUT、DELETE。它们分别对应四种基本操作:GET用来获取资源,POST用来新建资源(也可以用于更新资源),PUT用来更新资源,DELETE用来删除资源。

RESTful API

符合REST设计风格的Web API称为RESTful API。也就是说,RESTful是REST架构风格在WEB上的应用

实现功能

  • 访问所有车流量数据
    GET: /api/<Authen>/all

  • 访问近一周车流量数据
    GET: /api/<Authen>/near

  • 访问指定路口(crossID)即指定网关所有车流量数据
    GET: /api/<Authen>/cross/<crossID>

  • 访问指定路口(crossID)即指定网关近3分钟实时车流量数据
    GET: /api/<Authen>/cross/<crossID>/last3min

  • 访问指定路口(crossID)即指定网关一段时间车流量数据
    GET: /api/<Authen>/cross/<crossID>/start=<startTime>&end=<endTime>

代码部分

  1. 数据库部分Flow.js
    建立Schema:创建
var FlowSchema = new Schema({
    CrossTrafficData:{
        CrossID: String,
        DeviceType: String,
        DateTime: String,
        Interval: Number,
        DataList:{
            Data:{
                LaneNo: String,
                Volume: Number,
                AvgOccupancy: Number,
                AvgHeadTime: Number,
                AvgLength: Number,
                AvgSpeed: Number,
                Saturation: Number,
                Density: Number,
                Pcu: Number,
                AveQueueLength: Number,
                Volume1: Number,
                Volume2: Number,
                Volume3: Number,
                Volume4: Number,
                Volume5: Number
            }
        }
    }   
});

//exports对象:
var FlowOp = function(){};
//定义各种函数。prototype表示是给FlowOp对象用的,通过callback返回数据
FlowOp.prototype.<name_function> = function([parametres],callback){}
//定义一个Model对象方便使用Model封装的方法
var FlowModel = mongodb.mongoose.model('flowCar',FlowSchema);
//Model对象的find方法,参数:条件,投射,CB
//下面这句表示筛选出参数id值和时间段的文件,并且提取后去除_id和__v属性。查询结果返回给data_id_p,进入回调函数

FlowModel.find({'CrossTrafficData.CrossID': id,'CrossTrafficData.DateTime': {"$gt": start, "$lte": end}},'-_id -__v',(err,data_id_p)=>{});

//回调函数,将js的obj转换为json,然后给callback赋值,传递json数值

 var data_p_json= JSON.stringify({data_p});
 callback(err,data_p_json);
  1. 路由routedata.js
    //Json转XML,借助jsontoxml包并加入xml声明,之前传递的json就是obj
router.get('/cross/:id/start=:timestart&end=:timeend', (req, res) => {
    CarFlow.findByCrossByPeriod(req.params.id, req.params.timestart, req.params.timeend, (err, obj) => {
        var data_xml = jsontoxml(obj);
        res.set('Content-Type', 'text/xml');
        var d = '<?xml version="1.0" encoding="utf-8"?>';
        res.send(d + data_xml);
    });
});

反思

可以在Schema建立函数,并且导出一个Model对象是否封装更好?

mySchema.methods.findByCByP = function(paras, cb){
    return this.find({type: this.type}, cb);
}```
##Reference
Rest:https://github.com/astaxie/build-web-application-with-golang/blob/master/zh/08.3.md
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,752评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,100评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,244评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,099评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,210评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,307评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,346评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,133评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,546评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,849评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,019评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,702评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,331评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,030评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,260评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,871评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,898评论 2 351

推荐阅读更多精彩内容