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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2013-1-18 18:22:31 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
  漏洞文件:ftb.imagegallery.aspx
2 @$ x5 W5 F7 ]7 u1 e( Z+ [" U* g9 E- C1 J
漏洞一:目录遍历4 Z; i% A3 l  b* U7 S7 C
ftb.imagegallery.aspx?frame=1&rif=images&cif=../
- E5 X$ g( ]9 K: v. N: H不可以,过滤了/" X8 d9 t' Y! R0 v* c! n, m6 d
ftb.imagegallery.aspx?frame=1&rif=images&cif=..\
, i" y" ^- \$ b& B& |" t) z& z可以!!过滤\符号 嘿嘿,能干什么自己知道了呗。
7 t/ T* k3 f9 X* _$ c# B* G3 dftb.imagegallery.aspx?frame=1&rif=images&cif=..\..0 N/ |6 Z- ~- f: g
漏洞二:上传漏洞
3 j# S) d/ q: R% G6 b没做登陆验证可以直接访问上传木马 FTBv3-3-1 可以直接上传任意格式的文件 Freetextbox 1.6.3 及其他版本可以上传 格式为 1.asp;.jpg 文件 上传后木马地址为http://网站地址/images/1.asp;.jpg  m7 B  Z6 j$ i' I/ D; B

2 W  B6 V+ ^! `0 N7 g# Z1 Z
1 p; D7 B8 ~) Q. Y9 f漏洞修补方案:+ F9 w: B( Q7 Z; Q2 a9 S1 p

1 a, I  s4 {# }$ b& m+ L添加代码加登陆验证( n) V+ ~  G! r2 v
private void Page_Load(object sender, System.EventArgs e) {    string isframe = “” + Request["frame"];   Freetextbox上传图片是直接保留原文件名的,这个地方做个修改,上传文件使用时间串做文件名。
+ ?7 w4 w7 J1 @) h: S# H6 J+ E; E5 N. I/ h% v+ M/ Q& m  P) U
修改方式如下:, H  c: b) ~5 r

0 h5 D8 A' [/ l" ]找到 程序代码
! f8 Z% [5 S) `. \2 D( QUploadFileNameUploadFileName = UploadFileName.Substring(UploadFileName.LastIndexOf(“\\”)+1);    在其下面添加以下代码
* [/ m" K! Z7 d  m* j2 x//********************* UploadFileName = DateTime.Now.ToString() + UploadFileName.Remove(0, UploadFileName.LastIndexOf(“.”)); UploadFileName = UploadFileName.Replace(“:”, “”).Replace(“-”, “”).Replace(” “, “”); //by Yation.Team 2009/7/17 上传文件用时间重命名$ T4 m( {0 K, W) C( X% }5 v9 P
以前已经有人公布过fb暴路径的方法 http*****.cn/helps/ftb.imagegallery.aspx?frame=1”在地址后面加上&rif=..&cif=..在访问 整个网站的目录就呈现在眼前了,下面还有上传删除等按钮… 修正方式如下: 找到 程序代码 if (cif != “” && rif != “”) {0 L4 s! Y: b/ }* I2 N0 H8 |
把RootImagesFolder.Value = rif;
  e, `5 Z9 r! A0 z; |  m/ Y2 T8 V4 H& ?& d( L7 ]' {. h0 Q) H
替换成! Y+ \$ b3 x+ [" r; ^2 X* Q
程序代码 //***************************** RootImagesFolder.Value = DefaultImageFolder; Array srtArray = cif.Split(‘\\’); string str = srtArray.GetValue(0).ToString(); if (str != DefaultImageFolder) { cif = DefaultImageFolder; } cif = cif.Replace(“..\\”, “”).Replace(“../”,”");
/ b( B7 L# d) K. i/ e. i+ ]7 U# ]
回复

使用道具 举报

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

本版积分规则

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