原生JS如何实现Ajax的跨域请求?

在解决这个问题之前,我们务必先清楚为什么我们要跨域请求,以及在什么情况下会跨域请求。

了解一下:“同源策略”,你就知道了;

  同源策略限制从一个源加载的文档或脚本如何与来自另一个源的资源进行交互。这是一个用于隔离潜在恶意文件的关键的安全机制。

  它的定义是:

    一段脚本向后台请求数据,只能读取属于同一协议名、同一主机名、同一端口号下的数据;

    所以,请求不同协议名、不同端口号、不同主机名下面的文件时,

  将会违背同源策略,无法请求成功,需要进行跨越处理!!

解决跨域请求的方法:

方法一:

  通过后台的PHP进行设置

  前台无需任何设置,在后台被请求的PHP文件中,写入一条header。

    header("Access-Control-Allow-Origin:*");    --- 表示允许哪些域名请求这个PHP文件,*表示所有域名都允许

JS代码:  

$.post("http://127.0.0.1/json.php",function(data){
console.log(data);
});

注释:

  其中,url为PHP文件的路径;

PHP代码:

<?php
header("Content-Tyepe:text/html;charset=utf-8");
header("Access-Control-Allow-Origin:*");
$str = <<<str
[
{
"name": "影子",
"age": 17,
"hobby": [
"吃",
"喝",
"玩",
"乐"
],
"score":{
"math":78,
"chinese":89
}
},
]
str;
echo $str;

结果:

  

方法二:

  实现步骤: 

    1、原有src属性的标签子带跨域功能;所以可以使用script标签的src属性请求后台数据

       <script src="http://127.0.0.1/json.php">< /script>

    2、用于src在加载数据成功后,会直接将加载的内容放到script标签中;

         所以,后台直接返回JSON字符串将不能在script标签中解析。

       因此,后台应该返回给前台一个回调函数名,并将JSON字符串作为参数传入。

        后台PHP文件中返回: echo "callback({$json})";

     3、前台接收到返回的回调函数,将直接在script标签中调用。因此,需要声明这样一个回调函数,作为请求成功的回调

function callback(data){

    alert("请求成功!!");

    console.log(data);

}

JS代码:

<script type="text/javascript">
function callback(data){
console.log(data);
}
</script>
<script src="http://127.0.0.1/json.php"></script>

PHP文件:

<?php
header("Content-Tyepe:text/html;charset=utf-8");
$str = <<<str
[
{
"name":"yingzi",
"age":17,
"hobby":[
"吃",
"喝",
"玩",
"乐"
],
}
]
str;
echo "callback({$str})";

结果:

方法三:

   1、在ajax请求时,设置dataType为"jsonp";

2、后台返回时,依然需要返回回调函数名,但是,ajax在发送请求时,会默认使用get请求将回调函数名发给后台,

     后台$_GET['callback'] 取出函数名:

      ---   echo "{$_GET['callback']}({$str})";

3、后台返回以后,前台就可以使用ajax的success函数作为成功的回调

        ---    success : function(data){}

JS代码:

<script type="text/javascript">
$.ajax({
type:"post",
url:"http://127.0.0.1/json.php",
dataType:"jsonp",
success:function(data){
console.log(data);
}
});
</script>

PHP文件:

<?php
header("Content-Tyepe:text/html;charset=utf-8");
$str = <<<str
[
{
"name":"yingzi",
"age":17,
"hobby":[
"吃",
"喝",
"玩",
"乐"
],
}
]
str;
echo "{$_GET['callback']}({$str})";

结果:

当然,后台也可以随便返回一个函数名,前台只要请求成功,就会自动调用这个函数。类似第二条的②、③步,而不需要本方法的第③步

PHP返回: echo "callback({$str})";

JS代码:  function callback(data){

        console.log(data);

      }

JS代码:

<script type="text/javascript">
$.ajax({
type:"post",
url:"http://127.0.0.1/json.php",
dataType:"jsonp",
});
function(data){
console.log(data);
}
</script>

PHP文件:

<?php
header("Content-Tyepe:text/html;charset=utf-8");
$str = <<<str
[
{
"name":"yingzi",
"age":17,
"hobby":[
"吃",
"喝",
"玩",
"乐"
],
}
]
str;
echo "callback({$str})";

结果:

Web前端工程师,关于数据交互这一块,会用到的地方很多;这是大神“影子”的文章,我是无耻的搬运过来的,如有侵权,请联系本人删除;下面附上“影子”的博客原文链接:https://www.cnblogs.com/2502778498spw/p/7784390.html

