热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

PYTHON实现DISCUZ论坛的自动POST登录发贴回帖

#-*-coding:utf-8-*-importurllib2,urllib,cookielibimportreimportgetpassimportsqlite3impor

class="wp_codebox">



id="p107code2" class="code">

#-*-coding:utf-8-*-
import urllib2, urllib, COOKIElib
import re
import getpass
import sqlite3
import random
import time
 
class Discuz:
def __init__(self,user,pwd,args):
self.username = user
self.password = pwd
self.args = args
self.regex = {
‘loginreg‘:‘‘,
‘replyreg‘:‘‘,
‘tidreg‘: ‘[\s\S]+?‘
}
self.conn = None
self.cur = None
self.islogin = False
self.login()
self.InitDB()
 
def login(self):
try:
loginPage = urllib2.urlopen(self.args[‘loginurl‘]).read()
formhash = re.search(self.regex[‘loginreg‘], loginPage)
formhash = formhash.group(1)
#print ‘login formhash:‘, formhash
print ‘start login...‘
cj = COOKIElib.COOKIEJar()
opener = urllib2.build_opener(urllib2.HTTPCOOKIEProcessor(cj))
user_agent = ‘Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; Mozilla/4.0 \
(compatible; MSIE 6.0; Windows NT 5.1; SV1) ; .NET CLR 2.0.507‘

opener.addheaders = [(‘User-agent‘, user_agent)]
urllib2.install_opener(opener)
logindata = urllib.urlencode({
‘COOKIEtime‘: 2592000,
‘formhash‘: formhash,
‘loginfield‘:‘username‘,
‘username‘: self.username,
‘password‘: self.password,
‘questionid‘: 0,
‘referer‘: self.args[‘referer‘]
})
request = urllib2.Request(self.args[‘loginsubmiturl‘],logindata)
respOnse= urllib2.urlopen(request)
self.islogin = True
print ‘login success...‘
except Exception,e:
print ‘loggin error: %s‘ % e
 
def PostReply(self, fid, tid, content):
try:
sql = "select * from post where fid=‘%s‘ and tid=‘%s‘" % (fid,tid)
self.cur.execute(sql)
if self.cur.rowcount == -1:
tidurl = self.args[‘tidurl‘] % tid
replysubmiturl = self.args[‘replysubmiturl‘] % (fid,tid)
tidPage = urllib2.urlopen(tidurl).read()
formhash = re.search(self.regex[‘replyreg‘], tidPage)
formhash = formhash.group(1)
#print ‘reply formhash:‘, formhash
print ‘start reply...‘
replydata = urllib.urlencode({
‘formhash‘: formhash,
‘message‘: content,
‘subject‘: ‘‘,
‘usesig‘:‘1‘
})
request = urllib2.Request(replysubmiturl,replydata)
respOnse= urllib2.urlopen(request)
sql = "insert into post values (‘%s‘, ‘%s‘, ‘%d‘)" % (fid, tid, 1)
self.cur.execute(sql)
self.conn.commit()
print ‘reply success for [%s]‘ % tidurl
else:
print ‘Skip! Thread:%s is already replied...‘ % tid
except Exception, e:
print ‘reply error: %s‘ % e
 
def GetTids(self, fid):
if self.islogin:
fidurl = self.args[‘fidurl‘] % fid
respOnse= urllib2.urlopen(fidurl)
cOntent= response.read()
tids = re.findall(self.regex[‘tidreg‘], content)
return tids
else:
print ‘Error Please Login...‘
 
def InitDB(self):
self.conn = sqlite3.connect(‘data.db‘)
self.cur = self.conn.cursor()
sql = ‘‘‘create table if not exists post (
fid text,
tid text,
replied integer)‘‘‘

self.cur.execute(sql)
self.conn.commit()
 
