JS在线运行

版本:

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

                        
以下是用户最新保存的代码
<h1> sort的使用 发布于:2025-07-01 14:35 <h1> slice的使用 发布于:2025-07-01 14:31 <h1> shift的使用 发布于:2025-07-01 14:27 <h1> push的使用 发布于:2025-07-01 14:21 <h1> join的补充与pop的使用 发布于:2025-07-01 14:17 <h1> split与join的使用 发布于:2025-07-01 14:09 <h1> concat的使用 发布于:2025-07-01 11:52 <h1> indexOf的使用 发布于:2025-07-01 11:48 <h1> forEach的使用 发布于:2025-07-01 11:42 <h1> filter的使用 发布于:2025-07-01 11:25 <h1> some使用 发布于:2025-07-01 11:20 <h1> every使用 发布于:2025-07-01 11:16 <h1> reduce使用 发布于:2025-07-01 11:08 <h1> 数组 发布于:2025-07-01 11:05 <h1> 箭头函数 发布于:2025-07-01 10:53 <h1>数组方法 发布于:2025-07-01 11:52 <h1>箭头函数与...rest的结合 发布于:2025-07-01 10:24 <h1>箭头函数知识点 发布于:2025-07-01 10:19 js base64 发布于:2025-06-28 01:16 栅格化所有形状图层 发布于:2025-06-01 16:20 雪花算法ID 发布于:2025-05-30 13:59 Create a new reservation balalal 发布于:2025-06-28 18:44 Main message loop 发布于:2025-05-28 09:33 .env 发布于:2025-05-27 22:57 logger.js 发布于:2025-05-27 22:56 api.js 发布于:2025-05-27 22:56 SchedulerService.js 发布于:2025-05-27 22:55 WebhookService.js 发布于:2025-05-27 22:55 WeChatService.js 发布于:2025-05-27 22:54 database.js 发布于:2025-05-27 22:54 server.js 发布于:2025-05-27 22:53 package.json 发布于:2025-05-27 22:52 suzhou inovance shanglvlianmeng 发布于:2025-06-04 19:05 CryptoJS-node 发布于:2025-05-23 13:51 Promise链式调用示例 发布于:2025-05-21 19:40 扁平化JSON数据 发布于:2025-05-13 16:18 // 1. 粘贴你的原始 JSON 字符串 let raw = `{ "10": { "upgrade": 0 }, "15": { "upgrade": 3 }, "20": { "upgrade": 4 } }`; // 2. 解析为对象 let data = JSON.parse(raw); // 3. 批量处理 upgrade 字段 for (let k in data) { if (data[k].upgrade !== undefined) { data[k].upgrade = Math.floor(data[k].upgrade / 2); // 向下取整 } } // 4. 输出新 JSON 字符串 console.log(JSON.stringify(data, null, 2)); 发布于:2025-05-13 10:39 AES加解密 发布于:2025-05-08 13:31 ceshi damai 发布于:2025-05-06 22:53 新编写的企划内容 发布于:2025-04-30 20:25 JavaScript脚本与MongoDB服务器交互 发布于:2025-04-30 14:09 临时使用代码 发布于:2025-04-29 20:00 - 统计数组里最多的元素,并排序 - 构建树形结构并进行后续遍历 发布于:2025-06-05 15:27 手写防抖和节流 发布于:2025-05-16 16:58 check in balalal 发布于:2025-05-25 11:42 最近一次给学姐的代码 发布于:2025-04-26 13:13 JS AES128加解密 发布于:2025-04-21 13:44 最小矩阵宽度(从第一列开始一列列加,直到判断子矩阵内包含数组的所有元素) 发布于:2025-04-16 19:10 最小交付时间(二分+回溯:先将数组排序,最小值start=Math.max(arr),最大值end = arr.reduce,回溯中创建一个新的工人数组,每次遍历数组时将数组中的每一个元素都尝试分配给worker[i]) 发布于:2025-04-16 18:53 阿里巴巴找黄金宝箱Ⅳ(单调栈:栈中存储单调递减的元素的集合,当找到比栈顶元素大的元素时,循环出栈直到栈顶元素不小于当前元素) 发布于:2025-04-15 17:47 [更多]
显示目录

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