一、axios 入门

1、axios 的作用

Axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中。

官方网站:http://www.axios-js.com

官方文档:http://www.axios-js.com/zh-cn/docs/

2、axios 应用案例

step1:mybatis-plus 中添加后端接口

依赖

1
2
3
4
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>

controller

1
2
3
4
5
6
7
8
9
@SpringBootApplication
@MapperScan("com.atguigu.mybatisplus.mapper")
public class MybatisPlusApplication {

public static void main(String[] args) {
SpringApplication.run(MybatisPlusApplication.class, args);
}

}

启动主类

访问:http://localhost:8080/user/list

创建 index.html

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Document</title>
</head>
<body>
<!-- 引入axios.min.js -->
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
<script>
//基于promise
axios({
method: 'get',
url: 'http://localhost:8080/user/list',
})
.then((response) => {
console.log('获取数据成功', response)
})
.catch((error) => {
console.log('获取数据失败', error)
})

// 另一种写法
axios
.get('http://localhost:8080/user/list')
.then((response) => {
console.log('获取数据成功1', response)
})
.catch((error) => {
console.log('获取数据失败1', error)
})
</script>
</body>
</html>

浏览器访问,出现跨域问题

二、跨域

跨域的本质:是 http 的同源策略的禁止协议,简单来说就是 http 禁止非同源数据的请求传递,来保证网站的安全性。

1、为什么会出现跨域问题?

出于浏览器的同源策略限制。

所谓同源(即指在同一个域)就是两个地址具有相同的协议(protocol)、主机(host)和端口号(port)

以下情况都属于跨域:

跨域原因说明示例
域名不同www.jd.comwww.taobao.com
域名相同,端口不同www.jd.com:8080www.jd.com:8081
二级域名不同item.jd.com 与 miaosha.jd.com

http 和 https 也属于跨域。

如果域名和端口都相同,但是请求路径不同,不属于跨域,如:www.jd.com/itemwww.jd.com/goods

同源策略会阻止一个域的 javascript 脚本和另外一个域的内容进行交互。

而我们刚才是从 localhost:5500 端口去访问 localhost:8080 端口,这属于端口不同,跨域了。

2、解决跨域问题

Spring 早就给我们提供了解决方案,我们只需要在对应 controller 上添加一个注解就可以了

我们在 UserController 类上添加跨域标签@CrossOrigin,再进行测试,则测试成功!

1
2
3
4
@RestController
@CrossOrigin
@RequestMapping("/user")
public class UserController {

控制台查看结果

三、自定义配置

1、配置 axios 实例

可以对 axios 进行配置,简化代码的编写

1
2
3
4
5
6
//使用自定义配置
const request = axios.create({
baseURL: 'http://localhost:8080', //url前缀
timeout: 1000, //超时时间
headers: { token: 'hello' }, //携带令牌
})

2、配置请求参数

这样,远程接口的 url 地址就可以修改成相对路径了

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Document</title>
</head>
<body>
<!-- 引入axios.min.js -->
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
<script>
// 使用自定义配置
const request = axios.create({
baseURL: 'http://localhost:8080', //主机地址
timeout: 1000, //超时时间:毫秒
headers: {
token: 'hello',
},
})

// 基于promise
// 注意:这里使用了前面定义的request
request({
method: 'get',
url: '/user/list',
})
.then((response) => {
console.log('获取数据成功', response)
})
.catch((error) => {
console.log('获取数据失败', error)
})

// 另一种写法
// 注意:这里使用了前面定义的request
request
.get('http://localhost:8080/user/list')
.then((response) => {
console.log('获取数据成功1', response)
})
.catch((error) => {
console.log('获取数据失败1', error)
})
</script>
</body>
</html>

四、拦截器

在请求或响应被 then 或 catch 处理前拦截他们。

1、请求拦截器

在发送 axios 请求前,可以拦截请求,对请求做一些处理

1
2
3
4
5
6
7
8
9
10
11
12
13
14
// 请求拦截器
request.interceptors.request.use(
function (config) {
// 在发送请求之前做些什么,例如:在请求头中携带一个令牌
console.log('请求拦截')
config.headers.mytoken = 'hello world'
//放行
return config
},
function (error) {
// 对请求错误做些什么
return Promise.reject(error)
}
)

发送请求时,在请求头中会携带这个 token

2、响应拦截器

在发送完请求,获取到响应后,可以对响应做一些处理,再返回给前端用户

1
2
3
4
5
6
7
8
9
10
11
12
// 添加响应拦截器
request.interceptors.response.use(
function (response) {
// 响应放行
// 对响应数据做点什么,例如:使用response.data替代response,简化前端拿到的数据结果
return response.data
},
function (error) {
// 对响应错误做点什么
return Promise.reject(error)
}
)