python使用HTTP代理和SOCKS5代理的代码示例
2024-03-07 本文已影响0人
小石头IP客服
本文档为获取到代理IP后使用代理的代码样例,供开发者参考。
代码样例直接运行无法得到正确的结果,因为代码中的代理地址/端口和应用账号密码等信息都是虚构的,您替换成自己真实的就可以正常运行了。
如何获取代理地址/端口和设置代理授权?
使用前提:
1、 已经获取代理地址,去获取:www.xiaoshitouip.com。
2、 已经设置代理授权(用户名/密码或者IP白名单)。
标准代理使用示例:
#! /usr/bin/python
# coding=utf-8
import requests
import time
import random
# 请求目标地址
targetUrl = "http://myip.top"
# 如果是标准代理,提取ip的链接,ip格式如下:
# 125.105.48.157:30083
# 122.230.48.60:30083
# 从 https://www.xiaoshitouip.com/ 领取后,替换自己的appKey和订单号
server_url= "https://api.xiaoshitouip.com/v1/getip/text? \
appKey=替换为自己的appKey&orderNo=替换为自己的订单号&serviceType=http \
&validTime=20&sortRule=0&extractNumber=20&lb=0&isDetail=false"
ips=[]
# 替换为自己的用户名
# 到管理后台:https://admin.xiaoshitouip.com/proxy/proxy-auth 授权管理页面添加账号密码或者ip白名单
# 设置了ip白名单就不需要设置账号密码了
user="你的用户名"
password="你的密码"
# 获取全部的ip
def getips():
resp = requests.get(server_url)
ips = resp.text.split("\r\n")
return ips
# 随机选一个ip
def genProxyMeta():
proxyMeta = "http://%(user)s:%(pass)s@%(host)s" % {
"host": random.choice(ips), # 随机选一个ip
"user":user, # 用户名
"pass":password, # 密码
}
return proxyMeta
#账号密码验证
#proxyMeta = "http://账号:密码@%(host)s:%(port)s" % {
# "host": proxyHost,
# "port": proxyPort,
#}
#
# #pip install -U requests[socks] socks5代理
#非账号密码验证
# proxyMeta = "socks5://%(host)s:%(port)s" % {
# "host" : proxyHost,
# "port" : proxyPort,
# }
#账号密码验证
# proxyMeta = "socks5://账号:密码%(host)s:%(port)s" % {
# "host" : proxyHost,
# "port" : proxyPort,
# }
# 获取全部的ip
# ips = getips()
# print(ips)
i = 0
success = 0
fail = 0
while i < 1000:
try:
if i%3==0:
# 获取全部的ip
ips = getips()
print(ips)
if len(ips) == 0:
# 如果没获取到ip,就等2秒再获取
time.sleep(2)
continue
if ips[0] == '':
# 如果获取的ip为空,就等2秒再获取
time.sleep(2)
continue
# 设置代理信息
proxyMeta=genProxyMeta()
proxies = {
"http": proxyMeta,
"https": proxyMeta
}
t1 = time.time()
# 请求目标网址
resp = requests.get(url=targetUrl, proxies=proxies,timeout=10)
print(resp)
# print(resp.status_code)
if resp.status_code != 200:
print(resp.text)
print(resp.text)
success = success + 1
t2 = time.time()
print("耗时:", t2 - t1,"s")
except Exception as e:
fail = fail + 1
print(e)
i = i + 1
print('失败:%s 总共:%s' % (fail,i))
image.gif
隧道代理使用示例:
#! /usr/bin/python
# coding=utf-8
import requests
import time
import random
# 请求目标地址
targetUrl="http://myip.top"
# http隧道地址+端口:从管理后台:https://admin.xiaoshitouip.com/proxy/proxy-order-main
# 订单管理页面对应订单的提取链接获取
host="dy001.xiaoshitouip.com:40083"
# 替换为自己的用户名和密码
# 到管理后台:https://admin.xiaoshitouip.com/proxy/proxy-auth
# 授权管理页面添加账号密码或者ip白名单
# 设置了ip白名单就不需要设置账号密码了
user="你的用户名"
password="你的密码"
# 设置代理
def genProxyMeta():
proxyMeta = "http://%(user)s:%(pass)s@%(host)s" % {
"host": host,
"user":user,
"pass":password
}
return proxyMeta
#账号密码验证
#proxyMeta = "http://账号:密码@%(host)s:%(port)s" % {
# "host": proxyHost,
# "port": proxyPort,
#}
#
# #pip install -U requests[socks] socks5代理
#非账号密码验证
# proxyMeta = "socks5://%(host)s:%(port)s" % {
# "host" : proxyHost,
# "port" : proxyPort,
# }
#账号密码验证
# proxyMeta = "socks5://账号:密码%(host)s:%(port)s" % {
# "host" : proxyHost,
# "port" : proxyPort,
# }
i = 0
success = 0
fail = 0
while i < 1000:
try:
proxyMeta=genProxyMeta()
proxies = {
"http": proxyMeta,
"https": proxyMeta
}
t1 = time.time()
# 请求
resp = requests.get(url=targetUrl, proxies=proxies,timeout=10)
print(resp)
print(resp.text)
success = success + 1
t2 = time.time()
print("耗时:", t2 - t1,"s")
except Exception as e:
fail = fail + 1
print(e)
i = i + 1
print('失败:%s 总共:%s' % (fail,i))