原生JS实现Ajax的跨域请求的更多相关文章

  1. 原生JS实现Ajax及Ajax的跨域请求

      前  言          如今,从事前端方面的程序猿们,如果,不懂一些前后台的数据交互方面的知识的话,估计都不太好意思说自己是程序猿.当然,如今有着许多的框架,都有相对应的前后台数据交互的方法. ...

  2. Ajax之跨域请求

    一.引子 我现在开启了两个django项目,分别叫Demo1和Demo2,Demo1中有一个路径‘http://127.0.0.1:8000/index/’,对应的视图是index视图返回一个inde ...

  3. 利用Nginx轻松实现Ajax的跨域请求(前后端分离开发调试必备神技)

    利用Nginx轻松实现浏览器中Ajax的跨域请求(前后端分离开发调试必备神技) 前言 为什么会出现跨域? 造成跨域问题的原因是因为浏览器受到同源策略的限制,也就是说js只能访问和操作自己域下的资源,不 ...

  4. 原生JavaScript封装的jsonp跨域请求

    原生JavaScript封装的jsonp跨域请求 <!DOCTYPE html> <html lang="en"> <head> <met ...

  5. 原生JS封装Ajax插件(同域&&jsonp跨域)

    抛出一个问题,其实所谓的熟悉原生JS,怎样的程度才是熟悉呢? 最近都在做原生JS熟悉的练习... 用原生Js封装了一个Ajax插件,引入一般的项目,传传数据,感觉还是可行的...简单说说思路,如有不正 ...

  6. 【笔记】Asp.Net WebApi对js POST带参数跨域请求的支持方案

    先说下需求:在原来的WebApi项目中增加对js跨域的请求支持,请求方式:以POST为主,webapi路由规则根据原项目需求修改如下: public static void Register(Http ...

  7. jQuery的Ajax的跨域请求

    今天碰到一个Ajax跨域请求的问题,我把源码down下来,然后在服务器端写了一个http请求的代理(因为服务器端是不存在跨域问题的),说白了就是用BufferedReader写了个IO流,然后读取到目 ...

  8. jQuery的ajax jsonp跨域请求

    了解:ajax.json.jsonp.“跨域”的关系 要弄清楚以上ajax.json.jsonp概念的关系,我觉得弄清楚ajax是“干什么的”,“怎么实现的”,“有什么问题”,“如果解决存在的问题”等 ...

  9. ajax的跨域请求

    同源策略 同源策略(Same origin policy)是一种约定,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,则浏览器的正常功能可能都会受到影响.可以说Web是构建在同源策略基础之上的 ...

随机推荐

  1. 解决 unable to lock the administration directory (/var/lib/dpkg/) 问题

    阿里开源镜像站提供了raspbian的软件包镜像,国内的用户可以选择改用阿里镜像站作为更新源. 但是在更换源之后,执行 sudo apt-get update && apt-get u ...

  2. Struts UI标签的使用

    先来看一下日期控件 html5标签中其实已经有日期的类型,用<input type="date">便可调用. struts里面也自带了日期控件,其使用步骤为: 1. 导 ...

  3. 033.Kubernetes集群安全-API Server认证及授权

    一 Kubernetes集群安全 1.1 安全机制 Kubernetes通过一系列机制来实现集群的安全控制,其中包括API Server的认证授权.准入控制机制及保护敏感信息的Secret机制等.集群 ...

  4. ngzorro draw 第一次打开 ERROR TypeError: Cannot read property 'overlayElement' of undefined

    at NzDrawerComponent.push../node_modules/ng-zorro-antd/fesm5/ng-zorro-antd.js.NzDrawerComponent.trap ...

  5. 为什么 select count(*) from t,在 InnoDB 引擎中比 MyISAM 慢?

    统计一张表的总数量,是我们开发中常有的业务需求,通常情况下,我们都是使用 select count(*) from t SQL 语句来完成.随着业务数据的增加,你会发现这条语句执行的速度越来越慢,为什 ...

  6. Burpsuite被动扫描流量转发插件:Passive Scan Client

    编译成品:链接: https://pan.baidu.com/s/1E0vsPGgPgB9bXCW-8Yl1gw 提取码: 49eq Passive Scan Client Burpsuite被动扫描 ...

  7. Linux 基础篇(二)

    1.linux 关机和重启 关机: shutdown  -h  10:20  # 指定时间关机 shutdown -h now    # 马上关机 shutdown -h +10  # 10分钟后关机 ...

  8. java 为什么重写equals一定要重写hashcode?

    前言 最近复习,又看到了这个问题,在此记录和整理,通过例子来说明这种情况的原因,使大家可以清晰明白这个问题. 初步探索 首先我们要了解equals方法是什么,hashcode方法是什么. equals ...

  9. 写爬虫爬了3w条职位数据,看看当前招聘形势 | 开源

    最近有不少程序员又开始找工作了,为了了解目前技术类各职位的数量.薪资.招聘公司.岗位职责及要求,我爬取了拉勾网北上广深4个城市的招聘数据,共3w条.职位包括:人工智能(AI).大数据.数据分析.后端( ...

  10. ML Lecture 0-2: Why we need to learn machine learning?

    在Github上也po了这个系列学习笔记(MachineLearningCourseNote),觉得写的不错的小伙伴欢迎来给项目点个赞哦~~ ML Lecture 0-2: Why we need t ...