什么是跨域?如何解决?

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/shi851051279/article/details/87540517

1、什么是跨域

跨域:指的是路蓝旗不能执行其他网站的脚本。他是由浏览器的同源策略造成的,是浏览器对javascript 施加的安全限制。
例如:a页面想获取b页面的资源,如果a、b页面的协议、域名、端口、子域名不同,所进行的访问行动都是跨域的。而浏览器为了安全问题一般都限制了跨域访问,也就是不允许跨域请求资源。注意:跨域限制访问,其实是浏览器的限制。理解这一点很重要!!!

同源策略: 是指协议,域名,端口都要相同,其中有一个不同都会产生跨域。
在这里插入图片描述

2跨域访问示例

假设有两个网站,A网站部署在:http://localhost:81 即本地ip端口81上;B网站部署在:http://localhost:82 即本地ip端口82上。现在A网站的页面想去访问B网站的信息,A网站页面的代码如下(这里使用jquery的异步请求)

$(function (){
    $.get("http://localhost:82/api/values", {},function (result) {
          $("#show").html(result);
  })});

在这里插入图片描述
从错误信息可以看出以上出现了跨域问题!

3.如何解决跨域问题?

由之前的介绍我们已经知道错误的原因,既然跨域会产生问题,那么我们就不跨域不就完了嘛!!!

nginx 代理
先上图:

在这里插入图片描述
首先我们用nginx作为代理服务器和用户交互,这样用户就只需要在80端口上进行交互就可以了,这样就避免了跨域问题,因为我们都是在80端口上进行交互的;

下面我们看一下利用nginx作为反向代理的具体配置:

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.当用户发送localhost:80/时会被nginx转发到http://localhost:81服务;2.当界面请求接口数据时,只要以/apis 为开头,就会被nginx转发到后端接口服务器上;总结:nginx实现跨域的原理,实际就是把web项目和后端接口项目放到一个域中,这样就不存在跨域问题,然后根据请求地址去请求不同服务器(真正干活的服务器);

node本地服务器代理
传送门
这篇博客中有详细的操作步骤

还有就是通过webpack 的 proxy 代理转发。这种因为涉及的东西比较多在此不做过多说明!

JSONP
ajax请求受同源策略影响,不允许进行跨域请求,而script标签src属性中的链接却可以访问跨域的js脚本,利用这个特性,服务端不再返回JSON格式的数据,而是返回一段调用某个函数的js代码,在src中进行了调用,这样实现了跨域。
(其实就是动态添加script标签,在请求地址后边加上callback 回调函数)

<!-- a.html -->
<script>
    function dealData (data) {
        console.log(data);
    }
</script>
 
<script src='http://example.com/data.php?callback=dealData'></script>
<?php
    $callback = $_GET['callback'];
    $data = 'data';
    echo $callback.'('.json_encode($data).')';
?>

但是要注意JSONP只支持GET请求,不支持POST请求。

没有更多推荐了,返回首页