Проксі з модулем Python 'Requests'


159

Просто короткий простий про відмінний модуль Requests для Python.

Я не можу знайти в документації, що повинна містити змінна "проксі". Коли я надсилаю йому дікт зі стандартним значенням "IP: PORT", він відхилив його, просячи 2 значення. Отже, я здогадуюсь (оскільки це, здається, не висвітлено в документах), що перше значення - ip, а друге - порт?

Документи згадують лише про це:

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

Тому я спробував це ... що мені робити?

proxy = { ip: port}

і чи слід перетворювати їх на якийсь тип, перш ніж вносити їх у дікт?

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

Відповіді:


280

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 - метод для нового об’єкта запиту.
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-адреси: https://2.python-requests.org/en/latest/user/advanced/#proxies


@cigar Я знав, тому що urllib2 використовує точно такий же формат для їхніх проксі-серверів, і коли я побачив docs.python-requests.org/en/latest/api/#module-requests, кажуть "проксі - (необов'язково) протокол зіставлення словника до URL-адреса проксі. ", Я знав відразу.
чон

1
ага, я бачу, ніколи не використовував проксі з urllib2 через пораду позбутися від нього, отриманий звідси, замінив 2 сторінки коду на 8 рядків: / re: плечо :))) чудово залишайтесь тут, ви вже заощадили мене години всього! Якщо вам коли-небудь потрібна допомога з музикою, дайте кричати, що я можу дати пораду, інакше не можу придумати спосіб погасити, крім масивної подяки чи чашок чаю!

Здається , запити та крім того urllib3 не може зробити CONNECT при використанні проксі :(
Dzen

@dzen я ще не використовував, urllib3тому мені доведеться це вивчити. Дякую за голову вгору
чон

3
@chown синтаксис змінено запитами 2.0.0. Вам потрібно буде додати схему до URL: docs.python-requests.org/en/latest/user/advanced/#proxies Було б добре, якби ви могли додати це до своєї відповіді тут
Jay,

28

Я виявив, що в urllib є дійсно хороший код для підбору параметрів проксі-системи, і вони мають правильну форму для прямого використання. Ви можете використовувати це так:

import urllib

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

Він працює дуже добре, і urllib знає про отримання налаштувань Mac OS X та Windows.


Чи працює без проксі? Деякі наші користувачі не мають проксі, а деякі -.
jonasl

1
Чи включає він no_proxy і чи запити поважають no_proxy? Не забудьте, схоже, є рішення: github.com/kennethreitz/requests/isissue/879
jrwren

4
стає помилкою:module 'urllib' has no attribute 'getproxies'
Захра

4
Зеленуватий: urllib.request.getproxies ()
оліче

1
@Zahra try urllib2.getproxies ()
rleelr

25

Ви можете звернутися до документації про проксі тут .

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

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/"
}

17

Прийнята відповідь стала для мене гарним початком, але я продовжував отримувати таку помилку:

AssertionError: Not supported proxy scheme None

Виправте це, щоб вказати http: // у URL-адресі проксі-сервера таким чином:

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
            }

Мене цікавить, чому оригінальні твори для деяких людей, але не для мене.

Редагувати: я бачу, що основна відповідь зараз оновлена, щоб відобразити це :)


4
змінено на 2.0.0: URL-адреси проксі тепер мають мати чітку схему. Виняток MissingSchema буде підвищено, якщо вони цього не зробили.
Джей

4

Якщо ви хочете зберегти файли 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/')

2

На 8 років. Але мені подобається:

import os
import requests

os.environ['HTTP_PROXY'] = os.environ['http_proxy'] = 'http://http-connect-proxy:3128/'
os.environ['HTTPS_PROXY'] = os.environ['https_proxy'] = 'http://http-connect-proxy:3128/'
os.environ['NO_PROXY'] = os.environ['no_proxy'] = '127.0.0.1,localhost,.local'

r = requests.get('https://example.com')  # , verify=False

1

ось мій базовий клас у 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()

1

Я щойно зробив проксі-сервер, а також можу з'єднатись із тим самим захопленим проксі-сервером без будь-якого введення тут:

#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

Це трохи пізно, але ось клас обгортки, який спрощує скребки проксі, а потім створення http POST або GET:

Проксізапити

https://github.com/rootVIII/proxy_requests

0

Я ділюсь деяким кодом, як отримати проксі-сервери з сайту "https://free-proxy-list.net" та зберігати дані у файлі, сумісному з такими інструментами, як "Elite Proxy Switcher" (формат IP: PORT):

## PROXY_UPDATER - отримуйте безкоштовні проксі-сервери з https://free-proxy-list.net/

from lxml.html import fromstring
import requests
from itertools import cycle
import traceback
import re

######################FIND PROXIES#########################################
def get_proxies():
    url = 'https://free-proxy-list.net/'
    response = requests.get(url)
    parser = fromstring(response.text)
    proxies = set()
    for i in parser.xpath('//tbody/tr')[:299]:   #299 proxies max
        proxy = ":".join([i.xpath('.//td[1]/text()') 
        [0],i.xpath('.//td[2]/text()')[0]])
        proxies.add(proxy)
    return proxies



######################write to file in format   IP:PORT######################
try:
    proxies = get_proxies()
    f=open('proxy_list.txt','w')
    for proxy in proxies:
        f.write(proxy+'\n')
    f.close()
    print ("DONE")
except:
    print ("MAJOR ERROR")
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.