怎么分析Facebook Ads广告业务API接口的源代码泄露漏洞
发布时间 - 2023-05-11 00:00:00 点击率:次发现漏洞
一个多月后,我就发现了存在facebook ads广告业务系统api中的一个漏洞。存在漏洞的api是一个图片处理接口,它用于facebook商户账户上传广告图片,上传的图片会储存在一个名为“/adimages”的目录下,并用base64格式编码。所以,我的测试构想是,在这里的机制中,可以向上传图片中注入恶意payload,经api转换为 base64 格式后,再被facebook传入服务器中。
以下为上传图片的POST请求:
POST /v2.10/act_123456789/adimages HTTP/1.1Host: graph.facebook.comBytes=VGhpcyBpcyBtYWxpY2lvdXMgcGF5bG9hZC4=
由于Facebook服务器端不能有效地处理恶意Payload图片,最终其“Image Resizing Tool”图片处理工具返回了一个报错,在某个JSON响应内容的异常消息中,就包括了一些PHP库函数代码,这些代码来自不同的Facebook库文件,可以肯定的是,这应该属于Facebook源代码的一部份。
HTTP/1.1 200 OK{“error”:{“message”:”Invalid parameter”,”type”:”FacebookApiException”,”code”:100,”error_data”:”exception ‘Exception’ with message ‘gen_image_rescale_multi_thrift call to shrinkImageMulti failed with fbalgo exception: 43 (43: : IDAT: invalid distance too far back)’ in \/var\/www\/flib\/resource\/filesystem\/upload\/upload.php:1393\nStack trace:\n#0 \/var\/www\/flib\/resource\/filesystem\/upload\/upload.php(1662): gen_image_rescale_multi_thrift()\n#1 \/var\/www\/flib\/ads\/admanager\/adupload\/adupload.php(252): gen_image_rescale_multi()\n#2 \/var\/www\/flib\/ads\/admanager\/adupload\/AdImageUtils.php(195): _gen_adupload_image_resize()\n#3 \/var\/www\/flib\/ads\/entities\/creatives\/photos\/AdproCreativePhotoDownload.php(53): AdImageUtils::genResizeLocalFile()\n#4 \/var\/www\/flib\/platform\/graph\/resources\/adaccount\/adimages\/mutators\/GraphAdAccountAdImagesPost.php(134): AdproCreativePhotoDownload::addLocalFileToCreativeLibrary()\n#5 \/var\/www\/flib\/core\/data_structures\/utils\/Arrays.php(440): Closure$GraphAdAccountAdImagesPost::genImplementation#3()\n#6 \/var\/www\/flib\/platform\/graph\/resources\/adaccount\/adimages\/mutators\/GraphAdAccountAdImagesPost.php(136): Arrays::genMapWithKey()\n#7 \/var\/www\/flib\/ads\/api\/graph_base\/GraphAdsWriteWithRedirectBase.php(22): GraphAdAccountAdImagesPost->genImplementation()\n#8 \/var\/www\/flib\/ads\/api\/graph_base\/GraphAdsWriteWithRedirectBase.php(11): GraphAdsWriteWithRedirectBase->genDoCall()\n#9 \/var\/www\/flib\/core\/asio\/gen_utils.php(24): GraphAdsWriteWithRedirectBase->genCall()\n#10 \/var\/www\/flib\/platform\/api\/base\/ApiBaseWithTypedApiData.php(204): genw()\n#11 \/var\/www\/flib\/platform\/api\/base\/ApiBase.php(85): ApiBaseWithTypedApiData->genCallWithApiDataBase()\n#12 \/var\/www\/flib\/platform\/graph\/core\/runner\/GraphApiRunnerBase.php(373): ApiBase->genMakeCall()\n#13 \/var\/www\/flib\/platform\/graph\/core\/GraphRequestProcessorBase.php(629): GraphApiRunnerBase->genCall()\n#14 \/var\/www\/flib\/platform\/graph\/core\/GraphRequestProcessorBase.php(45): GraphRequestProcessorBase->genExecuteSingleGraphRequestCore()\n#15 \/var\/www\/api\/graph\/server.php(168): GraphRequestProcessorBase->genExecuteSingleGraphRequest()\n#16 \/var\/www\/api\/graph\/server.php(174): gen_api_graph_server()\n#17 \/var\/www\/flib\/core\/asio\/Asio.php(35): gen_api_graph_server_wrapper()\n#18 (): Closure$Asio::enterAsyncEntryPoint()\n#19 \/var\/www\/flib\/core\/asio\/Asio.php(37): HH\\Asio\\join()\n#20 \/var\/www\/api\/graph\/server.php(180): Asio::enterAsyncEntryPoint()\n#21 {main}”,”error_subcode”:1487242,”is_transient”:false,”error_user_title”:”Image Resize Failed”,”error_user_msg”:”Image Resize Failed:unknown reason”,”fbtrace_id”:”EN\/o9h
mqwZz”},”__fb_trace_id__”:”EN\/o9hmqwZz”}
# facebook
# 上传图片
# 的是
# 是一个
# 图片处理
# 上传
# 我就
# 在这里
# 有效地
# 多月
# 报错
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
手机网站制作与建设方案,手机网站如何建设?
nodejs redis 发布订阅机制封装实现方法及实例代码
Laravel怎么创建控制器Controller_Laravel路由绑定与控制器逻辑编写【指南】
如何用PHP快速搭建高效网站?分步指南
如何基于云服务器快速搭建网站及云盘系统?
Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤
阿里云高弹*务器配置方案|支持分布式架构与多节点部署
mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?
Laravel用户密码怎么加密_Laravel Hash门面使用教程
Laravel如何安装使用Debugbar工具栏_Laravel性能调试与SQL监控插件【步骤】
在线教育网站制作平台,山西立德教育官网?
Laravel Eloquent模型如何创建_Laravel ORM基础之Model创建与使用教程
如何在景安云服务器上绑定域名并配置虚拟主机?
Laravel如何升级到最新版本?(升级指南和步骤)
java获取注册ip实例
如何确保FTP站点访问权限与数据传输安全?
网站建设要注意的标准 促进网站用户好感度!
Angular 表单中正确绑定输入值以确保提交与验证正常工作
如何用y主机助手快速搭建网站?
Laravel如何实现API版本控制_Laravel API版本化路由设计策略
Laravel项目如何进行性能优化_Laravel应用性能分析与优化技巧大全
Laravel如何使用withoutEvents方法临时禁用模型事件
Laravel如何处理跨站请求伪造(CSRF)保护_Laravel表单安全机制与令牌校验
JS弹性运动实现方法分析
laravel怎么为API路由添加签名中间件保护_laravel API路由签名中间件保护方法
Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)
高防服务器租用首荐平台,企业级优惠套餐快速部署
如何快速选择适合个人网站的云服务器配置?
百度输入法ai面板怎么关 百度输入法ai面板隐藏技巧
Laravel如何使用Eloquent进行子查询
Laravel怎么防止CSRF攻击_Laravel CSRF保护中间件原理与实践
Laravel路由怎么定义_Laravel核心路由系统完全入门指南
Claude怎样写约束型提示词_Claude约束提示词写法【教程】
百度输入法全感官ai怎么关 百度输入法全感官皮肤关闭
Laravel如何正确地在控制器和模型之间分配逻辑_Laravel代码职责分离与架构建议
ChatGPT常用指令模板大全 新手快速上手的万能Prompt合集
装修招标网站设计制作流程,装修招标流程?
Laravel如何实现数据库事务?(DB Facade示例)
Laravel怎么连接多个数据库_Laravel多数据库连接配置
Laravel Fortify是什么,和Jetstream有什么关系
邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?
如何用PHP工具快速搭建高效网站?
如何挑选高效建站主机与优质域名?
Swift中swift中的switch 语句
Microsoft Edge如何解决网页加载问题 Edge浏览器加载问题修复
如何在万网利用已有域名快速建站?
如何制作一个表白网站视频,关于勇敢表白的小标题?
Laravel怎么清理缓存_Laravel optimize clear命令详解
如何在建站宝盒中设置产品搜索功能?
今日头条微视频如何找选题 今日头条微视频找选题技巧【指南】


mqwZz”},”__fb_trace_id__”:”EN\/o9hmqwZz”}