JS在线运行

版本:

所属目录
点击了解高性能代码运行API
运行结果
教程手册
代码仓库
极速运行
终端运行
图形+终端

                        
以下是用户最新保存的代码
思源鼠标移入大纲自动展开子标题 发布于:2024-09-25 02:49 思源建文档的时候自动设置为自定义的某个图标 发布于:2024-09-22 06:35 异步任务线程池 发布于:2024-09-21 16:42 JS的各种锻炼 发布于:2024-09-13 16:53 思源同步感知脚本 发布于:2024-09-16 11:42 在线测试各种脚本! 发布于:2024-09-12 14:37 思源编辑器增加标尺 发布于:2024-09-11 16:21 思源查询不在数据库中的文档2 发布于:2024-09-07 16:32 思源简单锁定笔记 发布于:2024-09-07 23:38 项目热度榜单 发布于:2024-09-06 15:20 修改z坐标 发布于:2024-09-06 15:23 带千分符的大小比较 发布于:2024-09-06 13:05 altG临时 发布于:2024-09-09 18:08 批量导入文档到数据库0.0.6版 发布于:2024-09-25 23:51 最长合法表达式 发布于:2024-09-04 21:55 API集群负载统计 发布于:2024-09-04 19:04 英文输入法 字符串 发布于:2024-09-04 15:05 RMS 变量 发布于:2024-09-04 14:44 最少停车数/停车场车辆统计 发布于:2024-09-04 15:02 hwod面试题联系 发布于:2024-09-06 15:17 时间转换测试 发布于:2024-09-04 09:41 原生JS消息响应 发布于:2024-09-09 18:08 批量导入指定文档及其子文档到指定数据库(0.0.4) 发布于:2024-09-03 04:13 批量导入指定文档及其子文档到指定数据库 发布于:2024-09-05 03:21 思源查询不在数据库中的文档 发布于:2024-09-07 16:37 思源js代码片段获取移动端设备ip 发布于:2024-09-01 12:55 无重复的最长字串儿 发布于:2024-08-28 21:42 思源为数据库文档列表项匹配已设置文档icon * 每次重启时刷新获取的icon * 通过localStorage存储icon(存储方式待优化) > 更新了空文本的处理 发布于:2024-08-28 17:34 你好多阿发 发布于:2024-08-27 11:15 按规则拆分 发布于:2024-08-27 11:07 删除字母匹配到字典里的最长单词 发布于:2024-08-28 20:49 给定一个字符串s和数组arr,找到数组中最长的串, 该串儿可以通过删除s中某些元素得到; 发布于:2024-08-26 17:41 链滴自动签到puppeteer脚本 发布于:2024-08-23 11:51 思源实现斜杠命令菜单展开并支持左右方向键 发布于:2024-08-24 13:15 测试用例20240821 发布于:2024-08-21 16:23 js-arr-tree 发布于:2024-08-21 15:04 给定一个数组找到三个元素,其之和与目标target最接近; 发布于:2024-08-28 20:18 测试批量表单验证 发布于:2024-08-20 17:12 就属于黑色口罩 发布于:2024-08-16 20:44 / 分组 ←→快速切换分组 发布于:2024-08-16 19:08 模拟window.prompt函数 发布于:2024-08-15 10:09 思源Asri主题斜杠命令方向键选择菜单 发布于:2024-08-16 17:21 yield结合promise 发布于:2024-08-12 10:48 edge接入 发布于:2024-08-06 14:30 思源数据库和图表关联脚本示例 发布于:2024-08-06 08:05 自动聚焦当前文档所在目录 发布于:2024-07-30 07:33 JavaScript实现一个带并发限制的异步调度器,保证同时最多运行2个任务 发布于:2024-07-28 18:18 模版字符串翻译替换 发布于:2024-07-25 23:21 识别算法测试 发布于:2024-07-24 15:59 影刀能捕捉Web前端页面的控件、元素,但是在运行的时候鼠标无法正确点击在元素之上。 发布于:2024-09-26 19:55 [更多]
显示目录

RESTful API



学习嵌入式的绝佳套件,esp8266开源小电视成品,比自己去买开发板+屏幕还要便宜,省去了焊接不当搞坏的风险。 蜂鸣版+触控升级仅36元,更强的硬件、价格全网最低。

点击购买 固件广场

Node.js RESTful API

本节介绍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

首先,创建一个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:

URI HTTP 方法 发送内容 结果
listUsers GET 显示所有用户列表
addUser POST JSON 字符串 添加新用户
deleteUser DELETE JSON 字符串 删除用户
:id GET 显示用户详细信息

获取用户列表:

以下代码,我们创建了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 } 
}`
由JSRUN为你提供的JS在线运行、在线编译工具
        JSRUN提供的JS 在线运行,JS 在线运行工具,基于linux操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。
yout