返回列表 发新帖

XSS攻击冷门花样玩法总结| →『网络安全区』

302.3k 6
kjeittccdf 发表于 2015-3-28 01:41:51|湖北 | 查看全部 阅读模式
作者:blackhole
( ^" D8 N2 {5 \" m' h8 [0 {3 }) y+ X9 l3 v) q& F: J3 r
前言什么是冷门,就是很少有人知道,而且不方便利用,危害性有的大,有的小。但对攻击者来说,它有一个“优点”——能让网站管理员不经意之间中招,一个小小的细节,就能完成攻击。本文里总结的攻击方式比较冷门,但危害和影响并不小,值得我们关注。4 e: l  R: z+ L9 X
0×01 Apache||Nginx访问日志的Attack网站管理员有时为了更好的维护网站,会在服务器上开启日志,为了更快一步的发现安全问题,并快速应急。但是Apache、Nginx提供的日志模块,根本不是人看的。就像下面这样:. {9 }$ u( Y* n" G9 p) g

1.png

1.png

+ H5 Y# k9 K) _) r4 A/ g这样的日志,你让管理员怎么快速高效的找到不正常的地方。
0 `; \) M8 [4 g/ N# t6 A于是很多管理员都修改了日志模板,让他成为html格式并且能按照一定的方式排版。排版什么的不用在意,我们只需要在意他是html格式的。当然了有的会直接做个网站,专门来显示日志的,用了后端语言和数据库操作,这些更为高级,攻击起来也颇有难度,但是除了一些特别大的公司,一般不会这么蛋疼式的给日志还做个website。- I3 Y9 R  d  p3 n
前面我说到了很多有安全意识的管理员都会开启日志,如果他是个正常人,应该会把日志按照一定格式排版,我倒是遇到很多这样的。
7 N" U, @) L  n& I' gOK,既然日志是html格式的了,我们就可以开始攻击了。
$ f4 r* F( d9 \! B& o7 ?' Z这里可能就有人要问了,html怎么了,就因为他日志保存的是html格式,你就能拿下服务器了?!
% {0 B1 F8 c. g呃…还是有可能的,这里有个前提“把日志按照html格式输出来的时候,不能有过滤字符串的方法”,但是因为Apache、Nginx的有一个特征,就是在日志输出的时候,很难指定过滤,除非你安装第三方模块。$ `' k; r& X1 C: L' i1 d/ _
下面是Nginx默认的日志模块的规则:4 a4 H# W5 m+ J" q; u8 v' e

11.png

11.png
3 `+ ~8 s5 W  ^# b) R
如果全部默认的话,你就要在/home/wwwlogs/域名.log里用cat慢慢看了,像我这种爱偷懒的人,是不准许这种浪费时间的事情发生的。于是乎,我增加了nginx.conf日志的规则。+ g6 O' e, w" a$ j* G. n

111.png

111.png
5 p. e  c. _: _
然后在vhost/域名.conf下的日志代码修改为:9 ^+ b1 Z/ [  V+ r6 p5 t: k6 u

1111.png

1111.png
6 Z7 H% ]$ j: G- G! K' A+ I6 Q) |
重启nginx,当有人访问的时候,会在/home/wwwlogs/域名.html里生成(关于apache的日志配置,在VirtualHost配置LogFormat参数 ,来修改日志如何显示,再在CustomLog里把输出的格式改下就行了。),下面是打开的内容:
1 s& m6 k0 U! r* j

5.png

5.png
4 D. Q, A: Y+ R
这时漏洞就来了,看过我写的XSS系列的朋友们应该知道IP、UA等是可以伪造的,OK。下面我们就开始进行伪造攻击。
+ r3 M  B# P  v; t  h9 b8 M我这里就拿UA举例吧,maxthon浏览器自带了修改UA的功能(设置-高级-其他)
4 j. l/ z" C& `( r7 _

55.png

55.png

- ~- }$ V$ }; q) P  ~( A7 \! b这个时候,我们再浏览网站。现在我们打开服务器上的日志文件看看吧。! N9 l% B0 U  [: T( s

555.png

555.png

  U% e' f1 ~, r/ H" B+ u成功弹窗,因为我的服务器没有安装图形界面,就把html拖到本地电脑打开了。大伙可以自行脑补日志文件在linux下打开。当然了有的管理员会吧日志放到网站里,方便查看,就像这样:
9 E* X1 B) ?! E. T$ z1 }

6.png

6.png
( J: w1 t; y5 ~$ P* C' e
弹窗了又能证明什么呢?之前黑哥就演示过XSS打内网,我也跟着duang了起来。下面是获取内网IP的js代码(使用WebRTC,因为浏览器限制,想获取真实的外网IP,除chrome、Firefox之外都不行)。" u. ~2 h2 [! y1 A7 G. o. y

66.png

66.png
: D' @/ D1 c) s
如果想获取外网IP,把第12行,改为
  1. servers ={iceServers:[{urls:"stun:stun.services.mozilla.com"}]};
复制代码
就行了。在文章底部会给出代码,大伙可自行下载(打开控制台即可见到IP)。
+ ]+ n6 x6 E& `- t0 p: `OK,有了内网IP就要渗透内网了。这里我给出获取内网IP端口的代码:
4 |6 j9 p& m/ I3 C  Q4 _

666.png

666.png
' X2 n+ `; R/ b3 F) m2 n* D$ c
代码就是在获取内网IP上做了修改(原谅我这几段神代码…经常用jquery,很少用JS)。
; u8 W5 d) s7 d& Q; C再结合XSS平台把42行的代码改下,如果成功,就把ip发送到XSS平台,新建个XSS模块就行了。你也可以同时加上IMG标签,来看对方是用什么解析网站的,代码如下:
* q6 i6 w+ l* H4 g, l
  1. <imgsrc="内网IP/apache_pb&#46;jpg" width="0"onload="xxxx">
