没有合适的资源?快使用搜索试试~ 我知道了~
资源推荐
资源详情
资源评论
vue+axios全局添加请求头和参数操作全局添加请求头和参数操作
主要介绍了vue+axios全局添加请求头和参数操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编
过来看看吧
走登录的接口都会返回一个token值,然后存起来方便之后调接口的时候给后台传过去,传给后台的方式有两种:(具体使用
哪种需要和后台商量)
1、放在请求头中
2、放在接口的参数中
1、放在请求头中、放在请求头中
下面代码是从本地cookie中拿token
VueCookie:一个用于处理浏览器cookies的简单Vue.js插件.
// 在封装axios的文件中添加拦截器
// 添加请求拦截器,在请求头中加token
service.interceptors.request.use(
config => {
// 判断本地的cookie中是否有token
if (VueCookie.isKey('token')) {
config.headers.Authorization = VueCookie.get('token')
} else {
// 跳转到登录页面(这里使用router,是因为路由文件引入到了此文件里)
router.push('/login')
}
return config
},
error => {
return Promise.reject(error)
})
这个时候虽然在请求头中放了token,但是后台并拿不到token的值,我们需要在创建axios对象的时候允许请求携带cokie,也
可以加到main.js全局里面。
// 放在请求文件中
const service = axios.create({
baseURL: "http://XXXXXXXXX:XXXX",
timeout: 10000,
withCredentials: true // 允许携带cookie
});
// 放在全局main.js中
import axios from "axios";
axios.defaults.withCredentials = true; // 允许携带cookie
2、放在参数中、放在参数中
以下代码是从本地存储localStorage中拿token
// 添加请求拦截器,在参数中加token
service.interceptors.request.use(
config => {
// 将token添加到每一个接口的参数中
// 判断请求的类型:如果是post请求就把默认参数拼到data里面;如果是get请求就拼到params里面
const token = localStorage.getItem('ISTOKEN')
if (localStorage.getItem('ISTOKEN')) {
// 注意:config.method 的判断值必须是小写的post和get
if (config.method === 'post') {
config.data = {
api_token: token,
...config.data
}
} else if (config.method === 'get') {
config.params = {
api_token: token,
...config.params
}
}
} else {
// 跳转到登录页面(这里使用router,是因为路由文件引入到了此文件里)
router.push('/login')
}
return config
资源评论
- xushaohui0982023-05-19感谢资源主分享的资源解决了我当下的问题,非常有用的资源。
weixin_38548704
- 粉丝: 3
- 资源: 931
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功