Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/romis2012/aiohttp-socks
Proxy (HTTP, SOCKS) connector for aiohttp
https://github.com/romis2012/aiohttp-socks
aiohttp asyncio http proxy python socks4 socks5
Last synced: 5 days ago
JSON representation
Proxy (HTTP, SOCKS) connector for aiohttp
- Host: GitHub
- URL: https://github.com/romis2012/aiohttp-socks
- Owner: romis2012
- License: apache-2.0
- Created: 2018-07-04T12:09:48.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2024-12-26T07:05:11.000Z (27 days ago)
- Last Synced: 2025-01-10T10:08:19.251Z (12 days ago)
- Topics: aiohttp, asyncio, http, proxy, python, socks4, socks5
- Language: Python
- Homepage:
- Size: 1.34 MB
- Stars: 224
- Watchers: 7
- Forks: 22
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
## aiohttp-socks
[![CI](https://github.com/romis2012/aiohttp-socks/actions/workflows/ci.yml/badge.svg)](https://github.com/romis2012/aiohttp-socks/actions/workflows/ci.yml)
[![Coverage Status](https://codecov.io/gh/romis2012/aiohttp-socks/branch/master/graph/badge.svg)](https://codecov.io/gh/romis2012/aiohttp-socks)
[![PyPI version](https://badge.fury.io/py/aiohttp-socks.svg)](https://pypi.python.org/pypi/aiohttp-socks)The `aiohttp-socks` package provides a proxy connector for [aiohttp](https://github.com/aio-libs/aiohttp).
Supports SOCKS4(a), SOCKS5(h), HTTP (tunneling) as well as Proxy chains.
It uses [python-socks](https://github.com/romis2012/python-socks) for core proxy functionality.## Requirements
- Python >= 3.8
- aiohttp >= 3.10.0
- python-socks[asyncio] >= 2.4.3## Installation
```
pip install aiohttp_socks
```## Usage
#### aiohttp usage:
```python
import aiohttp
from aiohttp_socks import ProxyType, ProxyConnector, ChainProxyConnectorasync def fetch(url):
connector = ProxyConnector.from_url('socks5://user:[email protected]:1080')
### or use ProxyConnector constructor
# connector = ProxyConnector(
# proxy_type=ProxyType.SOCKS5,
# host='127.0.0.1',
# port=1080,
# username='user',
# password='password',
# rdns=True # default is True for socks5
# )
### proxy chaining (since ver 0.3.3)
# connector = ChainProxyConnector.from_urls([
# 'socks5://user:[email protected]:1080',
# 'socks4://127.0.0.1:1081',
# 'http://user:[email protected]:3128',
# ])
async with aiohttp.ClientSession(connector=connector) as session:
async with session.get(url) as response:
return await response.text()
```## Why yet another SOCKS connector for aiohttp
Unlike [aiosocksy](https://github.com/romis2012/aiosocksy), aiohttp_socks has only single point of integration with aiohttp.
This makes it easier to maintain compatibility with new aiohttp versions.