事情起因:由于玩人人上的某个游戏的时候,与某人起了一点冲突,当时为了泄愤,打算写个程序,如果能每隔5min在游戏的小组内发个帖子就好了,于是就有了这个程序。
天助我也:一般的贴吧,发帖的时候需要输入验证码,暂时没有合理的解决办法,程序识别验证码代价太高,想法就是把验证码图片存到本地,然后人工识别输入,这就不免大大降低了程序速度,增加人工成本。
还有的贴吧做了每次不能连续发三个帖子的设置,这个要是想实现的话,就开两个程序,用两个号互相刷帖。
好消息是以上两个验证,人人小组都没有,所以免去不少工作,感谢人人小组开发人员,是你们的疏忽让我有机可乘(注:机,此处指非马航飞机,默哀)。
情景还原:
要想实现这个功能,总共分为以下几步:
1. 需要输入账号和密码进行登录操作,获得Cookie和三个重要的参数,为后续的发帖做准备。
def login(self):
print '开始登录'
url='http://www.renren.com/PLogin.do'
postdata={
'email':self.email,
'password':self.password,
'domain':self.domain
}
req=urllib2.Request(
url,
urllib.urlencode(postdata)
)
self.file=urllib2.urlopen(req).read()
#print self.file
idPos = self.file.index("'id':'")
self.id=self.file[idPos+6:idPos+15]
tokPos=self.file.index("get_check:'")
self.tok=self.file[tokPos+11:tokPos+21]
rtkPos=self.file.index("get_check_x:'")
self.rtk=self.file[rtkPos+13:rtkPos+21]
2. 需要分析小组发帖中点击提交按钮后进行的POST操作,看看他都传了什么参数,根据他的参数模拟HTTP请求。
因为现在不是小组成员了,所以也就截不了图了,主要使用浏览器的F12功能中的网络抓包功能,点击提交按钮后有个叫什么Status的包,然后看发送的详情就行了,标题和内容都在里面。
3. 程序模拟HTTP请求进行发帖,这个操作需要小组的成员权限
def publish(self,title,content):
url1='http://xiaozu.renren.com/xiaozu/620005025/ajaxCreateThread'
postdata={
'subject':title.decode('gb2312','ignore').encode('utf-8'),
'optionContent':'',
'optionContent':'',
'optionContent':'',
'optionContent':'',
'optionContent':'',
'voteinvite':'1',
'body':'<p>'+content.decode('gb2312','ignore').encode('utf-8')+'</p>',
'feedKind':'',
'feedSrc':'',
'requestToken':self.tok,
'_rtk':self.rtk,
'requestToken':self.tok,
'_rtk':self.rtk,
}
req1=urllib2.Request(
url1,
urllib.urlencode(postdata)
)
req1.add_header('Referer', 'http://xiaozu.renren.com/xiaozu/620005025/createthread')
self.file1=urllib2.urlopen(req1).read()
print '%s:\n刚才使用你的人人账号 %s 发了一条帖子\n内容为:(%s)'% (datetime.datetime.now(),self.email,postdata.get('content',''))
time.sleep(300)
最终结果:当然GM不会任贴吧这么水贴泛滥,随后双双封号处理了。
后期进展:目前在研究其他解决办法,去其他贴吧?或者让帐号获取到小组权限之类的,努力中。