前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >前端网站如何解决跨域问题?宝塔轻松搞定!

前端网站如何解决跨域问题?宝塔轻松搞定!

作者头像
李昂君
发布2022-01-04 11:17:53
4.3K0
发布2022-01-04 11:17:53
举报
文章被收录于专栏:李昂君李昂君

一、什么是跨域?

跨域,是指浏览器不能执行其他网站的脚本。它是由浏览器的同源策略造成的,是浏览器对JavaScript实施的安全限制。

这里说明一下,无法跨域是浏览器对于用户安全的考虑,如果自己写个没有同源策略的浏览器,完全不用考虑跨域问题了。就是浏览器的锅。

跨域报错情况

非同源策略

Cookie、LocalStorage 和 IndexDB 无法读取

DOM 和 JS 对象无法获取

Ajax请求发送不出去。

二、跨域的场景介绍

场景

当前页面的Url

被请求的地址或页面Url

是/否跨域

同源

http://www.baidu.com

http://www.baidu.com/login.html

否,同源(协议、域名、端口号相同)

协议不同

http://www.baidu.com

https://www.baidu.com

是,协议不同(http/https)

子域名不同

http://www.baidu.com

http://map.baidu.com

是,子域名不同(www/map)

主域名不同

http://www.baidu.com

http://www.jd.com

是,主域名不同(baidu/jd)

端口号不同

http://www.baidu.com:8080/

http://www.baidu.com:7070

是,端口号不同(8080/7070)

ip地址和网址不同

http://12.123.12.99:8080/

http://www.baidu.com

是,主域名不同

首先狭义的同源就是指,域名、协议、端口均为相同。

三、常见的跨域的解决方案有哪些?

  • 通过jsonp跨域
  • document.domain + iframe跨域
  • location.hash + iframe
  • window.name + iframe跨域
  • postMessage跨域
  • 跨域资源共享(CORS)
  • nginx代理跨域(笔者推荐)
  • nodejs中间件代理跨域
  • WebSocket协议跨域

四、代理有那些?

聊到这里,一定要知道代理是啥?

正向代理

我们常说的代理也就是指正向代理,正向代理的过程,它隐藏了真实的请求客户端,服务端不知道真实的客户端是谁,客户端请求的服务都被代理服务器代替来请求,某些科学上网工具扮演的就是典型的正向代理角色。

用浏览器访问http://www.google.com时,被残忍的block,于是你可以在国外搭建一台代理服务器,让代理帮我去请求google.com,代理把请求返回的相应结构再返回给代理的客户端。

正向代理

反向代理

反向代理隐藏了真实的服务端,当我们请求 www.baidu.com 的时候,就像拨打10086一样,背后可能有成千上万台服务器为我们服务,但具体是哪一台,你不知道,也不需要知道,你只需要知道反向代理服务器是谁就好了,www.baidu.com 就是我们的反向代理服务器,反向代理服务器会帮我们把请求转发到真实的服务器那里去。Nginx就是性能非常好的反向代理服务器,用来做负载均衡。

反向代理

简而言之:正向代理隐藏真实客户端,反向代理隐藏真实服务端,一下就懂了!

五、如何解决跨域?

为了解决跨域问题,自己造一个浏览器,屏蔽同源策略,那也是可行的,但那是愚蠢的行为!

笔者这里推荐使用 跨域资源共享(CORS)nginx代理跨域(笔者强烈推荐)

nginx代理解决跨域

1、跨域原理

同源策略是浏览器的安全策略,不是HTTP协议的一部分。服务器端调用HTTP接口只是使用HTTP协议,不会执行JS脚本,不需要同源策略,也就不存在跨越问题。

2、实现思路

通过nginx配置一个代理服务器(域名与domain1相同,端口不同)做跳板机,反向代理访问domain2接口,并且可以顺便修改cookie中domain信息,方便当前域cookie写入,实现跨域操作。

3、宝塔面板中,如何启动反向代理

关于宝塔的优劣我不做过多说明,安装的说明,请看点我跳转

安装宝塔环境好以后,部署自己的后端项目文件到网站版块下,并设置后端接口环境为,Php->7.2的版本环境,见下图:

设置后端接口环境

设置后端接口的局域网络端口地址,见下图:

注册局域网地址

上图中设置局域网端口地址:http://127.0.0.1:6123

设置局域网端口地址,优势在于,不用走外网请求!

接下来,部署自己的前端项目文件到网站版块下,并设置前端站点环境为,纯静态版本环境,见下图:

设置前端站点的环境

设置前端站点的反向代理,见下图:

设置前端站点的反向代理

通过上面轻松的设置,我们现在从外网访问前端站点:https://m.trademark.lilogs.com/,相关的后端接口访问则是如下效果:

请求接口说明

前端站点,加入jump反向代理区域入口,经过nginx服务反向代理解析,访问真实的业务接口地址则是:http://127.0.0.1:6123

总结,反向代理技术思路,见下图:

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2021-1-11 1,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 非同源策略
  • 二、跨域的场景介绍
  • 三、常见的跨域的解决方案有哪些?
  • 四、代理有那些?
    • 正向代理
      • 反向代理
      • 五、如何解决跨域?
        • nginx代理解决跨域
          • 1、跨域原理
          • 2、实现思路
          • 3、宝塔面板中,如何启动反向代理
      相关产品与服务
      负载均衡
      负载均衡(Cloud Load Balancer,CLB)提供安全快捷的流量分发服务,访问流量经由 CLB 可以自动分配到云中的多台后端服务器上,扩展系统的服务能力并消除单点故障。负载均衡支持亿级连接和千万级并发,可轻松应对大流量访问,满足业务需求。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档