node.js 数据模拟
Node: js在服务端的一个运行环境
node框架:express koa egg (本文采用express)
express: 是基于node的一个web框架
restful api:是目前流行的api设计规范,用于web数据接口设计
特点:动词+宾语
请求方式:Get, 地址: /api/articles
步骤:
1.安装node,安装后就有npm
2.生成依赖包管理文件,命令npm init -y 在项目的根目录(package.json)
3.下载依赖包, npm install -S express
4.启动服务:node xxx.js
参数传递:
get:适合查询方式,参数较少
1. 前端 :通过 http://192.168.0.111:8080?key=value传参数
后端(node):通过 request.query.key 取参数
参数在【Query string】
2. 通过尾部拼接传参: http://192.168.0.11:3000/info/value value即参数
后端取参数:request.params.key
post: 在跨域的时候发送两次请求(第一次试探性,第二次真实的请求)
1.发送json格式的参数
参数在【request payload】
node中接收参数采用: request.body
2.表单格式 key = value
参数在【from data】
jq默认使用【from data】发送数据
jq使用以下方式发送json数据 contentType:“appliction/json”, data:JSON.stringify({name:'tony",age:20}),
node中接收参数采用: request.body
eg:后端 (node)xxx.js文件
var express = require('express');//加载包
var bodyParse = require("body-parser"); //处理参数
var app = express();
// 处理跨域问题
var allowCrossDomain = function(req,res,next){
res.header("Access-Control-Allow-Origin","*"); // 允许的请求源 从哪里来
res.header("Access-Control-Allow-Headers","*"); // 允许的请求头
res.header("Access-Control-Allow-Methods","*"); // 允许的请求方法 get post put
next(); // 下一步
}
app.use(allowCrossDomain);
// 添加参数
app.use(bodyParse.json()) //处理json数据0
app.use(bodyParse.urlencoded({extended:true})) // 处理表单数据或者url
// 第一个接口
app.get('/',function(request,response){ // 定义一个Get请求 地址:/
response.send("my web serve"); // 发送信息
})
// 第二个接口 ?形式
app.get("/info",function(request,response){
// 拿到?后面的参数 request,query.name
console.log(request.query.name)
var data = {
code:"200",
msg:"success",
request:"XXXXXXXX"
}
response.send(JSON.stringify(data))
})
// 第三个接口 格式: 参数名
app.get("/info/:name",function(request,response){
// :参数名 res.params.name
console.log(request.params.name)
var data = {
code:"200",
msg:"success",
request:"XXXXXXXX"
}
response.send(JSON.stringify(data))
})
// 第四个接口 格式: 参数名
app.post("/info4",function(request,response){
// :参数名 res.params.name
console.log(request.body)
var data = {
code:"200",
msg:"success",
request:"XXXXXXXX"
}
response.send(JSON.stringify(data))
})
// 监听3000端口
app.listen(3000,function(){
console.log("服务已启动,端口3000"); // 服务启动完成时的日志
})
eg:前端页面
function getXMLHttpRequest(){
var xmlhttp; //ajax
if(window.ActiveXObject){ //判断是否有此对象
// ie5 ie6
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}else if(window.XMLHttpRequest){ //判断是否有此对象
// ie7+ ff chrome 浏览器原生
xmlhttp = new XMLHttpRequest();
}else {
xmlhttp = null;
}
return xmlhttp
}
function getData(){
var xmlhttp = getXMLHttpRequest();
// true异步 false同步
// get 方法请求
// xmlhttp.open('get','http://localhost:3000',true); // 无参数
// xmlhttp.open('get','http://localhost:3000/info?name=lisi',true); // 参数以?的形式拼接
// xmlhttp.open('get','http://localhost:3000/info/tom',true); // 参数直接拼接
// xmlhttp.send();//发送请求
// post 方法请求
xmlhttp.open('post','http://localhost:3000/info4',true);
//json
// 指定内容类型
xmlhttp.setRequestHeader("Content-Type","appliaction/json");
xmlhttp.send(JSON.stringify({"name":"jonu","age":20}));
xmlhttp.onreadystatechange = function(){
//200 请求成功
if(xmlhttp.readyState == 4 && xmlhttp.status == 200){
console.log(xmlhttp.responseText);
}
}
}
getData()
node.js 数据模拟的更多相关文章
- 十个书写Node.js REST API的最佳实践(下)
收录待用,修改转载已取得腾讯云授权 5. 对你的Node.js REST API进行黑盒测试 测试你的REST API最好的方法之一就是把它们当成黑盒对待. 黑盒测试是一种测试方法,通过这种方法无需知 ...
- node.js学习(三)简单的node程序&&模块简单使用&&commonJS规范&&深入理解模块原理
一.一个简单的node程序 1.新建一个txt文件 2.修改后缀 修改之后会弹出这个,点击"是" 3.运行test.js 源文件 使用node.js运行之后的. 如果该路径下没有该 ...
- 利用Node.js的Net模块实现一个命令行多人聊天室
1.net模块基本API 要使用Node.js的net模块实现一个命令行聊天室,就必须先了解NET模块的API使用.NET模块API分为两大类:Server和Socket类.工厂方法. Server类 ...
- Node.js:进程、子进程与cluster多核处理模块
1.process对象 process对象就是处理与进程相关信息的全局对象,不需要require引用,且是EventEmitter的实例. 获取进程信息 process对象提供了很多的API来获取当前 ...
- Node.js:理解stream
Stream在node.js中是一个抽象的接口,基于EventEmitter,也是一种Buffer的高级封装,用来处理流数据.流模块便是提供各种API让我们可以很简单的使用Stream. 流分为四种类 ...
- Node.js:Buffer浅谈
Javascript在客户端对于unicode编码的数据操作支持非常友好,但是对二进制数据的处理就不尽人意.Node.js为了能够处理二进制数据或非unicode编码的数据,便设计了Buffer类,该 ...
- node.js学习(二)--Node.js控制台(REPL)&&Node.js的基础和语法
1.1.2 Node.js控制台(REPL) Node.js也有自己的虚拟的运行环境:REPL. 我们可以使用它来执行任何的Node.js或者javascript代码.还可以引入模块和使用文件系统. ...
- Node.js npm 详解
一.npm简介 安装npm请阅读我之前的文章Hello Node中npm安装那一部分,不过只介绍了linux平台,如果是其它平台,有前辈写了更加详细的介绍. npm的全称:Node Package M ...
- Node.js入门(一)
一.Node.js本质上是js的运行环境. 二.可以解析js代码(没有浏览器安全级的限制): 提供系统级的API:1.文件的读写 2.进程的管理 3.网络通信 三.可以关注的四个网站: 1.https ...
- Node.js学习笔记——Node.js开发Web后台服务
一.简介 Node.js 是一个基于Google Chrome V8 引擎的 JavaScript 运行环境.Node.js 使用了一个事件驱动.非阻塞式 I/O 的模型,使其轻量又高效.Node.j ...
随机推荐
- LVM分区扩容
LVM分区扩容 用户需求: 将根分区有50G扩容到300G,以满足dmdb 集群用户后期增加需求 1. 查看当前硬盘分区情况,看到当前根分区只有50G 2. vgs 查看逻辑卷情况,发现root ...
- linux check folder files how many files
https://linuxhandbook.com/count-number-files/ tree -a
- Hyper-V虚拟机在Win2019server中共用一个公网IP
Hyper-V虚拟机在Win2019server中共用一个公网IP 有时生产环境中希望一台宿主机上的多台虚拟机共用一个IP出口,按以下操作处理即可. 环境: Windows 2019 server D ...
- 将含两列的csv文件生成二维矩阵
gen_diea=pd.read_csv('../data/ddg_data/diea-gene.csv', header=None, names=['diease','gene']) #生成关联矩阵 ...
- ubuntu 替换国内源,清华源
参考 https://mirrors.tuna.tsinghua.edu.cn/help/ubuntu/ Ubuntu 的软件源配置文件是 /etc/apt/sources.list.将系统自带的该文 ...
- esxi虚拟机定时创建快照
1.vim-cmd vmsvc/getallvms 列出所有虚拟机信息 2.获取需要备份的虚拟机的Vmid 3.执行快照 vim-cmd vmsvc/snapshot.create Vmid $( ...
- 解决 ant design vue Carousel 图片不能点击的问题
pointer-events: none 的作用如下: // 阻止用户的点击动作产生任何效果 // 阻止缺省鼠标指针的显示 // 阻止CSS里的hover和active状态的变化触发事件 // 阻止J ...
- MySQL的架构与历史1.5MySQL的存储引擎
1.5 MySQL的存储引擎 1.5.1 InnoDB存储引擎 InnoDB是 MySQL的默认事务型引,也是最重要.使用最广泛的存储引擎.它被设计用来处理大量的短期 (short-lived)事务, ...
- ssl 导入和配置
https://blog.csdn.net/qq_23663693/article/details/121698553
- SpringBoot导读
SpringBoot 一.导读 1.开发工具及技术栈 JDK:jdk1.8.0_191 开发工具:IntelliJIDEA 2020.3.2 SpringBoot: 简化Spring的开发 需要一定的 ...