http.interceptors.request.use(config => { config.headers['Token'] = storage.get('Token') // 请求头带上token return config }, error => { return Promise.reject(error) })
时间: 2023-06-25 08:04:53 浏览: 97
这段代码是一个axios的请求拦截器,它会在每次请求发送前被调用。这里的作用是在请求头中带上一个名为 Token 的字段,并将其值设置为本地存储中的 Token 值。这样在后端接收到请求时,就可以从请求头中获取到 Token 值,进行用户身份验证和权限控制等操作。如果请求发生错误,这里会通过 Promise.reject 将错误对象返回,以便后续的错误处理。
相关问题
const http = axios.create({ timeout: 1000 * 86400, withCredentials: true, baseURL: '/star', headers: { 'Content-Type': 'application/json; charset=utf-8' } }) // 请求拦截 http.interceptors.request.use(config => { config.headers['Token'] = storage.get('Token') // 请求头带上token return config }, error => { return Promise.reject(error) }) // 响应拦截 http.interceptors.response.use(response => { if (response.data && response.data.code === 401) { // 401, token失效 router.push({ name: 'login' }) } return response }, error => { return Promise.reject(error) }) export default http
这是一个使用 axios 封装的 HTTP 请求实例,包括请求拦截和响应拦截。具体实现如下:
1. 创建一个名为 http 的 axios 实例,设置基础 URL、超时时间、跨域请求时是否需要凭证等参数。
```javascript
const http = axios.create({
timeout: 1000 * 86400, // 请求超时时间
withCredentials: true, // 跨域请求时是否需要使用凭证
baseURL: '/star', // 基础URL
headers: {
'Content-Type': 'application/json; charset=utf-8' // 请求头配置
}
})
```
2. 添加请求拦截器,当发起请求时,在请求头中添加 token,以便后端验证用户身份。
```javascript
http.interceptors.request.use(config => {
config.headers['Token'] = storage.get('Token') // 在请求头中添加 Token
return config
}, error => {
return Promise.reject(error)
})
```
3. 添加响应拦截器,当后端返回 401 状态码时,表示用户身份验证失败,此时跳转到登录页。
```javascript
http.interceptors.response.use(response => {
if (response.data && response.data.code === 401) { // 后端返回 401 状态码
router.push({ name: 'login' }) // 跳转到登录页
}
return response
}, error => {
return Promise.reject(error)
})
```
4. 导出 http 实例,供其他组件调用。
```javascript
export default http
```
这样封装后,我们在项目中可以直接使用 http 实例进行 API 请求,并自动携带 token,同时也可以处理后端返回的 401 状态码。
const http = axios.create({ timeout: 1000 * 30, withCredentials: true, headers: { 'Content-Type': 'application/json; charset=utf-8' } }) //请求拦截器 http.interceptors.request.use( config => { var Authorization = localStorage.getItem("Authorization") // debugger // console.log("授权码是:" + Authorization) if (Authorization) { //判断token是否存在 config.headers['Authorization'] = Authorization; //将token设置成请求头 } return config; }, err => { return Promise.reject(err); } ); /** * 响应拦截 */ http.interceptors.response.use(response => { // debugger if (response.data && response.data.code === 401) { // 10021, token失效 clearLoginInfo() // console.log("token过期") router.replace('/') } // debugger // console.log(typeof (response.headers.Authorization)) // console.log(response.headers.Authorization) // debugger if (typeof (response.headers.authorization) !== "undefined") { let token = response.headers.authorization localStorage.setItem('Authorization', 'Bearer ' + token) // console.log("已经刷新token: " + token) } // debugger return response }, error => { return Promise.reject(error) }) export default http;
这段代码是使用axios进行网络请求时,设置了请求拦截器和响应拦截器。
请求拦截器用于在请求发送前对请求进行处理,这里判断了本地存储中是否存在Authorization,如果存在则将其设置成请求头的Authorization字段,这是用于用户身份验证的Token。如果不存在则不进行处理。
响应拦截器用于在响应返回后对响应进行处理,这里判断了响应中是否包含Authorization字段,如果包含则将其存储到本地存储中,用于更新用户身份验证的Token。另外,如果响应中的状态码为401,则表示用户的Token已失效,需要清除本地存储中的Token,并将用户重定向到登录页面。
这种拦截器的设置可以增强应用的安全性和稳定性,可以在请求和响应中进行统一的处理,减少代码的重复编写。
阅读全文