小石头HTTP@IT·互联网

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))

上一篇下一篇

猜你喜欢

热点阅读