python-3.x - 如何正确检查 socks5 代理
问题描述
您好,今天我在论坛上发布了一些 Socks5 代理,有人与我讨论并说许多“连接”代理和 socks4 代理的代理,但我认为我的代码没有检查任何 socks4 代理:
def process(self, task):
global alive
global dead
global tested
proxy = task
ip,port = proxy.split(":")
socket.setdefaulttimeout(timeout_value)
log_msg = str("Trying Socks5 proxy%21s " % proxy)
socks.set_default_proxy(socks.SOCKS5, ip, int(port))
socket.socket = socks.socksocket
try:
t1 = time.time()
response = requests.get(test_url, timeout=timeout_value)
tested += 1
t2 = time.time()
except Exception as e:
log_msg += "%s " % fail_msg
print(Fore.LIGHTRED_EX + log_msg + " " + str(tested))
dead += 1
tested += 1
return None
if "Connection working" in response.text:
log_msg += ok_msg + "Response time: %d" % (int((t2-t1)*1000))
print(Fore.LIGHTGREEN_EX + log_msg)
text_file = open(out_filename, "a")
text_file.write(proxy + "\r\n")
text_file.close()
alive += 1
return proxy
else:
log_msg += "%s " % fail_msg
print(Fore.LIGHTRED_EX + log_msg + " " + str(tested))
dead += 1
tested += 1
return None
我不知道我做错了什么,这个人说他自 2002 年以来一直在检查代理,他是成千上万抱怨它的人中的第一个。
解决方案
理论上,代理可以在同一端口上同时处理 socks4、socks5 和连接(即 HTTP 代理),这意味着你们俩可能都是对的。使用所有这些协议,客户端发送第一条消息,这些消息在 socks4、socks5 和 connect 之间存在显着差异。因此,代理可以根据第一条消息来决定客户端请求哪种协议。而且,虽然我不知道有任何代理可以处理同一端口上的所有三个协议,但至少可以通过同一代理在同一端口同时处理 socks4 和 socks5。
推荐阅读
- database - 第三范式数据库
- firebase - 推送通知未正确连接到 Firebase 消息传递
- java - Firebase Java Android 检查所有节点子节点的值
- c# - 使用 explorer.exe 打开应用程序,但添加了设置
- database - 使用正则表达式将字符串切割成 2 部分
- typescript - TypeScript 文件中只有一行,我得到:无法在我编译时重新声明块范围变量
- javascript - 如何遍历数组并在vue中直观地显示单个元素
- ios - SCNPlane 的 3D 世界位置 [ARkit]
- protocol-buffers - Protobuf NoClassDefFoundError - 解析 grpc 响应时出错
- javascript - Fetch API 不一致地修改请求正文