目录
[一、原生 AJAX](#一、原生 AJAX)
[(一)AJAX 介绍](#(一)AJAX 介绍)
[(二)XML 介绍](#(二)XML 介绍)
[(三)AJAX 的特点](#(三)AJAX 的特点)
[二、HTTP 协议](#二、HTTP 协议)
[(一)HTTP 介绍](#(一)HTTP 介绍)
[(二)HTTP 报文 格式与参数](#(二)HTTP 报文 格式与参数)
[(三)浏览器查看 HTTP 报文](#(三)浏览器查看 HTTP 报文)
[(一)Node.js 介绍](#(一)Node.js 介绍)
一、原生 AJAX
(一)AJAX 介绍
1.理解
AJAX 全称是 Asynchronous JavaScript And XML
根据意思就是异步的 JS 和 XML
AJAX 不是新的编程语言 是将现有的标准组合在一起使用的新方式
2.作用
可以在浏览器中向服务器发送异步请求
3.最大的优势
无刷新获取数据
4.应用例子
百度搜索栏 中搜索 下拉列表出现相关的关键字信息
注册用户名时 查看用户名是否与数据库里面的用户名重复
淘宝 鼠标放到相应的分类上,就请求服务器加载相应的模块,用户不用就不加载
今日头条 刷今日头条时 滚动新闻到底时 向服务器发送 ajax 请求 然后服务器返回资源 通过 js 创建相应的模块
(二)XML 介绍
1.理解
XML 全称叫做可扩展标记语言
和 HTML 超文本标记语言 类似,都是由标签组成的,但是 HTML 里面都是预定义标签 就是都是本来就定义好的标签,标签不是我们自己起的名 。XML 里面都是自定义标签
之前浏览器实现上面的应用例子就是使用 AJAX 让 服务器向浏览器返回 XML 文件数据的形式实现的
现在已经被 JSON 取代了
2.作用
被设计用来传输和存储数据
HTML 是用来呈现数据
(三)AJAX 的特点
1.优点
无需刷新页面与服务器进行通信
允许我们根据用户事件来更新部分页面内容
2.缺点
没有浏览历史不能回退,就是使用 AJAX 不能回退
存在跨域问题 就是默认不能 从A.com 向 B.com 发送 AJAX请求
对 SEO 优化不友好 在网页源代码中找不到想用的信息,源代码是响应体,不能用爬虫爬到商品信息
二、HTTP 协议
(一)HTTP 介绍
全称是 hypertext transport protocol 超文本传输协议,详细规定了浏览器和万维网服务器之间相互通信的规则
网页都用到 HTTP 协议,包含两个过程
浏览器向服务器发送请求服务,发送的请求内容就叫请求报文
服务器进行响应, 响应后返回给浏览器的内容就叫响应报文
(二)HTTP 报文 格式与参数
格式和参数是重点
1.请求报文
请求行:
1、请求类型: get / post
2、url :/s?ie=utf-8
3、 版本: HTTP/1.1
请求头:
形式都是 Host: hahah.com 这样的名字冒号空格加值的形式
空行:
必须有的空行
请求体:
可以有可以没有
如果是 get 请求 请求体为空
如果是 post 请求 请求体可以不为空 useraname=admin&password=admin
2.响应报文
响应行:
1、版本: HTTP/1.1
2、响应状态码:200 404 503 401 500 200 等
3、状态字符串: OK
响应头:

空行:
必须有的空行
响应体:
返回的 html 的格式放在这里 浏览器会把响应体的内容提出出来解析,在页面渲染和显现

(三)浏览器查看 HTTP 报文
百度搜索谷粒学院 点击 network(网络) 按 f12 刷新 到如下页面
当前网站所有发送的请求都会列出来

点击第一个 ,右边出现另一个标签域 主要看 Headers (消息头)和 Response(请求)
Headers:
主要看 Response Headers(响应头)和 Request Headers(请求头)
先看 Request Headers(请求头),里面都是请求头的内容
查到的请求行的内容 :
javascript
GET /s?ie=utf-8&f=8&rsv_bp=1&rsv_idx=1&tn=monline_3_dg&wd=%E8%B0%B7%E7%B2%92%E5%AD%A6%E9%99%A2&fenlei=256&rsv_pq=0xa243dec300563c69&rsv_t=423d6bjsnQ7jIKSr4gKgYoZnI6gEitQBkZMM5YutvpoOYcT42XjiOdZ9IkyHAEcabaQS&rqlang=en&rsv_dl=ib&rsv_enter=1&rsv_sug3=30&rsv_sug1=25&rsv_sug7=101 HTTP/1.1
查到的请求头内容 :
都是名字冒号 空格内容的格式
javascript
Host: www.baidu.com
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:124.0) Gecko/20100101 Firefox/124.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,*/*;q=0.8
Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2
Accept-Encoding: gzip, deflate, br
Connection: keep-alive
Cookie: BAIDUID=7DCC82ADD4258F05619537EBC525C6DC:FG=1; BIDUPSID=7DCC82ADD4258F0548070E60074AEBFC; PSTM=1710229679; BD_UPN=13314752; H_PS_PSSID=40080_40377_40415_40304_40465_40481_39662_40510_40514_40398_40446_60043_60027_60031_60046; BDORZ=FFFB88E999055A3F8A630C64834BD6D0; H_PS_645EC=01f3chrp9JvriT98psI3s1%2Fnj2yTwDT2n1EROd6H76K27TXD%2F3vhG5FSLD%2FwlWH6J0XW; BA_HECTOR=a18g01012hah04212g2h8k2kcnba2a1j0la631t; ZFY=sn:AMmt3ZqRqrj8YYt6fZ5tnF0cnOqwEERvmi0qhfhts:C; delPer=0; BD_CK_SAM=1; PSINO=1; BDRCVFR[Fc9oatPmwxn]=mk3SLVN4HKm
Upgrade-Insecure-Requests: 1
Sec-Fetch-Dest: document
Sec-Fetch-Mode: navigate
Sec-Fetch-Site: none
Sec-Fetch-User: ?1
get 类型请求体为空
再看过滤字符串:是对请求行中的 url 中的参数进行解析 对以后调试参数很方便 看看数据是否发送过去
看响应

查到的响应行内容:
javascript
HTTP/1.1 200 OK
查到的响应头内容 :
javascript
Bdpagetype: 3
Bdqid: 0xe5f8700d000082d2
Cache-Control: private
Ckpacknum: 2
Ckrndstr: d000082d2
Connection: keep-alive
Content-Encoding: br
Content-Security-Policy: frame-ancestors 'self' https://chat.baidu.com http://mirror-chat.baidu.com https://fj-chat.baidu.com https://hba-chat.baidu.com https://hbe-chat.baidu.com https://njjs-chat.baidu.com https://nj-chat.baidu.com https://hna-chat.baidu.com https://hnb-chat.baidu.com http://debug.baidu-int.com;
Content-Type: text/html;charset=utf-8
Date: Mon, 01 Apr 2024 12:33:11 GMT
P3p: CP=" OTI DSP COR IVA OUR IND COM "
Server: BWS/1.1
Set-Cookie: BDRCVFR[Fc9oatPmwxn]=mk3SLVN4HKm; path=/; domain=.baidu.com
Set-Cookie: H_PS_PSSID=40080_40377_40415_40304_40465_40481_39662_40510_40514_40398_40446_60043_60027_60031_60046; path=/; expires=Tue, 01-Apr-25 12:33:11 GMT; domain=.baidu.com
Set-Cookie: X-Use-Search-BFF-WWW=deleted; expires=Thu, 01-Jan-1970 00:00:01 GMT; path=/; domain=.baidu.com
Set-Cookie: delPer=0; path=/; domain=.baidu.com
Set-Cookie: BD_CK_SAM=1;path=/
Set-Cookie: PSINO=1; domain=.baidu.com; path=/
Set-Cookie: BDSVRTM=22; path=/
Strict-Transport-Security: max-age=172800
Traceid: 1711974791043318554616571118030046659282
Vary: Accept-Encoding
X-Ua-Compatible: IE=Edge,chrome=1
X-Xss-Protection: 1;mode=block
Transfer-Encoding: chunked
响应体的具体内容:

三、Node.js
(一)Node.js 介绍
Node.js 是基于 Chrome V8 引擎的 JavaScript 运行时
可以看成个运用程序 可以解析js 代码 对计算机资源进行操作
去官网安装好适合的 Node.js 版本就行了
(二)Express 框架
1.介绍
Express 是基于Node.js 平台快速开发极简的Web 开发框架,学习一下基本使用
因为 AJAX 要给服务器发请求所以需要一个服务端,就用这个 Express 框架 相对简单内容较少
2.语法
先引入 express 框架
然后创建应用对象
创建路由规则,函数里面有两个参数,分别是请求报文和响应报文的封装
监听端口启动服务
javascript
// 1、先引入 express 框架
const express = require('express')
// 2、然后创建应用对象
const app = express()
// 3、创建路由规则,函数里面有两个参数,分别是请求报文和响应报文的封装
app.get('/',(request,response)=>{
// 设置响应
response.send('HELLO EXPRESS')
})
// 4、监听端口启动服务
app.listen(8000,()=>{
console.log('服务已经启动,8000端口监听中...')
})
启动端口结果

查看我们向 8000端口发送的内容

查看请求响应报文:

响应体:响应头和响应体 组成了完整的响应报文

3.express框架实例
准备阶段:
先写前端界面 要求按下按钮 返回响应体 的内容到 div 中
界面展示:

代码部分:
html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>AJAX GET 请求</title>
</head>
<style>
#result {
width: 200px;
height: 100px;
border: solid pink 1px;
}
</style>
<body>
<button>点击发送请求</button>
<div id="result"></div>
</body>
</html>
Express 框架代码:
javascript
// 1、先引入 express 框架
const express = require('express')
// 2、然后创建应用对象
const app = express()
// 3、创建路由规则,函数里面有两个参数,分别是请求报文和响应报文的封装
app.get('/sever', (request, response) => {
// 设置响应头 设置允许跨域
response.setHeader('Access-Control-Allow-Origin', '*')
// 设置响应体
response.send('HELLO EXPRESS')
})
// 4、监听端口启动服务
app.listen(8000, () => {
console.log('服务已经启动,8000端口监听中...')
})
启动阶段:
右键外层文件夹 在终端中打开

然后运行文件

这时会发现报错了,显示8000端口被占用,这是因为刚才实验已经启动了这段代码,8000端口正在被使用,右边 node 就表示 有服务正在被启动

点击右面 node 然后 按下 ctrl + c 关闭刚才的服务

右边的 node 消失了 成功关闭

然后再启动我们要的服务就解决了

检验结果发现能成功返回 响应体,并且有我们新添加的响应头成功实现
启动阶段: