原生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. 《前端之路》- TypeScript(二) 函数篇

    目录 一.定义函数方法 二.定义函数传参 三.可选传参 四.默认传参 五.传递剩余参数 六.函数重载 七.箭头函数 八.总结 一.定义函数方法 在 es5 中定时函数的方法有 命名函数和函数表达式(匿 ...

  2. SyntaxError: unexpected character after line continuation character

    SyntaxError: unexpected character after line continuation character 待解决问题:在运行.py文件时报错SyntaxError: un ...

  3. 在Centos系统中基于PowerDNS和Poweradmin自建域名解析服务器替代DnsPod

    本文讲述了我在Centos 7系统(其他版本的Centos未尝试)中基于PowerDNS和poweradmin自建域名解析服务器替代DnsPod的过程.通过本文所述方法,可以建立权威域名解析服务器的m ...

  4. 我用STM32MP1做了个疫情监控平台2—Qt环境搭建

    目录 1.嵌入式Qt简介 2.查看开发板Qt库的版本 3.主机搭建Qt环境 4.第一个Qt程序--Hello World 5.一些问题 @ 1.嵌入式Qt简介 Qt 是一个跨平台的应用程序开发框架.使 ...

  5. Natas31 Writeup(Perl 远程命令执行)

    Natas31: 源码如下: my $cgi = CGI->new; if ($cgi->upload('file')) { my $file = $cgi->param('file ...

  6. JDBC怎么连接数据库

    1:注册驱动:class.forName("com.mysql.jdbc.Driver"); 2:连接数据库:DriverManager.getConnection(url , u ...

  7. Jocke的IOT之路--raspberrypi更换国内镜像

    一.编辑sources.list文件 sudo nano /etc/apt/sources.list 使用#将文件内容全部注释调,更改位 deb http://mirrors.tuna.tsinghu ...

  8. 干货 | Python进阶系列之学习笔记(二)

    目录 对象 字符串 一.对象 (1)什么是对象 在python中一切都是对象,每个对象都有三个属性分别是,(id)身份,就是在内存中的地址,类型(type),是int.字符.字典(dic).列表(li ...

  9. 新手必备 | 史上最全的PyTorch学习资源汇总

    目录: PyTorch学习教程.手册 PyTorch视频教程 PyTorch项目资源      - NLP&PyTorch实战      - CV&PyTorch实战 PyTorch论 ...

  10. Jmeter 中 Bean Shell 之全局变量

    1.新建测试计划>线程组 > http 请求 -登录 获取token , 可以参照我以前写的这篇博客 https://www.cnblogs.com/cyit/p/12632445.htm ...