查看“Node.js:RESTful API”的源代码
←
Node.js:RESTful API
跳到导航
跳到搜索
因为以下原因,您没有权限编辑本页:
您请求的操作仅限属于该用户组的用户执行:
用户
您可以查看和复制此页面的源代码。
[[category:Node.js教程]] == 关于 == <pre> 什么是 REST? REST 即“表述性状态传递”(英文:Representational State Transfer,简称 REST)是 Roy Fielding 博士在2000年他的博士论文中提出来的一种软件架构风格。 表述性状态转移是一组架构约束条件和原则。满足这些约束条件和原则的应用程序或设计就是 RESTful。 REST通常基于使用 HTTP,URI,和 XML(标准通用标记语言下的一个子集)以及 HTML(标准通用标记语言下的一个应用)这些现有的广泛流行的协议和标准。 需要注意的是: 1、REST是设计风格而不是标准。 2、REST 通常使用 JSON 数据格式。 </pre> 以下为 REST 基本架构的四个方法: # '''GET''':用于获取数据; # '''POST''':用于添加数据。 # '''PUT''':用于更新或添加数据; # '''DELETE''':用于删除数据; == RESTful Web Services == <pre> Web service 是一个平台独立的,低耦合的,自包含的、基于可编程的 web 的应用程序,可使用开放的 XML 标准来描述、发布、发现、协调和配置这些应用程序,用于开发分布式的互操作的应用程序。 基于 REST 架构的 Web Services 即是 RESTful。 由于轻量级以及通过 HTTP 直接传输数据的特性,Web 服务的 RESTful 方法已经成为最常见的替代方法。可以使用各种语言(比如 Java 程序、Perl、Ruby、Python、PHP 和 Javascript[包括 Ajax])实现客户端。 RESTful Web 服务通常可以通过自动客户端或代表用户的应用程序访问。但是,这种服务的简便性让用户能够与之直接交互,使用它们的 Web 浏览器构建一个 GET URL 并读取返回的内容。 </pre> 参考:[https://www.runoob.com/w3cnote/restful-architecture.html 菜鸟教程:RESTful 架构详解] == 创建 RESTful == 创建一个 json 数据资源文件 users.json: <syntaxhighlight lang="Json" highlight=""> { "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 } } </syntaxhighlight> 基于以上数据,我们创建以下 RESTful API: {| class="wikitable" ! 序号 !! URI !! HTTP 方法 !! 发送内容 !! 结果 |- | 1 || listUsers || GET || 空 || 显示所有用户列表 |- | 2 || addUser || POST || JSON 字符串 || 添加新用户 |- | 3 || deleteUser || DELETE || JSON 字符串 || 删除用户 |- | 4 || :id || GET || 空 || 显示用户详细信息 |} === 获取用户列表 === 示例:创建 RESTful API listUsers,用于读取用户的信息列表: # server.js 文件代码如下所示: #: <syntaxhighlight lang="JavaScript" highlight=""> 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) }) </syntaxhighlight> # 接下来执行以下命令: #: <syntaxhighlight lang="bash" highlight=""> $ node server.js 应用实例,访问地址为 http://0.0.0.0:8081 </syntaxhighlight> # 在浏览器中访问 http://127.0.0.1:8081/listUsers ,结果如下所示: #: <syntaxhighlight lang="Json" highlight=""> { "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 } } </syntaxhighlight> === 添加用户 === 示例:创建 RESTful API addUser, 用于添加新的用户数据: # server.js 文件代码如下所示: #: <syntaxhighlight lang="JavaScript" highlight=""> 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) }) </syntaxhighlight> # 接下来执行以下命令: #: <syntaxhighlight lang="bash" highlight=""> $ node server.js 应用实例,访问地址为 http://0.0.0.0:8081 </syntaxhighlight> # 在浏览器中访问 http://127.0.0.1:8081/addUser ,结果如下所示: #: <syntaxhighlight lang="Json" highlight=""> { 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 } } </syntaxhighlight> === 显示用户详情 === 示例:创建了 RESTful API :id(用户id), 用于读取指定用户的详细信息: # server.js 文件代码如下所示: #: <syntaxhighlight lang="JavaScript" highlight=""> 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) }) </syntaxhighlight> # 接下来执行以下命令: #: <syntaxhighlight lang="bash" highlight=""> $ node server.js 应用实例,访问地址为 http://0.0.0.0:8081 </syntaxhighlight> # 在浏览器中访问 http://127.0.0.1:8081/2 ,结果如下所示: #: <syntaxhighlight lang="Json" highlight=""> { "name":"suresh", "password":"password2", "profession":"librarian", "id":2 } </syntaxhighlight> === 删除用户 === 示例:创建 RESTful API deleteUser,用于删除指定用户的详细信息 # server.js 文件代码如下所示: #: <syntaxhighlight lang="JavaScript" highlight=""> 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" + id]; 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) }) </syntaxhighlight> # 接下来执行以下命令: #: <syntaxhighlight lang="bash" highlight=""> $ node server.js 应用实例,访问地址为 http://0.0.0.0:8081 </syntaxhighlight> # 在浏览器中访问 http://127.0.0.1:8081/deleteUser ,结果如下所示: #: <syntaxhighlight lang="Json" highlight=""> { user1: { name: 'mahesh', password: 'password1', profession: 'teacher', id: 1 }, user3: { name: 'ramesh', password: 'password3', profession: 'clerk', id: 3 } } </syntaxhighlight> == FAQ == === 乱码问题 === 遇到乱码的问题:除了不是文件读取的编码问题,可以考虑设置浏览器自动为没有在 html > head 中解释编码的 html 编码为本地默认编码。 可以主动添加 head: <syntaxhighlight lang="JavaScript" highlight=""> res.setHeader('Content-Type', 'text/html; charset=utf8'); </syntaxhighlight>
返回至“
Node.js:RESTful API
”。
导航菜单
个人工具
登录
命名空间
页面
讨论
大陆简体
已展开
已折叠
查看
阅读
查看源代码
查看历史
更多
已展开
已折叠
搜索
导航
首页
最近更改
随机页面
MediaWiki帮助
笔记
服务器
数据库
后端
前端
工具
《To do list》
日常
阅读
电影
摄影
其他
Software
Windows
WIKIOE
所有分类
所有页面
侧边栏
站点日志
工具
链入页面
相关更改
特殊页面
页面信息