zoukankan      html  css  js  c++  java
  • AJAX跨域请求详解

     最近开始学习ajax,学习ajax必须得掌握的就是跨域请求,实际上在不同源的地址上发送请求就是跨域请求

    域名地址的组成:

    http:// www . google : 8080 / script/jquery.js

          http:// (协议号)

                   www  (子域名)

                 google (主域名)

                   8080 (端口号)

    script/jquery.js (请求的地址)

    * 当协议、子域名、主域名、端口号中任意一各不相同时,都算不同的“域”。

    * 不同的域之间相互请求资源,就叫“跨域”。

    我们所了解的能够发送请求的有 img 、link、script 这些

    ##1    img

    img可以发送不同源地址之间的请求,但是无法拿到响应结果;

    ##2   link

    link可以发送不同源地址之间的请求,但是无法拿到响应结果或者说不能够处理

    #3   script

    script可以发送不同源地址之间的请求,但是无法拿到响应结果,但是能借助于能够作为js执行能获取数据

    跨域请求解决办法----jsonp:

    原理:通过script 标签请求一个服务器端的PHP文件,这个文件返回的结果是一段JS,作用是调用我们事先定义好的一个函数,从而将服务器端想要给客户端发过去的数据发送给客户端。具体实现如下:

    客户端:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
    </head>
    <body>
        <script>
            var script = document.createElement('script');
            script.src='http://test1.com/jsonp/server.php';
            document.body.appendChild(script);
            function aabb(res){
                console.log(res);
            }
        </script>
    </body>
    </html>

    服务端:

    <?php 
      $conn=mysqli_connect('127.0.0.1','root','root','demo1');
    
      $query=mysqli_query($conn,'select * from users');
    
      while ($row = mysqli_fetch_assoc($query)){
          $data[]=$row;
      }
      // header('Content-Type:application/json');
      // echo json_encode($data);
      // 如果客户端采用的是 script 标记对我发送的请求
      // 一定要返回一段 javascript
    
        header('Content-Type:application/json');
        $result=json_encode($data);
        echo "aabb({$result})";

    注意:但是JSONP只支持 “GET” 请求,但不支持 “POST” 请求。

  • 相关阅读:
    如何快速转载CSDN及博客园中的博客
    Ubuntu18.04连不网 报"有线连接未托管"
    Ubuntu18.04的网络配置
    vim基本操作
    Git更新远程仓库代码到本地(转)
    POJ 3253 Fence Repair
    POJ 2503 Babelfish
    POJ 2002 Squares
    POJ 1840 Eqs
    POJ 3274 Gold Balanced Lineup
  • 原文地址:https://www.cnblogs.com/Yaucheun/p/10492924.html
Copyright © 2011-2022 走看看