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 ...
随机推荐
- uniapp 中获取微信小程序的原生导航栏高度
const custom = wx.getMenuButtonBoundingClientRect() // console.log(custom) that.yuansheng= custom.he ...
- YOLO v6:一个硬件友好的目标检测算法
本文来自公众号"AI大道理" YOLOv6 是美团视觉智能部研发的一款目标检测框架,致力于工业应用. YOLOv6支持模型训练.推理及多平台部署等全链条的工业应用需求,并在 ...
- Ubuntu16.04设置root以及root用户自动登录
自己之前做的笔记确实不是很详细.因为像是一些环境的配置,即使是这样做,但是自己大概率下是不知道这样做的原因,所以很多东西能不能弄好是有很大的运气成分在里面.所以就很需要记录下自己到底干了些什么. 所以 ...
- fragment加radio不可滑动
public class MainActivity extends AppCompatActivity implements RadioGroup.OnCheckedChangeListener { ...
- 【ZYNQ学习】ZYNQ架构介绍
在上一篇博客中,主要介绍了ZYNQ的基本信息以及如何在vivado上实现自己的设计,但是在实际应用中,掌握ZYNQ的架构是必要的,因此在这篇博客中主要记录一下ZYNQ的架构 本篇博客的主要参考是ZYN ...
- 关于 verilator 中 config.vlt 等配置文件的使用
参考网页:https://verilator.org/guide/latest/exe_verilator.html#configuration-files 注意,在使用 config.vlt 配置文 ...
- TCP 协议之三次握手(一)
(声明:本文是阅读此文的总结笔记) 面试中对于该知识点的考察频繁,一般作为面试的暖场问题,你能够答出多少,答得多深刻,条理多清晰,给面试官的印象真的很重要. 三次握手的过程 TCP是面向连接的,全双工 ...
- nginx代理出现上传文件过大解决办法
1.错误描述 2.错误原因 1.上传文件时,利用localhost访问系统,不会出现这个问题:用域名访问这个系统时,出现这个问题,提示是:请求实体太大 由于Nginx反向代理服务器client_max ...
- 解决MyBatis-Plus修改为null值无效的问题
@TableField(strategy = FieldStrategy.IGNORED)
- DNS服务器(简)
服务端:192.168.182.187 客户端:192.168.182.16 windows客户端:192.168.182.17 1.安装相关服务 yum -y install bind bind-c ...