热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Vue开发使用Axios遇到了大坑!

Vue开发使用Axios遇到了大坑!,Go语言社区,Golang程序员人脉社


最近在赶项目,项目需要一定基础录入数据,所以边开发边让同事进行数据录入,但是遇到了天坑!

我使用angular的http请求,局域网内连接开发工程,一切正常!


Vue开发使用Axios遇到了大坑!


使用Vue的axios连接部分正常,部分不正常,服务器状态码200,服务器端控制台也不报错。但是页面请求就是报错。使用iPhone手机报错,换华为安卓手机也是一样的报错,安卓手机不知道怎么调试,使用macOS的Safari浏览器可以调试iPhone手机浏览器,调试报错,但是不知道原因。就单纯报错,服务器是没有任何问题。错误代码是200。


Vue开发使用Axios遇到了大坑!


也就是说,我PC版本浏览器缩放成手机浏览器一切正常,真机报错,如果说是ssl证书等拦截,但实际上是有的请求报错有的请求不报错,一般报错的是服务器返回一定数据的页面会报错。

换成局域网其它PC电脑访问,很多页面正常,部分页面异步请求不正常,所有的http请求都统一在一个axios工具里封装的。为何有些报错,有些不报错呢?太奇怪了唉。

但是在我工程开发的本机一切全部都正常!比如区域数据加载,数据为全云南省行政区数据,在我本机请求正常,但局域网其它浏览器访问就网络请求报错,控制台显示为incomplete encoding?

但是编码都是utf-8完全和其它请求和返回一致。我本机也可以正常加载,更离奇的是,打包成生产模式部署到阿里云服务器上也全部正常,就局域网跨电脑访问就异常,也不是全部异常,就是那么部分接口异常。


Vue开发使用Axios遇到了大坑!


