本节介绍node.js的restful api。

什么是 rest?

rest中文解释为,表述性状态传递(英文:representational state transfer,简称rest),是roy fielding博士在2000年他的博士论文中提出来的一种软件架构风格。

表述性状态转移是一组架构约束条件和原则。满足这些约束条件和原则的应用程序或设计就是restful。

需要注意的是,rest是设计风格而不是标准。rest通常基于使用http,uri和xml(标准通用标记语言下的一个子集)以及html(标准通用标记语言下的一个应用)这些现有的广泛流行的协议和标准。rest通常使用json数据格式。

http 方法

以下为rest基本架构的四个方法:
  • get - 用于获取数据。

  • put - 用于添加数据。

  • delete - 用于删除数据。

  • post - 用于更新或添加数据。


restful web services

web service是一个平台独立的,低耦合的,自包含的、基于可编程的web的应用程序,可使用开放的xml(标准通用标记语言下的一个子集)标准来描述、发布、发现、协调和配置这些应用程序,用于开发分布式的互操作的应用程序。

restful是基于rest架构的web services。

由于轻量级以及通过http直接传输数据的特性,web服务的restful方法已经成为最常见的替代方法。可以使用各种语言(比如,java程序、perl、ruby、python、php和javascript[包括ajax])实现客户端。

restful web服务通常可以通过自动客户端或代表用户的应用程序访问。但是,这种服务的简便性让用户能够与之直接交互,使用它们的web浏览器构建一个get url并读取返回的内容。

更多介绍,可以查看:restful 架构详解


创建 restful

首先,创建一个json数据资源文件users.json,内容如下:

{
   "user1" : {
      "name" : "mahesh",
	  "password" : "password1",
	  "profession" : "teacher",
	  "id": 1
   },
   "user2" : {
      "name" : "suresh",
	  "password" : "password2",
	  "profession" : "librarian",
	  "id": 2
   },
   "user3" : {
      "name" : "ramesh",
	  "password" : "password3",
	  "profession" : "clerk",
	  "id": 3
   }
}

基于以上数据,我们创建以下restful api:

序号urihttp 方法发送内容结果
1listusersget显示所有用户列表
2adduserpostjson 字符串添加新用户
3deleteuserdeletejson 字符串删除用户
4:idget显示用户详细信息

获取用户列表:

以下代码,我们创建了restful api listusers,用于读取用户的信息列表, server.js文件代码如下所示:

var express = require('express');
var app = express();
var fs = require("fs");

app.get('/listusers', function (req, res) {
   fs.readfile( __dirname + "/" + "users.json", 'utf8', function (err, data) {
       console.log( data );
       res.end( data );
   });
})

var server = app.listen(8081, function () {

  var host = server.address().address
  var port = server.address().port

  console.log("应用实例,访问地址为 http://%s:%s", host, port)

})

接下来执行以下命令:

$ node server.js 
应用实例,访问地址为 http://0.0.0.0:8081

在浏览器中访问http://127.0.0.1:8081/listusers,结果如下所示:

{
   "user1" : {
      "name" : "mahesh",
      "password" : "password1",
      "profession" : "teacher",
      "id": 1
   },
   "user2" : {
      "name" : "suresh",
      "password" : "password2",
      "profession" : "librarian",
      "id": 2
   },
   "user3" : {
      "name" : "ramesh",
      "password" : "password3",
      "profession" : "clerk",
      "id": 3
   }
}

添加用户

如果要添加新的用户数据,可以通过创建restful api adduser实现,server.js文件代码如下所示:

var express = require('express');
var app = express();
var fs = require("fs");

//添加的新用户数据
var user = {
   "user4" : {
      "name" : "mohit",
      "password" : "password4",
      "profession" : "teacher",
      "id": 4
   }
}

app.get('/adduser', function (req, res) {
   // 读取已存在的数据
   fs.readfile( __dirname + "/" + "users.json", 'utf8', function (err, data) {
       data = json.parse( data );
       data["user4"] = user["user4"];
       console.log( data );
       res.end( json.stringify(data));
   });
})

var server = app.listen(8081, function () {

  var host = server.address().address
  var port = server.address().port
  console.log("应用实例,访问地址为 http://%s:%s", host, port)

})

接下来执行以下命令:

$ node server.js 
应用实例,访问地址为 http://0.0.0.0:8081

在浏览器中访问http://127.0.0.1:8081/adduser,结果如下所示:

{ user1:
   { name: 'mahesh',
     password: 'password1',
     profession: 'teacher',
     id: 1 },
  user2:
   { name: 'suresh',
     password: 'password2',
     profession: 'librarian',
     id: 2 },
  user3:
   { name: 'ramesh',
     password: 'password3',
     profession: 'clerk',
     id: 3 },
  user4:
   { name: 'mohit',
     password: 'password4',
     profession: 'teacher',
     id: 4 } 
}

显示用户详情

以下代码,我们创建了restful api :id(用户id), 用于读取指定用户的详细信息,server.js文件代码如下所示:

var express = require('express');
var app = express();
var fs = require("fs");

app.get('/:id', function (req, res) {
   // 首先我们读取已存在的用户
   fs.readfile( __dirname + "/" + "users.json", 'utf8', function (err, data) {
       data = json.parse( data );
       var user = data["user" + req.params.id] 
       console.log( user );
       res.end( json.stringify(user));
   });
})

var server = app.listen(8081, function () {

  var host = server.address().address
  var port = server.address().port
  console.log("应用实例,访问地址为 http://%s:%s", host, port)

})

接下来执行以下命令:

$ node server.js 
应用实例,访问地址为 http://0.0.0.0:8081

在浏览器中访问http://127.0.0.1:8081/2,结果如下所示:

{
   "name":"suresh",
   "password":"password2",
   "profession":"librarian",
   "id":2
}

删除用户

以下代码,我们创建了restful api deleteuser, 用于删除指定用户的详细信息,以下实例中,用户id为2,server.js文件代码如下所示:

var express = require('express');
var app = express();
var fs = require("fs");

var id = 2;

app.get('/deleteuser', function (req, res) {

   // first read existing users.
   fs.readfile( __dirname + "/" + "users.json", 'utf8', function (err, data) {
       data = json.parse( data );
       delete data["user" + 2];
       
       console.log( data );
       res.end( json.stringify(data));
   });
})

var server = app.listen(8081, function () {

  var host = server.address().address
  var port = server.address().port
  console.log("应用实例,访问地址为 http://%s:%s", host, port)

})

接下来执行以下命令:

$ node server.js 
应用实例,访问地址为 http://0.0.0.0:8081

在浏览器中访问http://127.0.0.1:8081/deleteuser,结果如下所示:

{ user1:
   { name: 'mahesh',
     password: 'password1',
     profession: 'teacher',
     id: 1 },
  user3:
   { name: 'ramesh',
     password: 'password3',
     profession: 'clerk',
     id: 3 } 
}