CTFHub技能树-备份文件下载-vim缓存

目录

方法一:直接浏览器访问

方法二:使用kali恢复vim缓存文件

方法三:直接使用curl访问

最后同样备份文件系列的都可用dirsearch扫描


当开发人员在线上环境中使用 vim 编辑器,在使用过程中会留下 vim 编辑器缓存,当vim异常退出时,缓存会一直留在服务器上,引起网站源码泄露。

一、前置知识

在编辑文件的过程中,Vim将会在当前目录中自动生成一个以.swp结尾的临时交换文件,用于备份缓冲区中的内容,以便在意外退出时可以恢复之前编辑的内容。

当完成编辑并保存退出后,临时交换文件将会被删除;但如果Vim意外退出,那么这个临时文件就会留在硬盘中。当Vim再次启动时,会检查当前目录中是否存在交换文件。如果存在,则意味着Vim正在编辑此文件,或者在上次编辑过程中意外退出,这时Vim就会给出警告信息,并要求我们在以下四个选项中做出选择:

Open Read-Only(以只读方式打开):如果我们想要查看文件内容或是有另一个编辑过程正在运行,那么可以选择此选项;

Edit anyway(编辑文件):请尽量不要选择此选项。因为如果同时有两个或是多个编辑过程同时编辑一个文件,那么只有最后一个保存的编辑过程有效;

Recover(恢复):如果在编辑过程中vim意外退出,那么可以选择此选项尝试从交换文件恢复文档;

Quit(退出):选择此选项,将取消对此文件的修改。

在使用vim时会创建临时缓存文件,关闭vim时缓存文件则会被删除,当vim异常退出后,因为未处理缓存文件,导致可以通过缓存文件恢复原始文件内容

以 index.php 为例:第一次产生的交换文件名为 .index.php.swp

再次意外退出后,将会产生名为 .index.php.swo 的交换文件

第三次产生的交换文件则为 .index.php.swn

方法一:直接浏览器访问

直接访问/.index.php.swp文件可以看到为二进制文件

使用代码编辑器恢复文件

方法二:使用kali恢复vim缓存文件

下载该vim缓存文件

wget challenge-801aa09cb1ad910e.sandbox.ctfhub.com:10800/.index.php.swp -p /Desktop

注意:vim缓存文件ls指令是不显示的

直接使用

vim -r .index.php.swp

使用kali的vim编辑器恢复该vim缓存文件

方法三:直接使用curl访问

curl challenge-801aa09cb1ad910e.sandbox.ctfhub.com:10800/.index.php.swp -o -

最后同样备份文件系列的都可用dirsearch扫描

相关推荐
Z3r4y2 天前
【Web】2024“国城杯”网络安全挑战大赛决赛题解(全)
web·ctf·wp·国城杯·国城杯决赛
WTT00112 天前
2024楚慧杯WP
大数据·运维·网络·安全·web安全·ctf
摸鱼也很难2 天前
RCE 命令执行漏洞 && 过滤模式 && 基本的过滤问题 && 联合ctf题目进行实践
漏洞·ctf·ctfshow·rce命令执行
亿.63 天前
2024楚慧杯-Web
web·ctf·writeup
吾即是光6 天前
[HNCTF 2022 Week1]你想学密码吗?
ctf
吾即是光6 天前
[NSSCTF 2022 Spring Recruit]factor
ctf
吾即是光6 天前
[LitCTF 2023]easy_math (中级)
ctf
吾即是光7 天前
[HNCTF 2022 Week1]baby_rsa
ctf
云梦姐姐8 天前
Bugku-CTF getshell
ctf·wp
l2xcty9 天前
【网络安全】Web安全基础- 第一节:web前置基础知识
安全·web安全·网络安全·ctf