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扫描

相关推荐
诗人不说梦^4 天前
[RootersCTF2019]I_<3_Flask
web·ctf
爱隐身的官人5 天前
cfshow-web入门-php特性
python·php·ctf
爱隐身的官人5 天前
ctfshow - web - nodejs
前端·nodejs·ctf
诗人不说梦^7 天前
[CISCN2019 总决赛 Day2 Web1]Easyweb
web·ctf
Bruce_Liuxiaowei10 天前
基于BeEF的XSS钓鱼攻击与浏览器劫持实验
前端·网络安全·ctf·xss
小小小CTFER11 天前
NSSCTF每日一题_Web_[SWPUCTF 2022 新生赛]奇妙的MD5
ctf
爱隐身的官人12 天前
Web知识的总结
web安全·ctf
诗人不说梦^13 天前
[SWPUCTF 2018]SimplePHP
web·ctf
Chen--Xing13 天前
宁波市第八届网络安全大赛 -- Crypto -- WriteUp
ctf·crypto·宁波市第八届网络安全大赛
clover_pro13 天前
扩展中国剩余定理脚本(恢复密文c)
学习·ctf