wb 黑名单批量操作
0. 参考
yu961549745/WeiboBlackList 微博批量拉黑
1. 代码 block.py
更新内容:多线程,urllib.request 改为 requests + session
改成从 firefox 或 chrome 读取 cookie 更方便,懒得改了
#!/usr/bin/env python
# -*- coding: UTF-8 -* import requests
from requests.exceptions import (ConnectionError, ConnectTimeout, ReadTimeout, SSLError,
ProxyError, RetryError, InvalidSchema)
import threading
import Queue
import traceback import logging
def get_logger():
logger = logging.getLogger("threading_example")
logger.setLevel(logging.DEBUG) # fh = logging.FileHandler("d:/threading.log")
fh = logging.StreamHandler()
fmt = '%(asctime)s - %(threadName)-10s - %(levelname)s - %(message)s'
formatter = logging.Formatter(fmt)
fh.setFormatter(formatter) logger.addHandler(fh)
return logger logger = get_logger() def block():
while True:
try:
uid = task_queue.get()
data = dict(payload) #dict
data.update({'uid': uid})
resp = s.post(url, data=data)
except (ConnectionError, ConnectTimeout, ReadTimeout, SSLError,
ProxyError, RetryError, InvalidSchema) as err:
task_queue.task_done() ############### 重新 put 之前需要 task_done ,才能保证释放 task_queue.join()
task_queue.put(uid)
except Exception as err:
logger.debug(u'\nuid: {}\nerr: {}\ntraceback: {}'.format(uid, err, traceback.format_exc()))
task_queue.task_done() ############### 重新 put 之前需要 task_done ,才能保证释放 task_queue.join()
task_queue.put(uid)
else:
try:
code = resp.json()['code']
if code != '':
logger.debug(u'uid: {} code: {}'.format(uid, code))
else:
logger.debug(u'uid: {}'.format(uid))
except Exception as err:
logger.debug(u'\nuid: {}\nresp: {}\nerr: {}\ntraceback: {}'.format(uid, resp.text, err, traceback.format_exc()))
finally:
task_queue.task_done() if __name__ == '__main__': # lines: request in raw format captured from Fiddler
'''
['POST http://weibo.com/aj/filter/block?ajwvr=6 HTTP/1.1',
'Host: weibo.com',
'User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:56.0) Gecko/20100101 Firefox/56.0',
'Accept: */*',
'Accept-Language: zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3',
'Accept-Encoding: gzip, deflate',
'Content-Type: application/x-www-form-urlencoded',
'X-Requested-With: XMLHttpRequest',
'Referer: http://weibo.com/u/5471246591?is_hot=1',
'Content-Length: 57',
'Cookie: your cookie###########################################',
'Connection: keep-alive',
'',
'uid=5471246591&filter_type=1&status=1&interact=1&follow=1']
''' # 移除黑名单:
# In [317]: url2='http://weibo.com/aj/f/delblack?ajwvr=6'
# In [318]: resp = s.post(url2, data={'uid':'5209943797'}) # In [320]: resp.json()
# Out[320]: {u'code': u'100000', u'data': {}, u'msg': u''} with open('uids.txt') as f:
uids = [uid.strip() for uid in f.readlines()] with open('headers.txt') as f:
lines = [i.strip() for i in f.readlines()] url = lines[0].split()[1] headers = {}
for line in lines[2:-2]:
k, v = line.split(': ',1) #:space
headers[k] = v data=lines[-1]
# datas = [re.sub(r'uid=\d+','uid=%s'%uid ,data) for uid in uids]
payload = dict([i.split('=',1) for i in data.split('&')])
# payloads = [payload.update({'uid': uid}) for uid in uids]
# payloads = []
# for uid in uids:
# payload.update({'uid': uid})
# payloads.append(dict(payload)) ### dict # for payload in payloads:
# r = requests.post(url, headers=headers, data=payload)
# r.text
# {"code":"100000","msg":"\u96b1\u85cf\u6210\u529f","data":{}}
# In [287]: r.json()['code']
# Out[287]: u'100000' s = requests.Session()
s.headers = headers
s.mount('http://', requests.adapters.HTTPAdapter(pool_connections=1000, pool_maxsize=1000)) task_queue = Queue.Queue()
for uid in uids:
task_queue.put(uid) threads = []
for i in range(100):
t = threading.Thread(target=block) #args接收元组,至少(a,)
threads.append(t) for t in threads:
t.setDaemon(True)
t.start() task_queue.join()
print 'task done'
wb 黑名单批量操作的更多相关文章
- 【Hibernate框架】批量操作Batch总结
在我们做.net系统的时候,所做的最常见的批量操作就是批量导入.插入.更新.删除等等,以前我们怎么做呢?基本上有以下几种方式: 1.利用循环调用insert方法,一条条插入. public boole ...
- 基于黑名单的xss过滤器
/** * 类名称:AntiXssFilter * @version * 类描述:基于黑名单的xss过滤器 * @version * 创建人:xxx * @version * 创建时间:2015年11 ...
- druid sql黑名单 报异常 sql injection violation, part alway true condition not allow
最近使用druid,发现阿里这个连接池 真的很好用,可以监控到连接池活跃连接数 开辟到多少个连接数 关闭了多少个,对于我在项目中查看错误 问题,很有帮助, 但是最近发现里面 有条sql语句 被拦截了, ...
- Android课程---添加黑名单的练习2(课堂讲解)
实现黑名单的添加.修改.查询和删除,首先得有封装的3个类,便于使用 BlackNumber.java package com.hanqi.test3; /** * Created by Adminis ...
- Android课程---添加黑名单的练习(课堂讲解)
DBHelper.java package com.hanqi.test3; import android.content.Context; import android.database.sqlit ...
- Python文件使用“wb”方式打开,写入内容
Python文件使用"wb"方式打开,写入字符串会报错,因为这种打开方式为:以二进制格式打开一个文件只用于写入.如果该文件已存在则将其覆盖.如果该文件不存在,创建新文件. 所以写入 ...
- 转网页WB.ExecWB控件打印方法
网页WB.ExecWB控件打印方法 2010-02-01 12:48 代码: <table width="100%" cellpadding="1" on ...
- document.all.wb.ExecWB
<%@ page language="java" pageEncoding="UTF-8"%> <%@ taglib uri=&quo ...
- [WebServer] Tomcat 配置访问限制:访问白名单和访问黑名单
前言: 昨天配置了 Tomcat 服务器运行 PHP 的环境,但是通过观察 Tomcat 这几天的日志发现,有很多莫名其妙的 IP 访问主机下莫名其妙的地址,如:/80./testproxy.php. ...
随机推荐
- Winform调用百度地图接口简单示例
1.首先用一个html文件调用百度地图接口(主要注册一个序列号): <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitiona ...
- python获取windows信息
转载自http://www.blog.pythonlibrary.org/2010/02/06/more-windows-system-information-with-python/ How to ...
- html5 - drag 拖拽
参考资料: 张鑫旭 : http://www.zhangxinxu.com/wordpress/2011/02/html5-drag-drop-%E6%8B%96%E6%8B% ...
- 通过python操作GeoLite2-City.mmdb库将nginx日志访问IP转换为城市写入数据库
通过python操作GeoLite2-City.mmdb库将nginx日志写入数据库 # 创建存放nginx日志的表accesslog2 CREATE TABLE `accesslog2` ( `id ...
- Centos、Ubuntu开启命令模式
由于安装的虚拟机本来就比较卡,开机加载图形界面,会变的更卡,使用下面的命令可将图形界面关闭. centos: 开机以命令模式启动,执行: systemctl set-default multi-use ...
- Redis高级特性介绍及实例分析
转自:http://www.jianshu.com/p/af7043e6c8f9 Redis基础类型回顾 String Redis中最基本,也是最简单的数据类型.注意,VALUE既可以是简单的St ...
- python第13天
装饰器 装饰器本质上就是一个python函数,他可以让其他函数在不需要做任何改动的前提下,增加额外的功能,装饰器的返回值也是一个函数对象. 装饰器的应用场景:比如插入日志,性能测试,事务处理,缓存等等 ...
- List集合三种遍历方法
List<String> list = new ArrayList<String>();list.add("aaa");list.add("bbb ...
- Swift 新增fileprivate 详解
以前项目中只要用了private 那么在同一个文件同一个类中还是能访问的(比如一个类中写了一个extension) swift3.0现在不行了 新增了一个fileprivate 的访问控制 以前的p ...
- python自动化-unittest批量执行用例(discover)
前言 我们在写用例的时候,单个脚本的用例好执行,那么多个脚本的时候,如何批量执行呢?这时候就需要用到unittet里面的discover方法来加载用例了. 加载用例后,用unittest里面的Text ...