当前位置:   article > 正文

彻底解决uniapp发布为H5的跨域问题_uniapp h5跨域

uniapp h5跨域

一, uniapp发布成网站-PC Web或手机H5跨域

用HBuilder开发时, 用内置浏览器预览没有跨域的问题, 当发布为H5时, 调用后台接口就会出现跨域问题,如下图
在这里插入图片描述

二, 什么是跨域?

当一个请求url的协议、域名、端口三者之间任意一个与当前页面url不同即为跨域

当前页面url被请求页面url是否跨域原因
http://www.test.com/http://www.test.com/index.html同源(协议、域名、端口号相同)
http://www.test.com/https://www.test.com/index.html跨域协议不同(http/https)
http://www.test.com/http://www.baidu.com/跨域主域名不同(test/baidu)
http://www.test.com/http://blog.test.com/跨域子域名不同(www/blog)
http://www.test.com:8080/http://www.test.com:7001/跨域端口号不同(8080/7001)

三, nginx解决跨域

在一个server内配置多个location,转发前后端的请求
具体配置如下图:

1,前端项目请求的后端地址改成nginx所在服务器的IP和监听的端口号
在这里插入图片描述

2,发布成H5之后,放到如下位置
发布成H5之后,放到如下位置

3,修改nginx的配置文件


#user  nobody;
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';
    
    #access_log  logs/access.log  main;
    sendfile        on;
    #tcp_nopush     on;
    keepalive_timeout  100;
    #gzip  on;

    server {
		listen 8090;# 监听的端口号
	    server_name localhost;# 域名
	    #index index.php index.html index.htm default.php default.htm default.html;
	    gzip on;
	    gzip_static on;     # 需要http_gzip_static_module 模块
	    gzip_min_length 1k;
	    gzip_comp_level 4;
	    gzip_proxied any;
	    gzip_types text/plain text/xml text/css;
	    gzip_vary on;
	    gzip_disable "MSIE [1-6]\.(?!.*SV1)";
    
    
    # 后端接口地址 若新增后端路由前缀注意在此处添加(|新增)
    location / {
	   proxy_pass http://192.168.1.911:9999/;# 网关地址
       proxy_connect_timeout 60s;
       proxy_send_timeout 60s;
       proxy_read_timeout 60s;
       #proxy_set_header X-Real-IP $remote_addr;
       #proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
       #proxy_set_header X-Forwarded-Proto http;
    }
	
	#location ~* .*\.(js|css|ico|png|jpg|eot|svg|ttf|woff|html|txt|pdf){
	#   alias D:/Tools/nginx-1.12.2/html/creatar/;
	#   expires 30d;
	#}
	
    #前端页面地址
	location /creatar/ {
	   alias D:/Tools/nginx-1.12.2/html/creatar/;
	   #expires 30d;
	}
	
    # 避免端点安全问题
    if ($request_uri ~ "/actuator"){
        return 403;
    }
    }
}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73

4,浏览器访问
地址栏输入 nginx服务器的IP+监听端口号+页面的地址
在这里插入图片描述
在这里插入图片描述
OK,打完收工!!

方法不止这一种, 如有不正,望不吝赐教~~~

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/码创造者/article/detail/843150
推荐阅读
相关标签
  

闽ICP备14008679号