使用的代码为ant design vue pro后台管理模板预设的axios封装,代码如下:

  1. import Vue from 'vue' 
  2. import axios from 'axios' 
  3. import store from '@/store' 
  4. import notification from 'ant-design-vue/es/notification' 
  5. import { VueAxios } from './vueAxios' 
  6. import { ACCESS_TOKEN, ENTERPRISE_TOKEN } from '@/store/mutation-types' 
  7. import Constant from '@/config/ann.config' 
  8.  
  9. // 创建 axios 实例 
  10. const service = axios.create({ 
  11.   baseURL: Constant.API_URL, // api base_url 
  12.   timeout: 6000 // 请求超时时间 
  13. }) 
  14.  
  15. const err = (error) => { 
  16.   if (error.response) { 
  17.     const data = error.response.data 
  18.     const token = Vue.ls.get(ACCESS_TOKEN) 
  19.     if (error.response.status === 403) { 
  20.       notification.error({ 
  21.         message: 'Forbidden'
  22.         description: data.message 
  23.       }) 
  24.     } 
  25.     if (error.response.status === 401 && !(data.result && data.result.isLogin)) { 
  26.       notification.error({ 
  27.         message: 'Unauthorized'
  28.         description: 'Authorization verification failed' 
  29.       }) 
  30.       if (token) { 
  31.         store.dispatch('Logout').then(() => { 
  32.           setTimeout(() => { 
  33.             window.location.reload() 
  34.           }, 1500) 
  35.         }) 
  36.       } 
  37.     } 
  38.   } 
  39.   return Promise.reject(error) 
  40.  
  41. // request interceptor 
  42. service.interceptors.request.use(config => { 
  43.   // 登录用户身份认证Token 
  44.   const token = Vue.ls.get(ACCESS_TOKEN) 
  45.   if (token) { 
  46.     config.headers['Ann-Token'] = token // 让每个请求携带自定义 token 请根据实际情况自行修改 
  47.   } 
  48.   // 当前操作企业授权Token 
  49.   const tokenE = Vue.ls.get(ENTERPRISE_TOKEN) 
  50.   if (tokenE) { 
  51.     config.headers['Ann-E-Token'] = tokenE // 让每个请求携带自定义 token 请根据实际情况自行修改 
  52.   } 
  53.   return config 
  54. }, err) 
  55.  
  56. // response interceptor 
  57. service.interceptors.response.use((response) => { 
  58.   return response.data 
  59. }, err) 
  60.  
  61. const installer = { 
  62.   vm: {}, 
  63.   install (Vue) { 
  64.     Vue.use(VueAxios, service) 
  65.   } 
  66.  
  67. export { 
  68.   installer as VueAxios, 
  69.   service as axiosService 
  70.  
  71. 有没有遇到同样问题的道友呢? 

有没有遇到同样问题的道友呢?


【责任编辑:庞桂玉 TEL:(010)68476606】

点赞 0


推荐阅读
  • 高级缩放示例.就像谷歌地图一样.它仅缩放图块,但不缩放整个图像.因此,缩放的瓷砖占据了恒定的记忆,并且不会为大型缩放图像调整大小的图像.对于简化的缩放示例lookhere.在Win ... [详细]
  • 本文详细介绍了在PHP中如何获取和处理HTTP头部信息,包括通过cURL获取请求头信息、使用header函数发送响应头以及获取客户端HTTP头部的方法。同时,还探讨了PHP中$_SERVER变量的使用,以获取客户端和服务器的相关信息。 ... [详细]
  • 在CentOS 7中部署Nginx并配置SSL证书
    本文详细介绍了如何在CentOS 7操作系统上安装Nginx服务器,并配置SSL证书以增强网站的安全性。适合初学者和中级用户参考。 ... [详细]
  • Hadoop MapReduce 实战案例:手机流量使用统计分析
    本文通过一个具体的Hadoop MapReduce案例,详细介绍了如何利用MapReduce框架来统计和分析手机用户的流量使用情况,包括上行和下行流量的计算以及总流量的汇总。 ... [详细]
  • 探索UNIX操作系统的家族树
    通过回顾历史,我们可以更好地理解技术的发展。本文将带你深入了解UNIX操作系统的起源和发展历程,揭示其在现代计算中的重要地位。 ... [详细]
  • 本文探讨了在不同场景下如何高效且安全地存储Token,包括使用定时器刷新、数据库存储等方法,并针对个人开发者与第三方服务平台的不同需求提供了具体建议。 ... [详细]
  • 本文详细介绍了在 CentOS 7 系统上安装中文宋体字体的方法,包括操作系统的环境配置、字体管理工具的安装、字体文件的传输与缓存重建等步骤。 ... [详细]
  • 吴石访谈:腾讯安全科恩实验室如何引领物联网安全研究
    腾讯安全科恩实验室曾两次成功破解特斯拉自动驾驶系统,并远程控制汽车,展示了其在汽车安全领域的强大实力。近日,该实验室负责人吴石接受了InfoQ的专访,详细介绍了团队未来的重点方向——物联网安全。 ... [详细]
  • 本文详细探讨了在Java TCP编程中,如何理解和测量并发连接数、请求数及并发用户数,并提供了实际应用中的测试方法和优化建议。 ... [详细]
  • 本文探讨了如何通过优化 DOM 操作来提升 JavaScript 的性能,包括使用 `createElement` 函数、动画元素、理解重绘事件及处理鼠标滚动事件等关键主题。 ... [详细]
  • Requests库的基本使用方法
    本文介绍了Python中Requests库的基础用法,包括如何安装、GET和POST请求的实现、如何处理Cookies和Headers,以及如何解析JSON响应。相比urllib库,Requests库提供了更为简洁高效的接口来处理HTTP请求。 ... [详细]
  • 理解浏览器历史记录(2)hashchange、pushState
    阅读目录1.hashchange2.pushState本文也是一篇基础文章。继上文之后,本打算去研究pushState,偶然在一些信息中发现了锚点变 ... [详细]
  • 深入理解:AJAX学习指南
    本文详细探讨了AJAX的基本概念、工作原理及其在现代Web开发中的应用,旨在为初学者提供全面的学习资料。 ... [详细]
  • 如何在Mozilla Firefox中调整GIF动画的循环次数
    本文介绍了如何通过调整Mozilla Firefox的高级设置来控制GIF动画的播放次数,帮助用户根据个人喜好自定义浏览体验。 ... [详细]
  • 阿里云 Aliplayer高级功能介绍(八):安全播放
    如何保障视频内容的安全,不被盗链、非法下载和传播,阿里云视频点播已经有一套完善的机 ... [详细]
author-avatar
fdsafjlkjgklg_431
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有