vue打包上线服务器端nginx反向代理-解决前端跨域问题

23 篇文章 0 订阅

1.定义

跨域是指a页面想获取b页面资源,如果a、b页面的协议、域名、端口、子域名不同,所进行的访问行动都是跨域的,而浏览器为了安全问题一般都限制了跨域访问,也就是不允许跨域请求资源。注意:跨域限制访问,其实是浏览器的限制。理解这一点很重要!!!

2.跨域访问示例

假设有两个网站,A网站部署在:http://localhost:81 即本地ip端口81上;B网站部署在:http://localhost:82 即本地ip端口82上。

现在A网站的页面想去访问B网站的信息,A网站页面的代码如下(这里使用jquery的异步请求):

<div id="show"></div>
<script type="text/javascript">
$(function () {
	$.get("http://localhost:82/api/values", {}, function (result) {
		$("#show").html(result);
	})
})

这是浏览器会提示如下错误信息:

3.nginx反向代理解决跨域问题

3.1nginx配置

找到nginx的配置文件“nginx.conf”,修改一下信息

server {
        listen       80; #监听80端口,可以改成其他端口
        server_name  localhost; # 当前服务的域名

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            proxy_pass http://localhost:81;
            proxy_redirect default;
        }

		location /apis { #添加访问目录为/apis的代理配置
			rewrite  ^/apis/(.*)$ /$1 break;
			proxy_pass   http://localhost:82;
       }
#以下配置省略

配置解释:

1.由配置信息可知,我们让nginx监听localhost的80端口,网站A与网站B的访问都是经过localhost的80端口进行访问。
2.我们特殊配置了一个“/apis”目录的访问,并且对url执行了重写,最后使以“/apis”开头的地址都转到“http://localhost:82”进行处理。
3.rewrite  ^/apis/(.*)$ /$1 break; 
代表重写拦截进来的请求,并且只能对域名后边以“/apis”开头的起作用,例如www.a.com/apis/msg?x=1重写。只对/apis重写。
  rewrite后面的参数是一个简单的正则 ^/apis/(.*)$ ,$1代表正则中的第一个(),$2代表第二个()的值,以此类推。
  break代表匹配一个之后停止匹配。

3.2 访问地址修改

既然配置了nginx,那么所有的访问都要走nginx,而不是走网站原本的地址(A网站localhost:81,B网站localhost:82)。所以要修改A网站中的ajax访问地址,把访问地址由

“http://localhost:82/api/values”改成===>“/apis/api/values”。如下代码:

<div id="show"></div>

<script type="text/javascript">
        $(function () {
            $.get("/apis/api/values", {}, function (result) {
                $("#show").html(result);
            })
        })
</script>

 4.网站的访问

5.总结

浏览器跨域的解决方式有很多种:

1.jsonp 需要目标服务器配合一个callback函数。
2.window.name+iframe 需要目标服务器响应window.name。
3.window.location.hash+iframe 同样需要目标服务器作处理。
4.html5的 postMessage+ifrme 这个也是需要目标服务器或者说是目标页面写一个postMessage,主要侧重于前端通讯。
5.CORS  需要服务器设置header :Access-Control-Allow-Origin。
6.nginx反向代理 这个方法一般很少有人提及,但是他可以不用目标服务器配合,不过需要你搭建一个中转nginx服务器,用于转发请求。


配置 

server {
        listen       80; #监听80端口,可以改成其他端口
        server_name  localhost; # 当前服务的域名
 
        location / {
            root "D:/ProgramFiles/phpstudy_pro/WWW/dist";
			index index.html index.htm;
			try_files $uri $uri/ /index.html;
        }
 
		location ~* /api/ { #添加访问目录为/apis的代理配置
			rewrite  ^/api/(.*)$ /$1 break;
			proxy_pass   http://white-label-nft-admin-test.tianhe32.cn;
       }
}

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
对于前端Vue项目发送请求不携带cookie的问题,您可以按照以下步骤进行排查: 1. 检查vue.config.js配置:在Vue项目中,可以通过vue.config.js文件进行一些配置。请确保在该文件中没有对cookie进行了特殊的配置,比如禁用了cookie的发送。您可以检查是否有类似以下的配置项: ```javascript module.exports = { devServer: { // 是否禁用了发送cookie disableHostCheck: true, // ... }, // ... } ``` 如果存在以上配置,请将其删除或注释掉,以确保cookie能够正常发送。 2. 检查nginx反向代理配置:如果您使用了nginx进行反向代理,也需要检查nginx配置文件中的相关设置。请确保没有对cookie进行了特殊的配置,比如禁用了cookie的转发。您可以检查是否有类似以下的配置项: ```nginx location /api { # 是否禁用了cookie转发 proxy_cookie_path ~^/api/(.*)$ /$1 break; # ... } ``` 如果存在以上配置,请将其删除或注释掉,以确保cookie能够正常转发。 3. 确认接口允许跨域访问:在开发环境下,如果您的接口和前端项目部署在不同的域名下,可能会存在跨域访问的问题。请确保接口服务器允许前端项目的域名进行跨域访问,并在响应中包含Access-Control-Allow-Credentials和Access-Control-Allow-Origin头信息。您可以在接口服务器的响应头中添加以下配置: ``` Access-Control-Allow-Credentials: true Access-Control-Allow-Origin: 前端项目的域名 ``` 请将"前端项目的域名"替换为您实际的前端项目域名。 以上是一些常见的排查步骤,希望能帮助您解决问题。如果问题仍然存在,请提供更多详细信息,我将尽力协助您解决

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JackieDYH

谢谢您嘞!我会继续加油地

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值