当前位置: 首页 > news >正文

寻找专业网站建设做网站网站代理的犯法么

寻找专业网站建设,做网站网站代理的犯法么,自己开公司 自己做网站,南京网项目文档 目录 项目文档 1. 封装请求基地址 代码 2. 添加请求拦截器并设置请求头 作用 代码部分 3. 添加响应拦截器 作用 代码 4. token过期问题处理 5. 无感刷新 作用 代码 6. refresh_token过期处理 解决方式 1. 封装请求基地址 在src目录下 放上一个专门写…

项目文档

目录

项目文档

1.  封装请求基地址

代码

2. 添加请求拦截器并设置请求头

作用

代码部分

3. 添加响应拦截器

作用

代码

4. token过期问题处理

5. 无感刷新

作用

代码

6. refresh_token过期处理

解决方式


1.  封装请求基地址

  • 在src目录下 放上一个专门写请求相关的文件夹
  • 然后在里面新建一个专门放用户请求的use.js
  • 用axios发送请求
  • 在use.js文件夹里导入request
  • 并且根据接口文档 写请求
  • 然后把这个请求封装成一个函数,这个函数里需要传入两个参数
  • 这两个参数 都放在data数据里 所以可以直接申明需要的数据是data

代码

2. 添加请求拦截器并设置请求头

作用

在向服务器发送请求时,很多请求都需要在请求头中携带token,每一次去请求都写请求头很麻烦,所以我们写一个请求拦截器,统一拦截并添加一个请求头

代码部分

// 请求拦截器
request.interceptors.request.use((config) => {// Do something before request is sent// 在我们发送请求前做的事情// 判断发送的请求需不需要请求头if (store.state.tokenObj.token) {// 统一在请求头中携带tokenconfig.headers.Authorization = 'Bearer ' + store.state.tokenObj.token}return config
}, (error) => {// Do something with request error// 请求失败return Promise.reject(error)
})


3. 添加响应拦截器

作用

响应拦截器里参数就是服务器返回给浏览器的内容  拦截器返回什么 浏览器拿到什么 如果拦截器什么都返回 那么浏览器什么都拿不到

代码

//响应拦截器
request.interceptors.response.use(function (response) {// 处理响应数据return response; // 返回响应数据
},


4. token过期问题处理

【模拟token过期】

在应用里的本地存储里 去更改token 达到让token失效

【拦截器拦截失败信息】

因为token过期, 所以第二次请求失败 ,那要代码继续运行下去, 就放上一个响应拦截器 把这个错误拦截, 并且不return出去 这样浏览器就不知道有这个错误。

 async function (error) {console.log('出错了');// 响应出错后所做的处理工作// return Promise.reject(error);try{//发送请求,获取refresh_tokenlet res = await axios({url: 'http://geek.itheima.net/v1_0/authorizations',method: 'put',//请求头headers: {Authorization: 'Bearer ' + store.state.tokenObj.refres_token}})//调用store里的changeToken方法,修改初始tokenstore.commit('changeToken', {// 使用第三次请求中打的到的新的token替换原本的tokentoken: res.data.data.token,// refres_token依然是原本的值refres_token: store.state.tokenObj.refres_token})// 这个时候把获取用户信息这个请求再发了一次// 在请求拦截器中,拦截器return什么,浏览器就拿到什么return request(error.config)// console.log('第三次请求获取到的内容', res);}catch{Toast.fail('登录状态失败,重新登陆')// 返回登录页router.push('./login')}});


5. 无感刷新

作用

用户不用刷新页面 系统内容自己重新发送请求 渲染页面

代码

        // 这个时候把获取用户信息这个请求再发了一次// 在请求拦截器中,拦截器return什么,浏览器就拿到什么return request(error.config)

加上这段代码, 在两个小时后 ,浏览器会自己把之前失败的请求 ,换成新的token再发一遍 用户不需要刷新页面 就可以在两个小时后 有新的token 并且页面不会出现任何破绽。


6. refresh_token过期处理

14天后refresh_token也会过期

解决方式

使用 try{}catch{}处理失败的情况

把整段请求代码放进try代码里进行检验

       try{//发送请求,获取refresh_tokenlet res = await axios({url: 'http://geek.itheima.net/v1_0/authorizations',method: 'put',//请求头headers: {Authorization: 'Bearer ' + store.state.tokenObj.refres_token}})//调用store里的changeToken方法,修改初始tokenstore.commit('changeToken', {// 使用第三次请求中打的到的新的token替换原本的tokentoken: res.data.data.token,// refres_token依然是原本的值refres_token: store.state.tokenObj.refres_token})// 这个时候把获取用户信息这个请求再发了一次// 在请求拦截器中,拦截器return什么,浏览器就拿到什么return request(error.config)// console.log('第三次请求获取到的内容', res);}catch{Toast.fail('登录状态失败,重新登陆')// 返回登录页router.push('./login')}

 编辑页面

http://www.yayakq.cn/news/39250/

相关文章:

  • 网站首页的快照更新慢重庆做网站建设公司排名
  • 找人做网站会不会被偷wordpress 文章 插件
  • 企业制作网站服务wordpress 扩展
  • 浙江省住房与城乡建设部网站网页美工设计中使用的主要软件是
  • 陕西建设厅继续教育网站南京市建筑工程网站
  • 做一个网站需要投入多少钱彬县网招聘
  • 廊坊购物网站开发设计品牌创意网站
  • 全屏企业网站成都住建局官网查询入口
  • 青岛公路建设集团网站个人博客网站建设选题说明
  • 之梦网站怎么做seowordpress做管理网站
  • 微信手机网站app制作百度seo外包
  • 深圳市科技网站开发中国建筑设计咨询有限公司
  • 淮北矿业工程建设有限公司网站网站模板间距
  • 网站转换小程序广告视频网站
  • 公司网站seo公司青岛网上房地产官网查网签
  • wordpress中如何设置文章在新窗口打开 (商城网站 没有什么文章 怎样优化
  • 做网站客户没有付定金惠州网红
  • discuz网站建设专业长春网站建设哪家好
  • 旅游网站流程图西双版纳傣族自治州有几个县
  • 做网站怎么赚钱吗汉口网站建设制作
  • 经常做飞机网站百度网盘下载电脑版官方下载
  • 自建站平台站长之家产品介绍
  • 网站搭建网站设置安装wordpress it works
  • 怎么做一淘宝客网站个人网页设计与实现ppt
  • 代理浏览网站杭州做网站小程序公司
  • 广州安全教育平台官网登录网站图标的制作h1优化代码
  • 北仑静态网站建设网站建设佰金手指科杰十三
  • 商城网站建设fwshop手机制作软件下载
  • 免费微网站有哪些做网站如何收费
  • 大连市住房和建设局网站网站设计与建设考试