博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
svn源码泄露漏洞
阅读量:6403 次
发布时间:2019-06-23

本文共 1471 字,大约阅读时间需要 4 分钟。

在服务器上布署代码时。如果是使用 svn checkout 功能来更新代码,而没有配置好目录访问权限,则会存在此漏洞。黑客利用此漏洞,可以下载整套网站的源代码。

一、.svn 目录

使用svn checkout后,项目目录下会生成隐藏的.svn文件夹(Linux上用ls命令看不到,要用ls -al命令)。

svn1.6及以前版本会在项目的每个文件夹下都生成一个.svn文件夹,里面包含了所有文件的备份,文件名为  .svn/text-base/文件名.svn-base 

svn1.7及以后版本则只在项目根目录生成一个.svn文件夹,里面的pristine文件夹里包含了整个项目的所有文件备份

下面我以svn1.7及之后版本为例,讲解如何利用此漏洞下载整个网站源代码

二、分析.svn目录内容

我们看到的是一个名为 wc.db 的文件,用文本编辑器打开看到第一行有写  SQLite format 3  ,可以知道,这是一个SQLite数据库的文件,后面包含的信息,文本编辑器就先不看了。我们下载一个正经的SQLite查看软件来慢慢看-- 。

在软件下载完之前,再看看此文件夹里的其他内容:

entries和format文件里面,只有个数字12,没什么参考意义;wc.db-journal文件是空的,也没什么价值;tmp目录里面也是空的;

pristine里面内容就多了,一堆00~ff的文件夹,每个文件夹里有若干个 .svn-base文件;用文本编辑器打开看一下,有些文件是代码,有些文件是乱码(大概是图片文件吧)。看来这个文件夹是整个项目文件的一份备份,只是一堆哈希过的文件名,似乎有点难下手啊。

毕竟是无规律的这一堆文件名,40位的哈希(36^40)这样的暴力穷举下载的话,即便是N多线程,时间成本上也是非常大的啊。而且得到是一堆无序文件,要整理成原来代码项目的样子,还得费好一阵功夫。

这样看来,是不是说.svn漏洞利用的价值很少?然而非也,少年,还记得刚才说的 wc.db 文件吗。现在SQLite Studio软件应该下载好了,我们就打开看看这里有什么来头吧

三、wc.db文件,有你想要的一切

用SQLiteStudio软件打开 wc.db文件,我们看到 NODES 表,看到 local relpath栏 和 checksum栏,明白了吗(滑稽.jpg)。checksum栏里的$sha1$后面的那串数字就是pristine文件夹里的那堆文件的文件名,pristine里的00~ff文件夹,其实是文件名的前两位,而local relpath就是原始的文件名。

现在,我们根据这个 wc.db 的NODES表,遍历这个表里的每一行,就可以下载到整个项目里的代码了,而且还能得到对应的真实文件名,可谓岂不快哉?

(下面截图为我自己的项目,仅作参考)

除了NODES表以外,还可以看到一个 REPOSITORY表,里面存储了svn的项目路径和 uuid,如果没有做访问IP限制的话,你可以直接使用此信息取得此项目的SVN权限(下载、提交等)…

四、漏洞修复

方案一、不要使用svn checkout和svn up更新服务器上的代码,使用svn export(导出)功能代替。

方案二、服务器软件(Nginx、apache、tomcat、IIS等)设置目录权限,禁止访问.svn目录

不只svn,git或者其他版本管理软件也存在类似的问题

 

转载于:https://www.cnblogs.com/batsing/p/svn-bug.html

你可能感兴趣的文章
孩子初三上半学期期中考试情况
查看>>
可配置语法分析器开发纪事(二)——构造符号表
查看>>
[资料]PHP中的Classes/Objects Function
查看>>
Mono 3 的默认Gc是Sgen
查看>>
IEnumerable的谨慎使用和IQueryable 的延迟执行
查看>>
业务架构师的服务(靠什么赚钱),从事这一职业需要什么知识?
查看>>
Async Java HTTP client
查看>>
android 关闭app简要说明
查看>>
hibernate validator自定义校验注解以及基于服务(服务组)的校验
查看>>
Leetcode_num2_Maximum Depth of Binary Tree
查看>>
Android笔记二十四.Android基于回调的事件处理机制
查看>>
jquery checkbox勾选/取消勾选只能操作一次的诡异问题
查看>>
友盟统计小白教程:创建应用,申请appkey
查看>>
Multi-Tenancy模式,基础服务大规模扩张的时候,是应该推进了。
查看>>
var result = eval('(' + data + ')');的学习
查看>>
【sqli-labs】Less7
查看>>
文件操作之循环
查看>>
【Java学习笔记之二十】final关键字在Java继承中的用法小结
查看>>
Apache-kylin-2.0.0-bin-hbase1x.tar.gz的下载与安装(图文详解)
查看>>
String literal is not properly closed by a double-quote eclipse
查看>>