什么是JSONP

首先提一下JSON这个概念,JSON是一种轻量级的数据传输格式,被广泛应用于当前Web应用中。JSON格式数据的编码和解析基本在所有主流语言中都被实现,所以现在大部分前后端分离的架构都以JSON格式进行数据的传输。

那么JSONP是什么呢? 
首先抛出浏览器同源策略这个概念,为了保证用户访问的安全,现代浏览器使用了同源策略,即不允许访问非同源的页面,详细的概念大家可以自行百度。这里大家只要知道,在ajax中,不允许请求非同源的URL就可以了,比如www.a.com下的一个页面,其中的ajax请求是不允许访问www.b.com/c.php这样一个页面的。

JSONP就是用来解决跨域请求问题的,那么具体是怎么实现的呢?

JSONP原理

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

JSONP具体实现

1.首先看下ajax中如果进行跨域请求会如何。 
前端代码在域www.practice.com下面,使用ajax发送了一个跨域的get请求

<!DOCTYPE html>
<html>
<head><title>GoJSONP</title>
</head>
<body>
<script type="text/javascript">function jsonhandle(data){alert("age:" + data.age + "name:" + data.name);}
</script>
<script type="text/javascript" src="jquery-1.8.3.min.js">
</script>
<script type="text/javascript">$(document).ready(function(){$.ajax({type : "get",async: false,url : "http://www.practice-zhao.com/student.php?id=1",type: "json",success : function(data) {jsonhandle(data);}});});
</script>
</body>
</html>

后端PHP代码放在域www.practice-zhao.com下,简单的输出一段json格式的数据

jsonhandle({"age" : 15,"name": "John",
})

当访问前端代码http://www.practice.com/gojsonp/index.html 时 chrome报以下错误 

提示了不同源的URL禁止访问

2.下面使用JSONP,将前端代码中的ajax请求去掉,添加了一个script标签,标签的src指向了另一个域www.practice-zhao.com下的remote.js脚本

<!DOCTYPE html>
<html>
<head><title>GoJSONP</title>
</head>
<body>
<script type="text/javascript">function jsonhandle(data){alert("age:" + data.age + "name:" + data.name);}
</script>
<script type="text/javascript" src="jquery-1.8.3.min.js">
</script>
<script type="text/javascript" src="http://www.practice-zhao.com/remote.js"></script>
</body>
</html>

这里调用了跨域的remote.js脚本,remote.js代码如下:

jsonhandle({"age" : 15,"name": "John",
})

也就是这段远程的js代码执行了上面定义的函数,弹出了提示框 

3.将前端代码再进行修改,代码如下:

<!DOCTYPE html>
<html>
<head><title>GoJSONP</title>
</head>
<body>
<script type="text/javascript">function jsonhandle(data){alert("age:" + data.age + "name:" + data.name);}
</script>
<script type="text/javascript" src="jquery-1.8.3.min.js">
</script>
<script type="text/javascript">$(document).ready(function(){var url = "http://www.practice-zhao.com/student.php?id=1&callback=jsonhandle";var obj = $('<script><\/script>');obj.attr("src",url);$("body").append(obj);});
</script>
</body>
</html>

这里动态的添加了一个script标签,src指向跨域的一个php脚本,并且将上面的js函数名作为callback参数传入,那么我们看下PHP代码怎么写的:

<?php
$data = array('age' => 20,'name' => '张三',
);$callback = $_GET['callback'];echo $callback."(".json_encode($data).")";
return;

PHP代码返回了一段JS语句,即

jsonhandle({"age" : 15,"name": "张三",
})

此时访问页面时,动态添加了一个script标签,src指向PHP脚本,执行返回的JS代码,成功弹出提示框。

所以JSONP将访问跨域请求变成了执行远程JS代码,服务端不再返回JSON格式的数据,而是返回了一段将JSON数据作为传入参数的函数执行代码。

4.最后jQuery提供了方便使用JSONP的方式,代码如下:

