使用Nginx反向代理解决http和https跨域问题

 今天在做程序的时候,修改了一下源码,使用自己的服务端进行登陆,注意:这里是使用http域名访问https域名。1、下载源码,配置了pro的域名,pro.facai0.com 没有开启https,具体配置如下:
 

    server {
        server_name  pro.facai0.com;

        location / {
            proxy_pass http://127.0.0.1:8182;
            proxy_set_header   Host             $host;
            proxy_set_header   X-Real-IP        $remote_addr;
            proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;
            proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
        }

    }

注:以上使用Nginx反向代理了内部地址 8182 端口。

2、输入用户名进行提交的时候发现是跨域问题。

参考:jquery - Error :Request header field Content-Type is not allowed by Access-Control-Allow-Headers - Stack Overflow

修改nginx配置文件头部,添加以下内容:

add_header 'Access-Control-Allow-Origin' 'http://pro.facai0.com';
add_header 'Access-Control-Allow-Headers' 'Origin, X-Requested-With, Content-Type, Accept';

重启Nginx服务

sudo systemctl restart openresty.service

再次登录,问题解决了。

  • 11
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值