本質上來說,檢測隧道HTTP代理的可用性就是檢測HTTP代理的可用性,目前市面上常見的方法有如下幾種:
一、常用軟體
利用常用的日用軟體當中的“設定”,使用HTTP代理,填寫對應ip代理的地址+埠,點選“檢測”,返回成功,則是正常,返回失敗,這是無效。值得注意的是,目前市面上很多正規的廠商都對聊天工具實施禁止使用的狀態,所以建議日用軟體避開此類。
二、Telnet
在cmd命令列裡輸入 Telnet IP +埠,然後回車。
不過此類方法並不一定能連線代理伺服器,僅可測試客戶端和代理伺服器端是否能通訊。
三、ping
在cmd命令列裡輸入 ping IP
此類方法也有侷限性,因為很多伺服器的防火牆都會關閉ping的回顯。
四、訪問瀏覽器
直接設定HTTP代理,利用該HTTP代理是否能成功訪問網站來檢測是否連線代理成功。HTTP代理數量較少的時候可以使用curl 檢測,當面臨隧道代理這種,數量層級較大的時候,就需要用指令碼測試了,測試的同時,我們把可以讀取包含代理的文字檔案,並將可用的代理寫入另一個檔案中,具體如下:
import requests import time def check_proxy(proxy): # 使用代理發起請求,如果返回狀態碼為200,說明代理可用 try: # 這裡替換為你要請求的目標網站 response = requests.get('{"http": proxy, "https": proxy}, timeout=5) if response.status_code == 200: return True except Exception: pass return False # 讀取代理列表 with open('proxies.txt', 'r') as f: proxy_list = f.read().splitlines() # 建立用於儲存可用代理的列表 valid_proxies = [] # 遍歷代理列表,檢測代理是否可用 for proxy in proxy_list: if check_proxy(proxy): valid_proxies.append(proxy) # 將可用代理寫入檔案 with open('valid_proxies.txt', 'w') as f: for proxy in valid_proxies: f.write(proxy + '\n')