当前位置: 首页 > news >正文

[CTF]攻防世界:easy_laravel 学习

题目:攻防世界:easy_laravel 学习

提示:blade + pop chain(代码审计+sql注入+blade缓存+反序列化)

直接F12查看源码


php的web框架

一、注入

查看源码:

这里应该是注入点:

看到管理员认证,判断邮箱

可以重置密码,但是需要token


token在表password_reset中

确定思路:注册用户sql注入拿到token–>reset一下管理员的密码,生成token–>登录获取flag

1、注入

laravel内置重置密码在Illuminate\Auth\Passwords中实现,重置密码需要填写邮箱,并向邮箱发送一个重置链接。
laravel在5.4以后都是将token加密存储的,而之前是明文存储,所以我们就可以注入出token重置admin密码
先访问**/password/reset重置admin密码,然后注出token,访问/password/reset/[token]**,完成重置


2、登录后发现显示 no flag

二. blade 模板

Blade 是 Laravel 提供的一个简单而又强大的模板引擎。和其他流行的 PHP 模板引擎不同,Blade 并不限制你在视图中使用原生 PHP 代码。所有 Blade 视图文件都将被编译成原生的 PHP 代码并缓存起来,除非它被修改,否则不会重新编译,这就意味着 Blade 基本上不会给你的应用增加任何负担。Blade 视图文件使用 .blade.php 作为文件扩展名,被存放在 resources/views 目录。

所以当我们修改了flag的balde模板但是还没有编译使其渲染出新的flag页面,其页面还是没修改时的那个缓存

删除缓存文件:
1、上传phar文件
2、利用phar文件删除缓存文件

upload 实现phar文件上传 check利用


通过此类实现反序列化。

确定一下相关文件目录:
1、blade缓存位置:storage/framework/views
2、apache默认目录:/var/www/html/

加一起缓存文件就是 :/var/www/html/storage/framework/views/flag.blade.php
(sha1()==>34e41df0934a75437873264cd28e2d835bc38772)

phaer 文件是以序列化形式存储的。当解析它的时候,必然会用到反序列化的一些魔术方法。受影响的函数包括


从其他师傅那学习到的生成phar的代码:

<?php require'vendor/autoload.php';$a=serialize(newSwift_ByteStream_TemporaryFileByteStream());var_dump(unserialize($a));var_dump($a);# 这个函数很有趣,$_path 也就是删除的目录是可以自己制定的,将这里面的内容换成我们想要的内容,就可以删掉flag的缓存文件。 $a=preg_replace("/\/tmp\/FileByteStream[\w]{6}/","/usr/share/nginx/html/storage/framework/views/34e41df0934a75437873264cd28e2d835bc38772.php",$a);$a=str_replace('s:25','s:90',$a);# 这里将 _path 的内容修改掉 $b=unserialize($a);$p=newPhar('./shell.phar',0);$p->startBuffering();$p->setStub('GIF89a<?php __HALT_COMPILER(); ?>');# 改文件头 $p->setMetadata($b);$p->addFromString('test.txt','text');$p->stopBuffering();rename('shell.phar','1.gif')?>

生成后,将1.gif上传,然后点击check。

修改数据包

重新访问/flag路由,得到flag


flag: flag{d64e4b06f672429682a96b11172a8938}

http://www.gsyq.cn/news/95407.html

相关文章:

  • 40、敏捷开发相关指标与实践解析
  • 书生Intern-S1震撼发布:开源多模态AI模型改写科学研究范式
  • DDNS动态域名解析方案对比与实战配置
  • Linux批量清理Webman进程
  • 个人博客作业 3
  • ComfyUI与社交平台头像生成结合:个性化IP打造工具
  • 当LCL逆变器遇上谐波:两个前馈策略的实战PK
  • 《家庭的觉醒》——写给天天跟电脑打交道的你
  • Qwen3-VL-4B-Thinking-FP8震撼发布:FP8量化技术引领多模态模型部署革命
  • 突破生成模型效率瓶颈:Consistency Models开源代码库深度解析
  • Cogito v2大语言模型重磅发布:引领混合推理技术革命,解锁AI多模态应用新范式
  • Holo1.5系列大模型横空出世:重新定义计算机使用代理技术新高度
  • 行业变革新趋势:探索当前技术发展的核心动力与未来方向
  • 2.4 实战项目:构建智能数据库查询工具
  • 互联网大厂Java面试:谢飞机的搞笑历险记
  • IBM发布320亿参数长上下文模型Granite-4.0-H-Small,重新定义企业级AI应用标准
  • 人工智能发展新趋势:多模态大模型引领认知革命
  • NextStep-1横空出世:突破连续 tokens 瓶颈,革新自回归图像生成技术
  • 10、网络传输与会话管理工具:lftp 与 screen 实用指南
  • 英伟达数学推理新突破:15亿参数模型性能媲美完整版DeepSeek-R1
  • 2.1 深入理解Cursor核心功能:文档集成与智能交互
  • 2.1 Cursor进阶技巧:Rules设置与文档集成全攻略
  • 11、使用SELinux提升Linux系统安全性
  • 一个应用程序可以有多个进程吗?各进程之间是如何进行通信的?
  • 小米MiMo-Audio-7B-Base震撼发布:音频语言模型开源新标杆
  • 百度文心大模型4.5全系列源代码开放 配套API服务同步上线
  • 登顶开源Agent模型榜首:阿里通义DeepResearch凭何超越OpenAI与深度求索?
  • AI行业周报:腾讯混元3D模型开源破局 谷歌Gemma 3等新品重塑技术边界
  • JVM 面试题相关总结
  • 3、数字转型时代的商业模式探索