漏洞发生在插附件的地方。说到插附件各位看官也应该都想到了肯定是文件名。因为文件名是按照本地上传的文件名来显示的。% E0 ^$ ~, e. L' i$ K4 N
如果你的操作系统是linux你可以直接修改一个图片文件的文件名,像这样:7 W+ W3 R" l* _1 Z+ v- [1 M( L/ J9 b6 @
4 G$ y D6 J4 [( T1 o
1, X9 m/ [' O2 `6 H$ C6 X& C
<img src=javascript/alert(1);>.png
4 L# S5 K. r @- m$ ]$ e(这里的/在linux下会被转换成: 这个payload只有在IE6下才能弹起来,我知道你们都是高手 可以根据需要 插点高级的payload)1 D9 s" d* H+ a+ G: S
如果你的操作系统是windows,你可以上你喜欢的抓包工具(我个人喜欢用Tamper data)。第一次上传应该是抓不到文件名的,至少我没有抓到。
, |! m. e/ u" R% @所以你需要在上传,插入,发帖完成之后重新编辑你的帖子来更新你的图片,这个时候抓包是可以抓到这个可爱的filename的。
7 U6 z8 r- Z3 N- Y0 i修改xxx.png为: s: D8 V0 o% P9 L1 i9 T' E+ e
/ B1 U5 [0 a( k6 j& @2 L* M1
; y. P) |, r7 t; a* X2 W4 _& V3 q<img src=javascript:alert(1);>.png
* R$ o; V. l2 _* X | |提交。
" \7 W2 A. {* u! J. Uxss会被触发在第二个页面,也就是点击图片放大之后触发。! Q, k9 F/ y M! q7 s8 K- S: f
pwned!
1 I$ k1 A1 T& @$ i; \$ R , |3 v6 H0 g& S. _3 k E/ N' ~
字符长度限制在80左右,过滤了” ’ / etc..(斜杠的问题我会在后面继续叙述)
7 n" e7 i" @/ e2 e3 x# V因为不懂XSS,就拿给自己玩的好的几位基友去构造payload都说斜杠过滤了,字符限制云云 基本上都失败了。
# y; D8 z% m8 ?! u虽然现在XSS很火,但我个人真的不是很喜欢这个东西。# f2 I1 X4 ?- o( \
但基友居然都说不行就只好自己硬着头皮再试试了。6 j# m D0 T- X; {( A
在尝试中发现反斜杠也被过滤时,我才发现这不是一个xss filter的问题。
) ]+ m6 K! R# R! Q2 t而是上传过程中,我们可爱的/和反斜杠在这里应该起到分割filename和filepath的作用 所以被杀也是应该的。 Orz..3 @+ h# K4 ]5 X
这貌似就是传说中的mission impossible了。
, V3 q* ?- F: `( d2 Q我们需要解决这个斜杠的问题。经过各种尝试最后迂回到了附件描述的地方。很没有把握地插了一个XSS payload.像这样:
# F' L2 J6 w, b8 s' I% H1
" y' c8 ]/ i" _<img src=x onerror=alert(document.cookie)>.png4 i' G: q) g9 k" i1 K+ H" O: N
原来的文件名被这个描述给覆盖掉了。, E) {& F. Y3 Q$ _+ @
pwned! C* @7 d( T6 V2 u# j* ?$ X
' U2 d0 H4 w0 @3 U9 [# h* G而且已经可以带上我们的斜杠了(因为它已经不再是前面的那种情况了)
% [9 }2 \& k5 V0 }6 ]& H3 q: n到这儿,我觉得应该已经没有任何的阻碍了。& C2 l/ B; S5 B# K8 | Y
可能经过测试,会有人说payload会在主页面测漏,有HTTPonly cookie,属于被动触发云云。3 I+ M% ]# M$ L2 N7 N
whatever!5 n, m5 Y9 @/ e- L
我觉得这些已经不应该是该去研究的问题了。* U: ~* k( @* d! ]& I. F
因为没有哪个网站和你有这么大的恨。
* K1 w, E8 y# f6 B解决方案:( j1 a, B# _6 O4 T# `, A- Q& j
全局-上传设置-论坛附件-帖子中显示图片附件-否! Q, m+ Q. Q, R4 @3 T4 G8 _
这样,就搞定了。; R/ L: F) }( ]. I3 a, g& |
|