复制代码
和上面差不多,遍历就是了。
+ `. D! C$ k: ?6 l5 c配合POC自动拿内网的,大家可以去找找黑哥的PPT。我这POC几乎没有的渣,就不出来丢人了。$ m) m4 C9 k1 b; t. |1 \9 m6 i
关于利用POC的利用方法,大致是这样的:
7 z' ~+ t( U! K( I检测内网有没有使用某个CMS,假设我有dedecms的getshell。使用js来写POC,放在代码里,大体的代码是这样的:" h/ G; S( t* i  S( r

6666.png

6666.png

% R% J. m9 v/ H, Q  ?: G  C) Q8 U这个只能针对图片,如果不考虑跨站。可以使用ajax。
  h2 j9 h, ]; u! J如果不确定网站的标识图片是什么,可以使用iframe标签,src的值为IP:80。
+ N$ ?" K9 Z1 h1 a$ u0 C8 f7 O代码如下:
  1. var iframe=document&#46;createElement("iframe"); var ip_url =ip + "&#46;" + i + ":80";Iframe&#46;setAttribute("src","http://"+ ip_url); //记得把宽高设置为0,在给个ID parent&#46;appendChild(iframe); if(document&#46;getElementById("ID")&#46;document&#46;getElementsByTagName("body")){ //poc代码 }
复制代码
下面是把获取的IP 端口发送到指定网站上的代码:
/ L9 l! o1 y1 j+ S8 F( f  e

8.png

8.png

! }" g9 L" \$ r% I下面是我获取后的:
# B( y6 b/ u2 F9 z% ?1 p

88.png

88.png
$ E8 G* T7 T% l
获取内(外)网IP和端口并发送到指定的网站的代码下载链接: http://pan&#46;baidu&#46;com/s/1ntJudWP+ v1 a! U& a: a3 H" i4 @* J
0×02:插件安全有的黑客在攻击的时候喜欢有目标的攻击,也有的黑客是漫无目的的去攻击,而这一节所说的就是“漫无目的”的攻击,且,把漫无目的的攻击最大化来处理。
; F( }/ j  L6 U; C很多人都会XSS,也有很多人会CSRF。在刚开始玩的时候,很多人都都遵循一个XSS法则:见框就插和见参数就插。当然了玩的熟练之后就加上抓包分析、DOM XSS什么的。不知道你们有没有想过能不能把XSS1 g1 p4 l/ c0 p; k, k9 I; N3 H9 }
<p />的攻击范围变得更广一些呢?这里肯定有人想起了 XSS蠕虫。XSS蠕虫是可以大范围传播,但是如果不是同一个网站呢?这个就比较难了吧,因为这涉及到“跨域”的问题了。但是事实不是绝对的,跨域是很厉害。但是在“浏览器”看来,什么都不是,就像duang的一下加了特技。( o% o# k2 t, @- R6 |( ?
6 d5 G" ^! y! x& L( R
因为浏览器是个非常大的面包,各大公司都想分一杯羹。于是乎360 QQ 搜狗等等互联网巨擘纷纷开始加入了浏览器的队列。
6 G' \: i9 n1 j3 D% Z* D/ n9 h6 {6 y因为浏览器越来越多,厂家们为了拉拢更多的用户,纷纷的推出了“插件”。因为插件的存在,很多小厂家们开始纷纷的写插件(可以打知名度),等于是一箭三雕。8 A/ w/ Q5 [* k3 n" b
但是由于插件的是运行在各个网站里的,就比如“有道翻译”它必须在每个网站上都运行自己的代码,于是浏览器插件开始支持跨域。但是他们忽略了一个问题,插件的跨域不进行认证,导致很多的人都可以写插件,上传插件。其实插件问题已然是个重灾区。因为浏览器们认为不管他们的事。他们认为这属于一个一个愿打一个愿挨。事实却不是这样的。: O* t; f# ?0 ~6 r
下面是我自己写的一个插件,叫“网站自动响应式”,现在已经有38人安装了(其中有360安全部门的人也安装了哟~)围观链接: http://extension&#46;maxthon&#46;cn/detail/index&#46;php?view_id=28024 }: i# A! [  z
我们使用遨游官方提供的MxPacker来压缩解压插件: http://bbs&#46;maxthon&#46;cn/forum&#46;php?mod=viewthread&tid=611580( X) `7 B6 K! Y1 R
解压下来有三个文件Icon(放插件图标的、def&#46;json(主文件、配置、调用的)、base&#46;js(插件的js)2 k, T& y9 F6 }% U( Y
def&#46;son:

888.png

888.png

- a8 d; H* R4 bBase&#46;js:

9.png

9.png
5 C( f$ N! q. E* U' ]1 `8 n
这里感谢“陈星”提供的vps。
1 M2 O4 J; S( H2 {( v9 _咋一看是没啥问题,duoluosb&#46;com/flawless/base&#46;js一开始也是我写的响应式代码,没加其他的。为了方便遨游插件审核。
9 `/ C3 m4 `" f* t; ]: _等上传成功后,我就修改了base&#46;js的代码,在前面加了& \  U) C* k  R- j1 F+ C# y
0 A. T8 j# d2 b) j/ g
                               
登录/注册后可看大图

  k$ H4 W$ @, ^3 y: m获取cookies的,但是后来我看到360的一个朋友也装了这个插件后,我就把第一节说的js内网扫描代码也加了进去。后来被他发现了。本来还想看看360内网是长啥样的呢。。
1 g8 u& g2 z& \3天之后,我登陆xss平台看了一下。已收到5141个cookies了" D, m  ]( O8 S4 d

- Y) t+ K; @& r; g

999.png

999.png

5 O$ ]  @4 v/ Y# o里面包含了支付宝、QQ邮箱、等等的cookies。现在知道插件的问题了吧
1 p9 Z3 j# D9 Z. r当然了,这个需要别人安装才可以,有没有办法不安装就可以呢?答案是可以的。就是入侵别的插件的API。
8 H: [0 r! G4 A0 a% f; a比如有道翻译:' ^$ l9 C( X; `+ q5 o

9999.png

9999.png

% h, w. W% G: D1 I现在已经有了5574个用户安装了,我们入侵它的API接口,然后修改js,就可以达到一样的效果了。具体怎么做呢?难道要一个个安装、拆包、分析么?累死算了。# Y! T, P3 a5 G% I3 ?5 c
下面是个小技巧,教大家如何快速寻找API接口。首先下载
& {8 n+ S# n3 u

0.png

0.png

, W  D) r$ H6 l6 o  O在浏览器左边找到插件,点击插件* F$ H: A* B2 V/ |) T( K

00.png

00.png

0 ?2 d7 R, C* K* x3 R右键审核元素' {+ W2 s# ]! M5 S0 _; @) P

000.png

000.png

3 e) v1 ^" `/ B; p6 ]输入下面的代码:
  1. for(vari=0,tags=document&#46;querySelectorAll('iframe[src],frame[src],script[src],link[rel=stylesheet],object[data],embed[src]'),tag;tag=tags;i++){ var a = document&#46;createElement('a');a&#46;href = tag&#46;src||tag&#46;href||tag&#46;data; if(a&#46;hostname!=location&#46;hostname){console&#46;warn(location&#46;hostname+' 发现第三方资源['+tag&#46;localName+']:'+a&#46;href);}}
复制代码
返回的结果:8 I$ s. o0 Q$ M$ k3 E  a& D$ {' y

0000.png

0000.png

8 Z: [' C/ D; Y+ I+ D. d) J& R5 P- _3 e这个时候我们就可以利用这些网站,来实现入侵,并修改了。0 {$ f1 T* ?5 m0 L) I9 Y
0×03 利用Nginx&Apache环境bug来实现攻击现在很多网站都采用了前端nginx后端apahce这种方式来做网站,nginx对静态资源利用的非常好,apache对php利用的非常的好,当这两者在一起的时候,网站处理事件起来也比较好。这个时候呢,因为nginx&apache环境很多都是在linux下搭建的,没有那么的防火墙供你选择,于是很多根据nginx&apache来开发开源WAF模块。很多的网站也都使用了。
2 b- ^5 s/ s0 N- ?8 i : F7 B% P, w: ?  Q  D6 A* f
但是呢,nginx做反向代理的时候有个缺陷,那就是根据文件的后缀的来判别这个文件是静态资源还是动态资源,假设,当我们访问index&#46;html的时候,nginx根据后缀认为这是一个静态资源,于是就交给自己来处理,当遇上index&#46;php的时候,nginx根据后缀认为这是一个动态资源文件,于是就转发给后端的apache来处理。下面是相关的配置:5 Y7 p" B# n/ {3 C0 J: G, c# T2 ^

7.png

7.png

& e# A: n9 O4 A; ?' ~$ C' ^看的时候是没什么问题,几乎挑不出毛病,但是,当这个缺陷遇上浏览器的时候就会duang的一下,出来一个致命的漏洞。因为浏览器默认会隐藏index&#46;php文件名(并不一定是index&#46;php,要看服务端的配置,有可能是其他的文件,具体的请百度,这里就不再阐述了)9 i; r) M* X! t
假设网站是freebuf&#46;com,我们打开freebuf&#46;com/index&#46;php的时候正常,因为这是一个动态资源文件,nginx交给apache来处理了。
% i; f+ @4 B" {2 a4 R/ g+ P/ y* `+ Z. e但是,如果我们输入freebuf&#46;com,nginx就会认为这是一个静态的资源脚本,并不会交给apahce处理,也就不会触发第三个location。这个时候是nginx来负责解析php的,而nginx对静态资源文件并没有使用waf,这个时候漏洞就出来了,我们可以不带index&#46;php来攻击,比如freebuf&#46;com/?Id=<script>alert(1)</script>就可以来完成攻击。3 g+ r5 V5 h0 e9 V, ?4 V9 \/ w
这只是一个例子,还有一种,那就是在apache上使用apache的waf模块,nginx发现这是个php的时候,就会还给apache,apahce先交给apache的waf,再返回内容。漏洞的出现方式和利用方法和上面一样。

回复|共 6 个

wwzcdenleclv 发表于 2015-7-20 15:36:28|北美地区 | 查看全部
为了不让帖子沉得太快!!!为了人人知道这个~!! 我不是原创~!!但是我要把他发扬广大~!!!
gevaemaidovef 发表于 2015-7-20 15:37:37|美国 | 查看全部
cd:遮~~~~~~
effoggikeftor 发表于 2015-7-20 15:41:42|美国 | 查看全部
因删贴不及时所产生的任何法律(书法,基本法,劳动法,婚姻法,输入法,国际法,今日说法,与台湾关系法及文中涉及或可能涉及以及未及之法,各地治安管理条例)纠纷或责任本人概不负责。
mwxny 发表于 2016-2-19 18:41:24|美国 | 查看全部
楼猪.重量级人物阿.
wwzcdenleclv 发表于 2016-2-19 18:42:37|英国 | 查看全部
照你这么说真的有道理哦 呵呵 不进沙子馁~~~
effoggikeftor 发表于 2016-2-19 18:43:03|北美地区 | 查看全部
我只是为了十万积分默默奋斗。

回复

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

本版积分规则

得知互动是一个融创意、设计、开发、营销、生活、互联网于一体的专业交流分享平台。
Copyright © 2026 站长技术交流论坛|互联网技术交流平台 版权所有 All Rights Reserved. Powered by Discuz! X5.0 鄂ICP备15006301号-5|鄂公网安备 42018502006730号
关灯 在本版发帖 扫一扫添加QQ客服 返回顶部
快速回复 返回顶部 返回列表