目录
一、原生AJAX
1.1 AJAX简介
1.2 XML简介
1.3 AJAX的特点
1.3.1 AJAX的优点
1.3.2 AJAX的缺点
1.4 安装node.js
1.5 安装express
二、HTTP协议请求报文与响应文本结构
2.1 请求报文
2.2 响应报文
2.2.1 案例练习 - AJAX - GET请求的基本操作
2.2.2 案例练习 - AJAX - POST设置请求体
2.2.3 案例练习 - AJAX - 服务端响应JSON数据
三、nodemon安装
四、原生AJAX的基本使用
4.1 IE缓存问题
4.2 请求超时与网络异常处理
4.3 取消请求
4.4 AJAX请求重复发送问题
五、JQuery中的AJAX
5.1 get请求
5.2 post请求
5.3 通用方法
六、Axios发送AJAX请求
6.1 axios - get请求
6.2 axios - post请求
6.3 axios函数发送请求
七、fetch函数发送AJAX请求
八、跨域
8.1 同源策略
8.1.1 同源策略案例练习
8.2 如何解决跨域
8.2.1 JSONP
8.2.2 jQuery发送jsonp请求
8.3 CORS
AJAX,即异步的JS和XML。通过AJAX可以在浏览器中向服务器发送异步请求,最大优势:无刷新获取数据。AJAX是一中将现有的标准组合在一起使用的新方式
在网页中的应用:
XML 可扩展标记语言
XML 被设计用来传输和存储数据
XML和HTML类似,不同的是HTML中都是预定义标签,而XML中没有预定义标签,全是自定义标签,用来表示一些数据
Node.js 中文网Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境。Node.js 使用了一个事件驱动、非阻塞式 I/O 的模型,使其轻量又高效。Node.js 的包管理器 npm,是全球最大的开源库生态系统。http://nodejs.cn/
1.终端初始化环境
npm init --yes
2. 下载express包
npm install express --save
3. 代码编写
// 1. 引入express
const express = require('express');
// 2. 创建应用对象
const app = express();
// 3. 创建路由规则
// request 是对请求报文的封装
// response 是对响应报文的封装
app.get('/', (request,response)=>{
// 设置响应
response.send('HELLP EXPRESS');
});
// 4. 监听端口启动服务
app.listen(8000, ()=>{
console.log('服务已经其中,8000端口监听中');
});
4. 终端运行
node express基本使用.js
行 GET / POST /s?ie=utf-8 HTTP/1.1
头 Host:
Cookie:
Content-type:
User-Agent:
空行
体 例如:username:admin&password=admin
(行 为GET,请求体为空;行 为POST,请求体可以不为空)
行 HTTP/1.1 200 OK
头 Content-Type: text/html;charst=utf-8
Content-length: 2048
Content-encoding: gzip
空行
体
....
案例前操作,需先安装nodeJS
server.js
// 1. 引入express
const express = require('express');
// 2. 创建应用对象
const app = express();
// 3. 创建路由规则
// request 是对请求报文的封装
// response 是对响应报文的封装
app.get('/server', (request,response)=>{
// 设置响应头 设置允许跨域
response.setHeader('Access-Control-Allow-Origin','*');
// 设置响应体
response.send('HELLO AJAX');
});
// 4. 监听端口启动服务
app.listen(8000, ()=>{
console.log('服务已经启动, 8000端口监听中');
});
1-GET.html
AJAX GET 请求
server.js 添加新的代码段,并重启服务
app.post('/server', (request,response)=>{
// 设置响应头 设置允许跨域
response.setHeader('Access-Control-Allow-Origin','*');
// 设置响应体
response.send('HELLO AJAX POST');
});
2-POST.html
AJAX POST请求
鼠标移动入框内
请求体
server.js 添加新的代码段,并重启服务
app.all('/json-server', (request,response)=>{
// 设置响应头 设置允许跨域
response.setHeader('Access-Control-Allow-Origin','*');
// 设置响应头
response.setHeader('Access-Control-Allow-Headers','*');
// 响应一个数据
const data = {
name: '9527'
}
let str = JSON.stringify(data);
response.send(data);
});
3-JSON.html
JSON响应
点击键盘后
前提条件:已经安装nodeJS
nodemon可以使在修改服务器端文件后,会自动检测重启服务,省略手动重启步骤
nodemon - npm (npmjs.com)https://www.npmjs.com/package/nodemon
终端内输入
npm install -g nodemon
启动服务
nodemon [your node app]
如果出现禁止允许脚本问题,在nodemon前加npx
npx nodemon [your node app]
server.js 添加新的代码段
app.get('/ie', (request,response)=>{
// 设置响应头 设置允许跨域
response.setHeader('Access-Control-Allow-Origin','*');
// 设置响应体
response.send('HELLO IE');
});
4-IE.html
IE缓存问题
server.js 添加新的代码段
// 延时响应
app.get('/delay', (request,response)=>{
// 设置响应头 设置允许跨域
response.setHeader('Access-Control-Allow-Origin','*');
setTimeout(() => {
response.send('延时响应');
},3000)
});
5-超时与网络异常.html
请求超时与异常问题处理
取消请求
重复请求问题
server.js
app.all('/jquery-server',(request,response) =>{
response.setHeader('Access-Control-Allow-Origin','*');
response.send('Hello JQuery AJAX');
});
$.get(url, [data], [callback], [type])
$('button').eq(0).click(function(){
$.get('http:127.0.0.1:8000/jquery-server',{a:1,b:2},function(data){
console.log(data);
})
});
$.post(url, [data], [callback], [type])
$('button').eq(1).click(function(){
$.post('http:127.0.0.1:8000/jquery-server',{a:1,b:2},function(data){
console.log(data);
})
});
app.all('/jquery-server',(request,response) =>{
response.setHeader('Access-Control-Allow-Origin','*');
// response.send('Hello JQuery AJAX');
let data = {name:'9527'};
response.send(JSON.stringify(data));
});
$('button').eq(2).click(function(){
$.ajax({
// url
url: 'http://127.0.0.1:8000/jquery-server',
// 参数
data: {a:1, b:2},
// 请求类型
type: 'GET',
// 响应体结果
dataType: 'json',
//成功回调
success: function(data){
console.log(data);
},
// 超时事件
timeout: 2000,
// 失败回调
error:function(){
console.log('出错!');
}
});
});
GitHub - axios/axios: Promise based HTTP client for the browser and node.jshttps://github.com/axios/axiosaxios (v0.26.1) - Axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 Node.js 中。 | BootCDN - Bootstrap 中文网开源项目免费 CDN 加速服务https://www.bootcdn.cn/axios/
server.js
app.all('/asiox-server',(request,response) =>{
response.setHeader('Access-Control-Allow-Origin','*');
response.setHeader('Access-Control-Allow-Headers','*');
let data = {name:'9527'};
response.send(JSON.stringify(data));
});
const btns = document.querySelectorAll('button');
// 配置 baseURL
axios.defaults.baseURL = 'http://127.0.0.1:8000';
btns[0].onclick = function(){
// GET 请求
axios.get('/axios-server',{
// url 参数
params: {
id: 10001,
vip: 7
},
// 请求头信息
headers: {
name: 'zhang3',
age: 24
}
}).then(value => {
console.log(value);
});
}
btns[1].onclick = function(){
axios.post('/axios-server',
{
username: 'admin',
password: 'admin123'
},
{
params: {
id: 1002,
vip: 2
},
headers: {
height: 180,
weight: 70
}
})
}
btns[2].onclick = function(){
axios({
// 请求方法
method: 'POST',
// url
url: '/axios-server',
// url参数
params: {
id: 1003,
vip: 10
},
// 头信息
headers: {
a:1,
b:2
},
// 请求体参数
data: {
username: 'admin',
password: 'admin123'
}
}).then(response=>{
// 响应状态码
console.log(response.status);
// 响应状态字符串
console.log(response.statusText);
// 响应头信息
console.log(response.headers);
// 响应体
console.log(response.data);
})
}
WorkerOrGlobalScope.fetch() - Web API 接口参考 | MDN (mozilla.org)https://developer.mozilla.org/zh-CN/docs/Web/API/fetch语法
Promisefetch(input[, init]);
server.js 添加代码段
app.all('/fetch-server',(request,response) =>{
response.setHeader('Access-Control-Allow-Origin','*');
response.setHeader('Access-Control-Allow-Headers','*');
let data = {name:'9527'};
response.send(JSON.stringify(data));
});
fetch.html
违背同源策略就是跨域
server.js
const express = require('express');
const app = express();
app.get('/home',(request,response)=>{
response.sendFile(__dirname+'/index.html');
});
app.get('/data',(request,response)=>{
response.send('用户数据');
})
app.listen(9000,()=>{
console.log('服务已经启动...');
});
index.html
同源策略测试案例
1. JSONP是什么
JSONP(JSON with Padding),是一个非官方的跨域解决方案,只支持get请求
2. JSONP怎么工作的
在网页有一些标签天生具有跨域能力,比如:img、link、iframe、script
JSONP就是利用script标签的跨域能力来发送请求的
3. JSONP的使用
1) 动态的创建一个script标签
var script = document.createElement('script');
2) 设置 script 的src ,设置回调函数
script.src = "http://localhost:3000/testAJAX?callback=abc";
function abc(data) {
alert(data.name);
};
3)将script插入到文档中
document.body.appendChild(script);
4)原生JSONP实践 - 案例练习
server.js添加代码段
app.all('/check-username',(request,response) => {
const data = {
exist:1,
msg:'用户名已经存在'
}
let str = JSON.stringify(data);
response.end(`handle(${str})`);
});
jsonp.html
用户名:
server.js添加代码段
app.all('/jquery-jsonp-server',(request,response) => {
const data = {
name:'王小明',
city:['厦门','上海','深圳']
}
let str = JSON.stringify(data);
// 接收 callback 参数
let cb = request.query.callback;
response.end(`${cb}(${str})`);
});
jquery-jsonp.html
jQuery发送jspon请求
跨源资源共享(CORS) - HTTP | MDN跨源资源共享 (CORS)(或通俗地译为跨域资源共享)是一种基于 HTTP 头的机制,该机制通过允许服务器标示除了它自己以外的其它origin(域,协议和端口),这样浏览器可以访问加载这些资源。跨源资源共享还通过一种机制来检查服务器是否会允许要发送的真实请求,该机制通过浏览器发起一个到服务器托管的跨源资源的"预检"请求。在预检中,浏览器发送的头中标示有HTTP方法和真实请求中会用到的头。https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Access_control_CORS
1. CORS 是什么?
CORS(Cross-Origin Resource Sharing),跨域资源共享。CORS 是官方的跨域解决方 案,它的特点是不需要在客户端做任何特殊的操作,完全在服务器中进行处理,支持 get 和post 请求。跨域资源共享标准新增了一组HTTP 首部字段,允许服务器声明哪些 源站通过浏览器有权限访问哪些资源
2. CORS 怎么工作的?
CORS 是通过设置一个响应头来告诉浏览器,该请求允许跨域,浏览器收到该响应 以后就会对响应放行。
3. CORS的使用
主要是服务器端的设置:
app.all("/cors-server" , function (request , response) {
//通过response 来设置响应头,来允许跨域请求
response.set("Access-Control-Allow-Origin","*");
response.set("Access-Control-Allow-Headers","*");
response.set("Access-Control-Allow-Method","*");
response.send("hello CORS");
});