Прокси с модулем Python «Запросы» - PullRequest
129 голосов
/ 27 ноября 2011

Коротко, просто о превосходном модуле Requests для Python.

Я не могу найти в документации то, что должна содержать переменная 'прокси'.Когда я посылаю ему диктет со стандартным значением «IP: PORT», он отклоняет его, запрашивая 2 значения.Итак, я предполагаю (потому что это не рассматривается в документации), что первое значение - это ip, а второе - порт?

В документах упоминается только об этом:

прокси - (необязательно) Протокол преобразования словаря в URL прокси.

Итак, я попробовал это... что я должен делать?

proxy = { ip: port}

и я должен преобразовать их в некоторый тип прежде, чем поместить их в dict?

r = requests.get(url,headers=headers,proxies=proxy)

Ответы [ 8 ]

231 голосов
/ 27 ноября 2011

Синтаксис dict proxies 'равен {"protocol":"ip:port", ...}. С его помощью вы можете указать разные (или одинаковые) прокси для запросов, использующих протоколы http , https и ftp :

http_proxy  = "http://10.10.1.10:3128"
https_proxy = "https://10.10.1.11:1080"
ftp_proxy   = "ftp://10.10.1.10:3128"

proxyDict = { 
              "http"  : http_proxy, 
              "https" : https_proxy, 
              "ftp"   : ftp_proxy
            }

r = requests.get(url, headers=headers, proxies=proxyDict)

Выведено из requests документации :

Параметры:
method - метод для нового объекта Request.
url - URL для нового объекта запроса.
...
proxies - (необязательно) Словарь отображение протокол на URL прокси .
...


В Linux вы также можете сделать это через переменные окружения HTTP_PROXY, HTTPS_PROXY и FTP_PROXY:

export HTTP_PROXY=10.10.1.10:3128
export HTTPS_PROXY=10.10.1.11:1080
export FTP_PROXY=10.10.1.10:3128

В Windows:

set http_proxy=10.10.1.10:3128
set https_proxy=10.10.1.11:1080
set ftp_proxy=10.10.1.10:3128

Спасибо, Джей, за то, что указал на это:
Синтаксис изменился с запросами 2.0.0 .
Вам нужно добавить схему в URL: http://docs.python -requests.org / ru / latest / user / advanced / # proxies

25 голосов
/ 01 мая 2013

Я обнаружил, что у urllib есть действительно хороший код, чтобы подобрать настройки прокси-сервера системы, и они оказались в правильной форме для непосредственного использования.Вы можете использовать это как:

import urllib

...
r = requests.get('http://example.org', proxies=urllib.request.getproxies())

Это работает очень хорошо, и urllib также знает о настройках Mac OS X и Windows.

21 голосов
/ 15 ноября 2012

Вы можете обратиться к документации прокси здесь .

Если вам нужно использовать прокси, вы можете настроить отдельные запросы с аргументом прокси для любого метода запроса:

import requests

proxies = {
  "http": "http://10.10.1.10:3128",
  "https": "https://10.10.1.10:1080",
}

requests.get("http://example.org", proxies=proxies)

Для использования HTTP Basic Auth с вашим прокси используйте синтаксис http://user:password@host.com/:

proxies = {
    "http": "http://user:pass@10.10.1.10:3128/"
}
16 голосов
/ 03 февраля 2014

Принятый ответ был хорошим началом для меня, но я продолжал получать следующую ошибку:

AssertionError: Not supported proxy scheme None

Исправлено, что указание http: // в прокси-адресе, таким образом:

http_proxy  = "http://194.62.145.248:8080"
https_proxy  = "https://194.62.145.248:8080"
ftp_proxy   = "10.10.1.10:3128"

proxyDict = {
              "http"  : http_proxy,
              "https" : https_proxy,
              "ftp"   : ftp_proxy
            }

Мне было бы интересно узнать, почему оригинал работает для некоторых людей, но не для меня.

Изменить: я вижу, что основной ответ теперь обновляется, чтобы отразить это :)

1 голос
/ 30 ноября 2018

Если вы хотите сохранить файлы cookie и данные сеанса, лучше всего сделать это следующим образом:

import requests

proxies = {
    'http': 'http://user:pass@10.10.1.0:3128',
    'https': 'https://user:pass@10.10.1.0:3128',
}

# Create the session and set the proxies.
s = requests.Session()
s.proxies = proxies

# Make the HTTP request through the session.
r = s.get('http://www.showmemyip.com/')
1 голос
/ 13 ноября 2012

вот мой базовый класс на python для модуля запросов с некоторыми настройками прокси и секундомером!

import requests
import time
class BaseCheck():
    def __init__(self, url):
        self.http_proxy  = "http://user:pw@proxy:8080"
        self.https_proxy = "http://user:pw@proxy:8080"
        self.ftp_proxy   = "http://user:pw@proxy:8080"
        self.proxyDict = {
                      "http"  : self.http_proxy,
                      "https" : self.https_proxy,
                      "ftp"   : self.ftp_proxy
                    }
        self.url = url
        def makearr(tsteps):
            global stemps
            global steps
            stemps = {}
            for step in tsteps:
                stemps[step] = { 'start': 0, 'end': 0 }
            steps = tsteps
        makearr(['init','check'])
        def starttime(typ = ""):
            for stemp in stemps:
                if typ == "":
                    stemps[stemp]['start'] = time.time()
                else:
                    stemps[stemp][typ] = time.time()
        starttime()
    def __str__(self):
        return str(self.url)
    def getrequests(self):
        g=requests.get(self.url,proxies=self.proxyDict)
        print g.status_code
        print g.content
        print self.url
        stemps['init']['end'] = time.time()
        #print stemps['init']['end'] - stemps['init']['start']
        x= stemps['init']['end'] - stemps['init']['start']
        print x


test=BaseCheck(url='http://google.com')
test.getrequests()
0 голосов
/ 25 декабря 2018

Я только что сделал прокси-грабер, а также могу подключиться к тому же самому захваченному прокси без ввода:

#Import Modules

from termcolor import colored
from selenium import webdriver
import requests
import os
import sys
import time

#Proxy Grab

options = webdriver.ChromeOptions()
options.add_argument('headless')
driver = webdriver.Chrome(chrome_options=options)
driver.get("https://www.sslproxies.org/")
tbody = driver.find_element_by_tag_name("tbody")
cell = tbody.find_elements_by_tag_name("tr")
for column in cell:

        column = column.text.split(" ")
        print(colored(column[0]+":"+column[1],'yellow'))
driver.quit()
print("")

os.system('clear')
os.system('cls')

#Proxy Connection

print(colored('Getting Proxies from graber...','green'))
time.sleep(2)
os.system('clear')
os.system('cls')
proxy = {"http": "http://"+ column[0]+":"+column[1]}
url = 'https://mobile.facebook.com/login'
r = requests.get(url,  proxies=proxy)
print("")
print(colored('Connecting using proxy' ,'green'))
print("")
sts = r.status_code
0 голосов
/ 08 августа 2018

Немного поздно, но вот класс-оболочка, который упрощает очистку прокси и затем делает HTTP POST или GET:

ProxyRequests

https://github.com/rootVIII/proxy_requests
...