<!DOCTYPE html>
<html>
<head><title>GoJSONP</title>
</head>
<body>
<script type="text/javascript" src="jquery-1.8.3.min.js">
</script>
<script type="text/javascript">$(document).ready(function(){$.ajax({type : "get",async: false,url : "http://www.practice-zhao.com/student.php?id=1",dataType: "jsonp",jsonp:"callback", //请求php的参数名jsonpCallback: "jsonhandle",//要执行的回调函数success : function(data) {alert("age:" + data.age + "name:" + data.name);}});});
</script>
</body>
</html>

5.JSONP优缺点:

jsonp优点:
        完美解决在测试或者开发中获取不同域下的数据,用户传递一个callback参数给服务端,然后服务端返回数据时会将这个callback参数作为函数名来包裹住JSON数据,这样客户端就可以随意定制自己的函数来自动处理返回数据了。简单来说数据的格式没有发生很大变化

jsonp缺点:

这里主要讲jsonp的缺点,也就是我上面说的没有用这个的原因

1. jsonp只支持get请求而不支持post请求,也即是说如果想传给后台一个json格式的数据,此时问题就来了,浏览器会报一个http状态码415错误,告诉你请求格式不正确,这让我很蛋疼(在登录注册中需要给后台传一大串数据),如果都用参数的形式拼接在url后面的话不太现实,后台取值也会显得繁琐,

2.在登录模块中需要用到session来判断当前用户的登录状态,这时候由于是跨域的原因,前后台的取到的session是不一样的,那么就不能就行session来判断.

3.由于jsonp存在安全性问题(不知qq空间的跨域是怎么解决的,还是另有高招?)后来考虑到上面的一系列问题,采用的是后台进行设置允许跨域请求(但还是存在缺陷的,实质上还是跨域,如上面说的session问题)

.Header set Access-Control-Allow-Origin *

为了防止XSS攻击我们的服务器, 我们可以限制域,比如

Access-Control-Allow-Origin: http://blog.csdn.net

安全防范:

1.防止callback参数意外截断js代码,特殊字符单引号双引号,换行符存在风险.

2.防止callback参数恶意添加script标签,造成xss漏洞

3.防止跨域请求滥用,阻止非法站点恶意调用

详细请看 :http://blog.csdn.net/jian_xi/article/details/66474717


JSONP原理及使用相关推荐

  1. Ajax跨域:Jsonp原理解析

    推荐先看下这篇文章:JS跨域(ajax跨域.iframe跨域)解决方法及原理详解(jsonp) JavaScript是一种在Web开发中经常使用的前端动态脚本技术.在JavaScript中,有一个很重 ...

  2. JQuery实现Ajax跨域访问--Jsonp原理

    JavaScript是一种在Web开发中经常使用的前端动态脚本技术.在JavaScript中,有一个很重要的安全性限制,被称为"Same-Origin Policy"(同源策略). ...

  3. JSONP原理以及安全问题

    JSONP介绍 JSONP全称是JSON with Padding ,是基于JSON格式的为解决跨域请求资源而产生的解决方案.他实现的基本原理是利用了 HTML 里 元素标签没有跨域限制 JSONP原 ...

  4. php json 原理,基于JSONP原理详解

    本文主要为大家推荐一篇基于JSONP原理解析,具有很好的参考价值,希望对大家有所帮助.一起跟随小编过来看看吧,希望能帮助到大家. 前言 我工作以来接触的第一个项目就是前后端分离的,前端静态文件有自己独 ...

  5. 跨域解决方法——jsonp原理

    跨域解决方法--jsonp原理 一个域名地址的组成: 当协议.子域名.主域名.端口号任意一个不相同时,都算作不同域,不同域之间相互请求资源,就算做"跨域".由于浏览器同源策略的限制 ...

  6. jsonp原理-node篇

    jsonp-原理node篇 在学习kerwin老师讲的nodejs的课程其中的jsonp原理这节课,使我理解的更加透彻,加深了我对jsonp理解,所以我打算写一篇文章用来记录一下,jsonp的学习成果 ...

  7. jsonp原理和详解

    在介绍JSONP之前,先简单的介绍一些JSON.JSON是JavaScript Object Notation的缩写,是一种轻量的.可读的基于文本的数据交换开放标准.源于JavsScript编程语言中 ...

  8. js跨域请求方式 ---- JSONP原理解析

    这篇文章主要介绍了js跨域请求的5中解决方式的相关资料,需要的朋友可以参考下 跨域请求数据解决方案主要有如下解决方法: 1 2 3 4 5 JSONP方式 表单POST方式 服务器代理 Html5的X ...

  9. “约见”面试官系列之常见面试题之第六十七篇之jsonp原理和实现(建议收藏)

    一. 同源策略 所有支持Javascript的浏览器都会使用同源策略这个安全策略.看看百度的解释: 同源策略,它是由Netscape提出的一个著名的安全策略. 现在所有支持JavaScript 的浏览 ...

  10. 彻底弄懂jsonp原理及实现方法

    一. 同源策略 所有支持Javascript的浏览器都会使用同源策略这个安全策略.看看百度的解释: 同源策略,它是由Netscape提出的一个著名的安全策略. 现在所有支持JavaScript 的浏览 ...

最新文章

  1. java maven项目使用sonar审核代码
  2. 基于tcpdump的Android智能移动终端数据包捕获完整解决方案
  3. u3d无锯齿遮罩shader-可用于ugui
  4. 微软Office Online服务安装部署及wopi代码实现--------域控制服务器安装
  5. 网骗欺诈?网络裸奔?都是因为 HTTP?
  6. IIS服务器SSL证书安装
  7. Kubernetes-Service服务(十一)
  8. mysql学习笔记 查找技术 1207 0311
  9. mysql binlog更新记录缺失_记一次mysql数据库binlog丢失引起的故障
  10. sqli注入前置知识
  11. 电销机器人源码支持私有云和本地部署
  12. SIFT特征提取原理
  13. 计算机图形学常用知识点,计算机图形学基础重点
  14. 「NLP入门系列」11. 使用 Seq2Seq 模型进行文本翻译
  15. 关机计算机cmd,图文详解电脑关机命令是什么
  16. 云之家:SaaS协同市场的“隐形冠军”
  17. html 制作箭头,怎么使用html制作箭头?制作箭头代码分享!
  18. php ajax 域名查询,PHP+AJAX 实现域名查询系统
  19. 对开源软件的认识与实践-刘彬
  20. Python爬虫包 BeautifulSoup 递归抓取实例详解

热门文章

  1. STC学习:八位数码管滚动显示
  2. 2020年不能启动win7_包装车间2020年大修正式启动
  3. 在html种颜色的代码,html颜色代码生成器
  4. linux 在线考试系统下载,在线考试系统-英文版
  5. oracle定时清理回收站,电脑设置定时清理回收站的操作方法
  6. Armadillo:踩坑指南(ubuntu-16.04+clion)
  7. 深度学习图解 - 具备高中数学知识就能从入门到精通的神书 Andrew W· Trask
  8. Google Code Review 处理代码审查中的推回
  9. k8s和mysql怎么通信_k8s中的网络通信总结
  10. 智力问答选择题_智力问答题