if __name__ == ‘__main__‘:
username = raw_input(‘username:‘).strip()
password = getpass.getpass(‘password:‘).strip()
args = {
‘loginurl‘: ‘http://www.xxx.com/logging.php?action=login‘,
‘loginsubmiturl‘: ‘http://www.xxx.com/logging.php?action=login&loginsubmit=yes‘,
‘fidurl‘: ‘http://www.xxx.com/forum-%s-1.html‘,
‘tidurl‘: ‘http://www.xxx.com/thread-%s-1-1.html‘,
‘replysubmiturl‘: ‘http://www.xxx.com/post.php?action=reply&replysubmit=yes&infloat=yes&handlekey=fastpost&fid=%s&tid=%s‘,
‘referer‘:‘http://www.xxx.com/index.php‘
}
dz = Discuz(username, password,args)
fid = ‘45‘
tids = dz.GetTids(‘45‘)
replylist = [
u‘不错,支持一下,呵呵‘,
u‘已阅,顶一下‘,
u‘看看,顶你,呵呵‘,
u‘多谢分享,顶一下‘,
u‘说的不错,支持一下‘,
u‘提着水桶到处转,哪里缺水哪里灌! ‘,
u‘你太油菜了!‘
]
for tid in tids:
cOntent= random.choice(replylist)
cOntent= content.encode(‘gbk‘)
dz.PostReply(‘45‘,tid, content)
time.sleep(20)


-

下面简单说下过程:

首先是得到了login的post地址:http://www.xxx.com/logging.php?action=login&loginsubmit=yes
>几个关键的parameter是


formhash
> COOKIEtime

formhash
loginfield

password
questionid

referer
username




  • COOKIEtime 浏览器自?

PYTHON实现DISCUZ论坛的自动POST登录发贴回帖,布布扣,bubuko.com


推荐阅读
  • packagecom.panchan.tsmese.utils;importjava.lang.reflect.ParameterizedType;importjava.lang. ... [详细]
  • Python多线程详解与示例
    本文介绍了Python中的多线程编程,包括僵尸进程和孤儿进程的概念,并提供了具体的代码示例。同时,详细解释了0号进程和1号进程在系统中的作用。 ... [详细]
  • 本文介绍了一种支付平台异步风控系统的架构模型,旨在为开发类似系统的工程师提供参考。 ... [详细]
  • 解决SQL Server数据库sa登录名无法连接的问题
    在安装SQL Server数据库后,使用Windows身份验证成功,但使用SQL Server身份验证时遇到问题。本文将介绍如何通过设置sa登录名的密码、启用登录名状态以及开启TCP协议来解决这一问题。 ... [详细]
  • 本文详细介绍如何在忘记MySQL服务器密码的情况下进行密码重置,包括具体的步骤和注意事项。 ... [详细]
  • 蒜头君的倒水问题(矩阵快速幂优化)
    蒜头君将两杯热水分别倒入两个杯子中,每杯水的初始量分别为a毫升和b毫升。为了使水冷却,蒜头君采用了一种特殊的方式,即每次将第一杯中的x%的水倒入第二杯,同时将第二杯中的y%的水倒入第一杯。这种操作会重复进行k次,最终求出两杯水中各自的水量。 ... [详细]
  • 经过一年的思考,我发现自己对开发的兴趣并不浓厚,而对算法研究则更加热衷。本文将探讨开发与算法之间的本质差异,并分享我的未来学习计划。 ... [详细]
  • 小程序的授权和登陆
    小程序的授权和登陆 ... [详细]
  • Bootstrap 缩略图展示示例
    本文将展示如何使用 Bootstrap 实现缩略图效果,并提供详细的代码示例。 ... [详细]
  • 使用 Git Rebase -i 合并多个提交
    在开发过程中,频繁的小改动往往会生成多个提交记录。为了保持代码仓库的整洁,我们可以使用 git rebase -i 命令将多个提交合并成一个。 ... [详细]
  • Manacher算法详解:寻找最长回文子串
    本文将详细介绍Manacher算法,该算法用于高效地找到字符串中的最长回文子串。通过在字符间插入特殊符号,Manacher算法能够同时处理奇数和偶数长度的回文子串问题。 ... [详细]
  • malloc 是 C 语言中的一个标准库函数,全称为 memory allocation,即动态内存分配。它用于在程序运行时申请一块指定大小的连续内存区域,并返回该区域的起始地址。当无法预先确定内存的具体位置时,可以通过 malloc 动态分配内存。 ... [详细]
  • 本文介绍了多种开源数据库及其核心数据结构和算法,包括MySQL的B+树、MVCC和WAL,MongoDB的tokuDB和cola,boltDB的追加仅树和mmap,levelDB的LSM树,以及内存缓存中的一致性哈希。 ... [详细]
  • 包含phppdoerrorcode的词条 ... [详细]
  • 本文详细介绍了Linux系统中用于管理IPC(Inter-Process Communication)资源的两个重要命令:ipcs和ipcrm。通过这些命令,用户可以查看和删除系统中的消息队列、共享内存和信号量。 ... [详细]
author-avatar
张哥他爹
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有