目 录CONTENT

文章目录

vue项目,安卓pc均正常,ios Safari Network Error

aprilz
2023-02-02 / 0 评论 / 0 点赞 / 850 阅读 / 708 字

vue项目,安卓pc均正常,ios Safari Network Error

前言

刚开始呢,项目按照若依搭建,一切正常,突然有人和我说,ios浏览器去访问,页面上提示Network Error,我立马打开电脑测试均正常,然后F12模拟iPhone也没问题,安卓正常,用我的iPhone去测试后发现居然真的异常。

正文

  1. 第一步,我打开stream抓包软件,发现请求后端接口时,并没有发出请求,就在request.js中报错了,报错位置如图下

image-1675348347953

2.因为 我vue和后台是部署在同一域名下的,nginx配置如下

server {
    listen       80;
    server_name   tool.losey.top;
    rewrite ^(.*)$ https://tool.losey.top$1 permanent; #将所有HTTP请求通过rewrite指令重定向到HTTPS。
}

#以下属性中,以ssl开头的属性表示与证书配置有关。
server {
    listen 443 ssl;
    #配置HTTPS的默认访问端口为443。
    #如果未在此处配置HTTPS的默认访问端口,可能会造成Nginx无法启动。
    #如果您使用Nginx 1.15.0及以上版本,请使用listen 443 ssl代替listen 443和ssl on。
    server_name   tool.losey.top  ; #需要将yourdotool.com替换成证书绑定的域名。

    ssl_certificate cert/tool/cert-tool.pem;  #需要将cert-file-name.pem替换成已上传的证书文件的名称。
    ssl_certificate_key cert/tool/cert-tool.key; #需要将cert-file-name.key替换成已上传的证书私钥文件的名称。
    ssl_session_cache shared:SSL:1m;
    ssl_session_timeout  10m;
    ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
    #表示使用的加密套件的类型。
    ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3; #表示使用的TLS协议的类型。
    ssl_prefer_server_ciphers on;


    
    location / {
      try_files $uri $uri/ /index.html; #解决刷新以及跳转404
      root /usr/share/nginx/html/tool/dist;  #站点目录。 因为是docker nginx里的目录
      index index.html index.htm;
    }
	
	#反向代理vue 项目接口	
   location /app-api/{
        proxy_pass http://172.18.0.6:48080/app-api/; 
		proxy_set_header Host $http_host;
		proxy_set_header X-Real-IP $remote_addr;
		proxy_set_header REMOTE-HOST $remote_addr;
		proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  }
		

}


试了半天没找到原因,百度查一堆说vue https,后端http导致的,和我这种情况不同,所以呢我干脆直接吧后端也用个二级域名吧来试试吧,申请过后,配置发现这个时候访问正常了!!

所以原因到底在哪呢,我哭死不得其解,最后定位到vue.config.js中

image-1675351511872

改成如下后测试即可

image-1675348720629

即生产环境就不使用devServer了,上面这个配置结果把请求转到http://127.0.0.1:48080/app-api了,导致都没到nginx转发??

0

评论区