用Node.js实现Restful风格webservice

Restful风格的WebService正在渐渐取代传统的SOAP, Java 也有很多Restful的框架,很方便简洁,Jersey,restlet,甚至SpringMVC也可以,不得不说Rest让人从Web转型到WebService更容易和方便,当然深入Restful的理论还是发现比较复杂的,但是,开发和理论并不需要那么的贴合,有时候伪Restful更直观,靠谱些。

但是,作为很帅的Node.js怎么可以不和同样帅气的Restful相结合呢!?对于我们这种无视理论的开发者来说,Restful不就是url的规范+HTTP method的规范而已嘛,所以Node这种很自由的技术来说,同样实现restful变的非常正常。不需要什么框架,但是我还是用了Express,Express只是对原生的http模块的一层封装而已,不要那么计较嘛!

Java曾经是一个Xml配置文件横行的世界,现在是各种Annotation(注解)乱入的世界,虽然注解的侵入性比较小,但是加了一摞注解的类也让人伤神,尤其是各框架混杂的注解,好在各大框架还是比较自觉的,各种负责不同的层,所以还不会导致各种注解的混乱。好了,那么下面欢迎来到,没有注解,也没用xml的世界:

     ----我是例子---------
[javascript]  view plain copy
  1. var express = require('express'//加载模块  
  2. var app = express() //实例化之  
  3.   
  4. var map = {"1":{id:1,name:"test"},"2":{id:2,name:"test"}} //定义一个集合资源,key为字符串完全是模仿java MAP<T,E>,否则谁会这么去写个hash啊!  
  5.   
  6. app.get('/devices',function(req, res){ //Restful Get方法,查找整个集合资源  
  7.     res.set({'Content-Type':'text/json','Encodeing':'utf8'});  
  8.     res.send(map)  
  9. })  
  10. app.get('/devices/:id',function(req, res){ //Restful Get方法,查找一个单一资源  
  11.     res.set({'Content-Type':'text/json','Encodeing':'utf8'});  
  12.     res.send(map[req.param('id')])  
  13.     //console.log(req.param('id'))  
  14. })  
  15. app.post('/devices/', express.bodyParser(), function(req, res){ //Restful Post方法,创建一个单一资源  
  16.     res.set({'Content-Type':'text/json','Encodeing':'utf8'});  
  17.     map[req.body.id] = req.body  
  18.     res.send({status:"success",url:"/devices/"+req.body.id}) //id 一般由数据库产生  
  19. })  
  20. app.put('/devices/:id', express.bodyParser(), function(req, res){ //Restful Put方法,更新一个单一资源  
  21.     res.set({'Content-Type':'text/json','Encodeing':'utf8'});  
  22.     map[req.body.id] = req.body  
  23.     res.send({status:"success",url:"/devices/"+req.param('id'),device:req.body});  
  24. })  
  25. app.delete('/devices/:id',function(req, res){ //Restful Delete方法,删除一个单一资源  
  26.     res.set({'Content-Type':'text/json','Encodeing':'utf8'});  
  27.     delete map[req.param('id')]  
  28.     res.send({status:"success",url:"/devices/"+req.param('id')})  
  29.     console.log(map)  
  30. })  
  31. app.listen(8888); //监听8888端口,没办法,总不好抢了tomcat的8080吧!  

---------我是测试-----------

     用Postman测试ok, 代码中唯一让人诧异的应该是delete map[req.param('id')],我们知道js的map是一个Object,或者Object是一个map,,delete object.property,可以删除这个属性,但是delete Object[Property]也可以把这个属性给干掉,delete o.x 也可以写作 delete o["x"],两者效果相同 关于delete请观看:ECMAScript delete

     系不系很方便哈!和那些XXX框架些的代码很类似啊!如果你是一个寻求不同的人,Node.js当然也满足你,一直备受争议的路由表上场了:

------我是另一个文件:routes.js--------
[javascript]  view plain copy
  1. { get:   
  2.    [ { path: '/',  
  3.        method: 'get',  
  4.        callbacks: [Object],  
  5.        keys: [],  
  6.        regexp: /^\/\/?$/i },  
  7.    { path: '/user/:id',  
  8.        method: 'get',  
  9.        callbacks: [Object],  
  10.        keys: [{ name: 'id', optional: false }],  
  11.        regexp: /^\/user\/(?:([^\/]+?))\/?$/i } ],  
  12. delete:   
  13.    [ { path: '/user/:id',  
  14.        method: 'delete',  
  15.        callbacks: [Object],  
  16.        keys: [Object],  
  17.        regexp: /^\/user\/(?:([^\/]+?))\/?$/i } ] }  



    定义这么一个对象,然后

[javascript]  view plain copy
  1. var routes = require('./routes')  
  2. app.use(app.router);//保留原来的  
  3. routes(app);//这个是新加的,将前者作为默认路由  

 关于routes的更多内容:Express官网   靠谱些,毕竟node.js最大的问题,就是资料的api都太旧了!

Node.js处理请求包括其它一些Io都是异步的,很快,所以对于性能,我是比较看好的,关于Ab测试的结果,还在测,总之我希望可以秒杀tomcat!(不是集群哦!)

  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Rabbit.js 的定位是一个超轻量的快速开发框架。Light and Fast。你甚至很快就可以理解它的底层实现(也许只需要5分钟)。Rabbit.js本身的代码量并不大,这得益于很多NodeJS开源库的支持,通过 一些有效的组合,成为这样一个简单而清晰的开发框架。 Rabbit.js 能够提供一个清晰的开发思路,让你的应用逻辑清晰并且足够结构化,但是同时又不会增加你的开发复杂度,相反,复杂度被降低,因为在逻辑分层的过程中对很多操作做了封装,你要做的就是关注自己需要关注的逻辑代码,而不用关心框架本身。 Rabbit.js 是一个依靠约定和封装进行工作的框架,秉承约定大于配置的快速开发理念,高度自动化,提高开发效率。不过可能因此降低了一些灵活性,但是本框架的定位决定 其使用场景,Rabbit.js比较适合于中小型项目或者个人项目,得益于其快速开发的特点,可以快速搭建restfull的网络服务。 特色 清晰的应用分层,可以帮助您构建大型的应用,具体见章节“分层” 约定大于配置,基本无需配置,即可开始开发之旅。 约定大于配置,团队合作写出来的应用代码基本一致,方便统一代码风格。 应用的restful的route完全根据目录结构自动生成,无需自己声明和指定。 controller和view之间拥有自动映射,你在controller里无需指定渲染的view路径。 分层之间不采用跳路径方式应用,而是根据名字寻找,无需关心自己和别的分层中得js得目录结构关系。 将controller层,service层,model层做了抽象封装,大部分通用逻辑都已经默认添加,极大的减少代码量。 对model层做了特别封装,同时支持sql和mongodb,写法完全一样。 model层封装成了promise的写法,让你的数据操作更清晰简介。 功能插件系统,开发中,常用的服务器功能一句话引入,例如用户系统,无需开发。 默认为您配置了一个可用的express服务器。 clone下来,查看文档,立马开始您的开发之旅。 标签:Rabbit  Web框架

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值