找回密码
 立即注册
欢迎中测联盟老会员回家,1997年注册的域名
查看: 2092|回复: 0
打印 上一主题 下一主题

Treetextbox编辑器遍历目录+上传漏洞

[复制链接]
跳转到指定楼层
楼主
发表于 2013-1-18 18:22:31 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
  漏洞文件:ftb.imagegallery.aspx
; @' e& X; o, b  L! I8 C+ I% x3 O0 n
漏洞一:目录遍历* \5 A# Y" m$ |; ^8 s: V4 X2 X
ftb.imagegallery.aspx?frame=1&rif=images&cif=../1 P. y5 S% e6 J& n
不可以,过滤了/
. S* l* o0 g, I$ h, m  `ftb.imagegallery.aspx?frame=1&rif=images&cif=..\
* M' N' O3 `/ j4 [3 x9 N可以!!过滤\符号 嘿嘿,能干什么自己知道了呗。
' S9 h% q5 f; T8 xftb.imagegallery.aspx?frame=1&rif=images&cif=..\..' n+ x2 G# ?9 ?. _# D5 @
漏洞二:上传漏洞
/ Z1 Q4 [0 d' k* }. C" f没做登陆验证可以直接访问上传木马 FTBv3-3-1 可以直接上传任意格式的文件 Freetextbox 1.6.3 及其他版本可以上传 格式为 1.asp;.jpg 文件 上传后木马地址为http://网站地址/images/1.asp;.jpg
: {# ^2 x8 ~0 [; T* l7 s; n+ G
, m" g3 r; E% g8 p! h 1 A" i, f+ J4 N7 G
漏洞修补方案:
) I" a" N2 {9 {7 c! G0 _( L
, c; v1 ?% ^3 E( N添加代码加登陆验证
: `# _* g2 k" L* A. k; F: }2 vprivate void Page_Load(object sender, System.EventArgs e) {    string isframe = “” + Request["frame"];   Freetextbox上传图片是直接保留原文件名的,这个地方做个修改,上传文件使用时间串做文件名。* E* t8 j) K# y) g# m
- G7 U" R0 O4 ]9 |% Y' z
修改方式如下:; `, i+ p2 l+ \, Z+ N' L5 o
% Z# ~1 ]) ]1 g, t0 E" c/ G
找到 程序代码 ! R  |) ~2 F  s8 E6 T8 i% A
UploadFileNameUploadFileName = UploadFileName.Substring(UploadFileName.LastIndexOf(“\\”)+1);    在其下面添加以下代码
- V4 J" u$ j- F9 S8 I0 o//********************* UploadFileName = DateTime.Now.ToString() + UploadFileName.Remove(0, UploadFileName.LastIndexOf(“.”)); UploadFileName = UploadFileName.Replace(“:”, “”).Replace(“-”, “”).Replace(” “, “”); //by Yation.Team 2009/7/17 上传文件用时间重命名. O5 P8 Z4 X% o- X% K. P% ~: r$ g
以前已经有人公布过fb暴路径的方法 http*****.cn/helps/ftb.imagegallery.aspx?frame=1”在地址后面加上&rif=..&cif=..在访问 整个网站的目录就呈现在眼前了,下面还有上传删除等按钮… 修正方式如下: 找到 程序代码 if (cif != “” && rif != “”) {
2 j3 ?8 R/ S2 j' j! c* Q- {- g把RootImagesFolder.Value = rif;! h# F2 c: J% q+ w8 J" d* A! G& F
3 D& C5 A) [4 i; Y
替换成
. L7 {+ @% b2 I; V5 S* W程序代码 //***************************** RootImagesFolder.Value = DefaultImageFolder; Array srtArray = cif.Split(‘\\’); string str = srtArray.GetValue(0).ToString(); if (str != DefaultImageFolder) { cif = DefaultImageFolder; } cif = cif.Replace(“..\\”, “”).Replace(“../”,”");" c* v6 o* D1 S/ N0 Z- W: a3 Y
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表