โœจ What's New

May 18, 2026 ยท View on GitHub


Docs PyPI - Python Version PyPI License PyPI - Downloads (total) PyPI - Downloads (month) PyPI - Downloads (week) Update Proxies.json Issue Resolution Open Issues

๐Ÿ“š Documentation

https://freeproxy.readthedocs.io/

โšก Live Proxies (ๆœ€ๆ–ฐๅ…่ดน้ซ˜่ดจ้‡ไปฃ็†)

https://charlespikachu.github.io/freeproxy/

demo

ๅญฆไน ๆ”ถ่Žทๆ›ดๅคšๆœ‰่ถฃ็š„ๅ†…ๅฎน, ๆฌข่ฟŽๅ…ณๆณจๅพฎไฟกๅ…ฌไผ—ๅท๏ผšCharles็š„็šฎๅกไธ˜

โœจ What's New

  • 2026-05-19: Released pyfreeproxy v0.4.7 โ€” Add two proxy sources: hide.mn and proxybros.com.
  • 2026-04-22: Released pyfreeproxy v0.4.6 โ€” Added two new free proxy nodes: Geonix and ProxyVerity.
  • 2026-04-08: Released pyfreeproxy v0.4.5 โ€” Fix compatibility issues with Python 3.10; add support for two new high-quality free proxy sources: "pubproxy.com" and "floppydata.com".

๐Ÿ“˜ Introduction

๐ŸŒ FreeProxy continuously discovers, verifies, and updates free proxy lists for HTTP, HTTPS, SOCKS4, and SOCKS5. With flexible filtering by geography, anonymity, speed, and more, it helps you quickly find proxies that match your needs. If you find this project useful, please consider giving it a โญ to support development and stay updated.

๐ŸŒ Supported Proxy Sources

Proxy Source (EN)Proxy Source (CN)HTTPHTTPSSOCKS4SOCKS5Code Snippet
ADVFPProxiedSessionAdvanced.Nameโœ”โœ”โœ”โœ”advfp.py
DatabayProxiedSessionDatabayโœ”โœ”โŒโœ”databay.py
DpangestuwProxiedSessionDpangestuwโœ”โœ”โœ”โœ”dpangestuw.py
FreeproxylistProxiedSessionFreeProxyListโœ”โœ”โœ”โŒfreeproxylist.py
FineProxyProxiedSessionFineProxyโœ”โœ”โœ”โœ”fineproxy.py
FreeProxyDBProxiedSessionFreeProxyDBโœ”โŒโœ”โœ”freeproxydb.py
FreeVPNNodeProxiedSessionFreeVPNNodeโœ”โŒโœ”โœ”freevpnnode.py
FloppyDataProxiedSessionFloppyDataโœ”โŒโŒโŒfloppydata.py
GeonodeProxiedSessionGeonodeโœ”โœ”โœ”โœ”geonode.py
GoodIPSProxiedSession่ฐทๅพทๅ…่ดนไปฃ็†โœ”โœ”โœ”โœ”goodips.py
GeonixProxiedSessionGeonixโœ”โœ”โœ”โœ”geonix.py
HideProxiedSessionHideMyNameโœ”โœ”โœ”โœ”hide.py
IPLocateProxiedSessionIPLocateโœ”โœ”โœ”โœ”iplocate.py
IP3366ProxiedSessionไบ‘ไปฃ็†โœ”โœ”โŒโŒip3366.py
IP89ProxiedSessionIP89โœ”โŒโŒโŒip89.py
IPRoyalProxiedSessionIPRoyalโŒโœ”โŒโŒiproyal.py
JiliuipProxiedSession็งฏๆตไปฃ็†โœ”โŒโŒโŒjiliuip.py
KuaidailiProxiedSessionๅฟซไปฃ็†โœ”โœ”โŒโŒkuaidaili.py
KxdailiProxiedSessionๅผ€ๅฟƒไปฃ็†โœ”โœ”โŒโŒkxdaili.py
OpenProxyListProxiedSessionOpenProxyListโœ”โœ”โœ”โœ”openproxylist.py
ProxyhubProxiedSessionProxyHubโœ”โœ”โœ”โœ”proxyhub.py
ProxydbProxiedSessionProxyDBโœ”โœ”โŒโœ”proxydb.py
ProxylistProxiedSessionProxyListโœ”โœ”โœ”โœ”proxylist.py
ProxiflyProxiedSessionProxiflyโœ”โœ”โœ”โœ”proxifly.py
ProxydailyProxiedSessionProxyDailyโœ”โœ”โœ”โœ”proxydaily.py
ProxyScrapeProxiedSessionProxyScrapeโœ”โŒโœ”โœ”proxyscrape.py
ProxyEliteProxiedSessionProxyEliteโœ”โŒโœ”โœ”proxyelite.py
ProxyNovaProxiedSessionProxyNovaโœ”โŒโŒโŒproxynova.py
ProxyShareProxiedSessionProxyShareโœ”โœ”โœ”โœ”proxyshare.py
ProxiwareProxiedSessionProxiwareโœ”โœ”โœ”โœ”proxiware.py
ProxyFreeOnlyProxiedSessionProxyFreeOnlyโœ”โœ”โœ”โœ”proxyfreeonly.py
PubProxyProxiedSessionPubProxyโœ”โŒโŒโŒpubproxy.py
ProxyVerityProxiedSessionProxyVerityโœ”โœ”โœ”โœ”proxyverity.py
ProxybrosProxiedSessionProxyBrosโœ”โœ”โœ”โœ”proxybros.py
QiyunipProxiedSession้ฝไบ‘ไปฃ็†โœ”โœ”โŒโŒqiyunip.py
RoundProxiesProxiedSessionRoundproxiesโœ”โœ”โœ”โœ”roundproxies.py
SpysoneProxiedSessionSPYS.ONEโœ”โŒโŒโœ”spysone.py
SCDNProxiedSessionๅ…ฌๅ…ฑไปฃ็†ๆฑ โœ”โœ”โœ”โœ”scdn.py
SixSixDailiProxiedSession66ๅ…่ดนไปฃ็†โœ”โœ”โœ”โœ”sixsixdaili.py
SocksListProxiedSessionFreeSocks5ProxyโŒโŒโŒโœ”sockslist.py
Tomcat1235ProxiedSessionๅŒ—ๆžๅ…‰ไปฃ็†โŒโŒโŒโœ”tomcat1235.py
TheSpeedXProxiedSessionTheSpeedXโœ”โŒโœ”โœ”thespeedx.py
TrustyTechProxiedSessionTrustyTechโœ”โœ”โœ”โœ”trustytech.py

๐ŸŽฎ Playground

Here are some projects built on top of pyfreeproxy,

ProjectWeChat ArticleProject Location
ICU996็”จๆ•ฐไธ‡ๆกๆ•ฐๆฎๅธฆๅคงๅฎถ็œ‹็œ‹ๅˆฐๅบ•ๆ˜ฏๅ“ชไบ›ไบบๅœจๅๅฏน996~click

๐Ÿ“ฆ Install

You have three installation methods to choose from,

# from pip
pip install pyfreeproxy
# from github repo method-1
pip install git+https://github.com/CharlesPikachu/freeproxy.git@master
# from github repo method-2
git clone https://github.com/CharlesPikachu/freeproxy.git
cd freeproxy
python setup.py install

Please note that some proxy sources need to be crawled using DrissionPage, such as IP3366ProxiedSession. If DrissionPage cannot find a suitable browser in the current environment, it will automatically download the latest compatible beta version of Google Chrome for the current system. So if you notice that the program is downloading a browser, there is no need to be overly concerned.

๐Ÿš€ Quick Start

Scrape proxies from multiple sources

After installing freeproxy, you can run a script to:

  • scrape proxies from multiple sources,
  • print basic statistics for each source,
  • save all retrieved proxies into a JSON file.

Example code (scrape + summarize + save):

import json, random
from tqdm import tqdm
from freeproxy.modules import BaseProxiedSession, ProxyInfo, BuildProxiedSession, printtable, colorize

'''settings'''
SOURCES = ["ProxiflyProxiedSession", "KuaidailiProxiedSession", "QiyunipProxiedSession", "ProxylistProxiedSession"]
TITLES = ["Source", "Retrieved Example", "HTTP", "HTTPS", "SOCKS4", "SOCKS5", "Chinese IP", "Elite", "Total"]

'''scrape'''
def scrape(src: str) -> list[ProxyInfo]:
    try:
        sess: BaseProxiedSession = BuildProxiedSession({"max_pages": 1, "type": src, "disable_print": False})
        return sess.refreshproxies()
    except Exception:
        return []

'''stats'''
def stats(proxies: list[ProxyInfo]) -> dict:
    return {
        "http":   sum(p.protocol.lower() == "http"   for p in proxies),
        "https":  sum(p.protocol.lower() == "https"  for p in proxies),
        "socks4": sum(p.protocol.lower() == "socks4" for p in proxies),
        "socks5": sum(p.protocol.lower() == "socks5" for p in proxies),
        "cn":     sum(bool(p.in_chinese_mainland) for p in proxies),
        "elite":  sum(p.anonymity.lower() == "elite" for p in proxies),
        "total":  len(proxies),
        "ex":     (random.choice(proxies).proxy if proxies else "NULL"),
    }

'''row'''
def row(src: str, s: dict) -> list:
    ex = colorize(s["ex"], "green") if s["total"] else "NULL"
    return [
        src.removesuffix("ProxiedSession"),
        ex,
        colorize(s["http"], "number"),
        colorize(s["https"], "number"),
        colorize(s["socks4"], "number"),
        colorize(s["socks5"], "number"),
        colorize(s["cn"], "number"),
        colorize(s["elite"], "number"),
        colorize(s["total"], "number"),
    ]

'''main'''
def main():
    free_proxies, items = {}, []
    for src in tqdm(SOURCES):
        proxies = scrape(src)
        items.append(row(src, stats(proxies)))
        free_proxies[src] = [p.todict() for p in proxies]
    print("The proxy distribution for each source you specified is as follows:")
    printtable(titles=TITLES, items=items, terminal_right_space_len=1)
    json.dump(free_proxies, open("free_proxies.json", "w"), indent=2)

'''tests'''
if __name__ == "__main__":
    main()

Example output (terminal):

C:\Users\Charles\Desktop>python test.py
KuaidailiProxiedSession >>> adding country_code: 37it [00:05,  6.57it/s]                 | 1/4 [00:18<00:56, 18.95s/it]
100%|โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆ| 4/4 [00:28<00:00,  7.17s/it]
The proxy distribution for each source you specified is as follows:
+-----------+-------------------------------+------+-------+--------+--------+------------+-------+-------+
|   Source  |       Retrieved Example       | HTTP | HTTPS | SOCKS4 | SOCKS5 | Chinese IP | Elite | Total |
+-----------+-------------------------------+------+-------+--------+--------+------------+-------+-------+
|  Proxifly |   http://195.231.69.203:443   | 5112 |   0   |  1043  |  477   |     48     |  2157 |  6632 |
| Kuaidaili |   http://113.45.158.25:3128   |  20  |   13  |   0    |   0    |     19     |   33  |   33  |
|  Qiyunip  |   https://114.103.88.18:8089  |  6   |   9   |   0    |   0    |     15     |   14  |   15  |
| Proxylist | socks4://184.181.217.206:4145 | 420  |   59  |  182   |  156   |     54     |  699  |  817  |
+-----------+-------------------------------+------+-------+--------+--------+------------+-------+-------+

All proxies are saved to free_proxies.json in the current directory, e.g.:

{
  "KuaidailiProxiedSession": [
    {
      "source": "KuaidailiProxiedSession",
      "protocol": "http",
      "ip": "58.216.109.17",
      "port": "800",
      "country_code": "CN",
      "in_chinese_mainland": true,
      "anonymity": "elite",
      "delay": 124,
      "test_timeout": 5,
      "test_url": "http://www.baidu.com",
      "test_headers": {
        "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/124.0.0.0 Safari/537.36"
      },
      "failed_connection_default_timeout": 3600000,
      "created_at": "2025-12-03T12:43:25.018208",
      "extra": {}
    }
  ],
  "ProxiflyProxiedSession": [],
  "QiyunipProxiedSession": [],
  "ProxylistProxiedSession": []
}

Tip: Increase max_pages to fetch more proxies from each source.

List supported proxy sources

To list all proxy sources supported by your current freeproxy version:

python -c "from freeproxy.modules import ProxiedSessionBuilder; print(ProxiedSessionBuilder.REGISTERED_MODULES.keys())"

Example output:

{
  'ProxiflyProxiedSession':      ProxiflyProxiedSession,      'FreeproxylistProxiedSession': FreeproxylistProxiedSession,
  'IP89ProxiedSession':          IP89ProxiedSession,          'ProxyEliteProxiedSession':    ProxyEliteProxiedSession,
  'IP3366ProxiedSession':        IP3366ProxiedSession,        'KuaidailiProxiedSession':     KuaidailiProxiedSession,
  'KxdailiProxiedSession':       KxdailiProxiedSession,       'ProxydailyProxiedSession':    ProxydailyProxiedSession,
  'ProxydbProxiedSession':       ProxydbProxiedSession,       'ProxyhubProxiedSession':      ProxyhubProxiedSession,
  'ProxylistProxiedSession':     ProxylistProxiedSession,     'QiyunipProxiedSession':       QiyunipProxiedSession,
  'SpysoneProxiedSession':       SpysoneProxiedSession,       'Tomcat1235ProxiedSession':    Tomcat1235ProxiedSession,
  'DatabayProxiedSession':       DatabayProxiedSession,       'FineProxyProxiedSession':     FineProxyProxiedSession,
  'IPLocateProxiedSession':      IPLocateProxiedSession,      'JiliuipProxiedSession':       JiliuipProxiedSession,
  'TheSpeedXProxiedSession':     TheSpeedXProxiedSession,     'GeonodeProxiedSession':       GeonodeProxiedSession,
  'FreeProxyDBProxiedSession':   FreeProxyDBProxiedSession,   'ProxyScrapeProxiedSession':   ProxyScrapeProxiedSession,
  'SCDNProxiedSession':          SCDNProxiedSession,          'GoodIPSProxiedSession':       GoodIPSProxiedSession,
  'SixSixDailiProxiedSession':   SixSixDailiProxiedSession,   'DpangestuwProxiedSession':    DpangestuwProxiedSession,
  'ProxyNovaProxiedSession':     ProxyNovaProxiedSession,     'ProxyShareProxiedSession':    ProxyShareProxiedSession,
  'OpenProxyListProxiedSession': OpenProxyListProxiedSession, 'IPRoyalProxiedSession':       IPRoyalProxiedSession,
  'ADVFPProxiedSession':         ADVFPProxiedSession,         'RoundProxiesProxiedSession':  RoundProxiesProxiedSession,
  'SocksListProxiedSession':     SocksListProxiedSession,     'ProxiwareProxiedSession':     ProxiwareProxiedSession,
  'ProxyFreeOnlyProxiedSession': ProxyFreeOnlyProxiedSession, 'TrustyTechProxiedSession':    TrustyTechProxiedSession,
  'FreeVPNNodeProxiedSession':   FreeVPNNodeProxiedSession,   'FloppyDataProxiedSession':    FloppyDataProxiedSession,
  'PubProxyProxiedSession':      PubProxyProxiedSession,      'ProxyVerityProxiedSession':   ProxyVerityProxiedSession,
  'GeonixProxiedSession':        GeonixProxiedSession,        'HideProxiedSession':          HideProxiedSession,
  'ProxybrosProxiedSession':     ProxybrosProxiedSession,
}

Apply stricter filtering

By default, freeproxy:

  • validates proxy format,
  • de-duplicates results,
  • does not aggressively filter by geography/anonymity/speed unless you specify rules.

You can enforce stricter filtering by passing filter_rule.

Common fields in filter_rule:

  • country_code: e.g., ['CN'], ['US']
  • anonymity: elite, anonymous, transparent (string or list)
  • protocol: http, https, socks4, socks5 (string or list)
  • max_tcp_ms: maximum TCP connect latency (ms)
  • max_http_ms: maximum HTTP request latency to test_url (ms)

Example A: only mainland China proxies

from freeproxy.modules.proxies import IP3366ProxiedSession

sess = IP3366ProxiedSession(filter_rule={"country_code": ["CN"]})
sess.refreshproxies()
print(sess.getrandomproxy(proxy_format="freeproxy"))

Example B: US + elite anonymity

from freeproxy.modules.proxies import SpysoneProxiedSession

sess = SpysoneProxiedSession(filter_rule={"anonymity": ["elite"], "country_code": ["US"]})
sess.refreshproxies()
print(sess.getrandomproxy(proxy_format="freeproxy"))

Example C: constrain protocol + speed

from freeproxy.modules.proxies import FreeproxylistProxiedSession

sess = FreeproxylistProxiedSession(
    filter_rule={
        "protocol": ["http", "https"],
        "max_tcp_ms": 10000,
        "max_http_ms": 10000,
    }
)
sess.refreshproxies()
print(sess.getrandomproxy(proxy_format="freeproxy"))

Note (performance): max_tcp_ms / max_http_ms may significantly slow down crawling when too many proxies are scraped, because each proxy requires additional testing. In general, itโ€™s better to crawl first, then run a separate post-test script if you need strict speed constraints.

Unified client: ProxiedSessionClient

ProxiedSessionClient provides a unified interface across proxy sources and behaves like a requests.Session with an automatically maintained proxy pool.

  • It keeps a proxy pool where all proxies satisfy your filter_rule.
  • Each .get() / .post() consumes at least one proxy.
  • When the pool is low, it automatically replenishes proxies by scraping again.

Minimal example:

from freeproxy.freeproxy import ProxiedSessionClient

proxy_sources = ["KuaidailiProxiedSession"]
init_proxied_session_cfg = {"filter_rule": {"country_code": ["CN", "US"]}}
client = ProxiedSessionClient(
    proxy_sources=proxy_sources, init_proxied_session_cfg=init_proxied_session_cfg,
)
headers = {
    "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/98.0.4758.102 Safari/537.36"
}
resp = client.get("https://space.bilibili.com/406756145", headers=headers)
print(resp.text)

Quiet mode (suppress logs):

from freeproxy import freeproxy

client = freeproxy.ProxiedSessionClient(
    proxy_sources=["ProxydbProxiedSession"], disable_print=True,
)

Init arguments:

  • proxy_sources (list[str]): proxy sources to use.
  • init_proxied_session_cfg (dict): session config; supports:
    • max_pages: pages to fetch per source
    • filter_rule: filtering rules described above
    • plus standard requests.Session options
  • disable_print (bool): suppress proxy usage logs.
  • max_tries (int): max attempts per .get() / .post() call.

Example: filter scraped proxies via the unified client

from freeproxy.freeproxy import ProxiedSessionClient

client = ProxiedSessionClient(
    proxy_sources=["ProxyScrapeProxiedSession", "ProxylistProxiedSession"],
    init_proxied_session_cfg={
        "max_pages": 2,
        "filter_rule": {
            "country_code": ["CN"],
            "anonymity": ["elite"],
            "protocol": ["http", "https"],
        },
    },
    disable_print=False,
    max_tries=20,
)
headers = {
    'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/143.0.0.0 Safari/537.36',
}
resp = client.get("https://www.baidu.com/", timeout=10, headers=headers)
print(resp.text)
resp = client.get("https://httpbin.org/ip", timeout=5)
print(resp.json())
resp = client.get("https://httpbin.org/anything", timeout=15)
print(resp.json())
print("origin:", resp.json().get("origin"))
print("X-Forwarded-For:", resp.json()["headers"].get("X-Forwarded-For"))
print("Forwarded:", resp.json()["headers"].get("Forwarded"))

Final note: you can refer to freeproxyโ€™s source code to unlock more features, the overall codebase is small and easy to navigate.

โญ Recommended Projects

Projectโญ Stars๐Ÿ“ฆ Versionโฑ Last Update๐Ÿ›  Repository
๐ŸŽต Musicdl
่ฝป้‡็บงๆ— ๆŸ้Ÿณไนไธ‹่ฝฝๅ™จ
StarsVersionLast Commit๐Ÿ›  Repository
๐ŸŽฌ Videodl
่ฝป้‡็บง้ซ˜ๆธ…ๆ— ๆฐดๅฐ่ง†้ข‘ไธ‹่ฝฝๅ™จ
StarsVersionLast Commit๐Ÿ›  Repository
๐Ÿ–ผ๏ธ Imagedl
่ฝป้‡็บงๆตท้‡ๅ›พ็‰‡ๆœ็ดขไธ‹่ฝฝๅ™จ
StarsVersionLast Commit๐Ÿ›  Repository
๐Ÿ–ผ๏ธ Paperdl
่ฝป้‡็บงๅญฆๆœฏ่ฎบๆ–‡ๆœ็ดขไธ‹่ฝฝๅ™จ
StarsVersionLast Commit๐Ÿ›  Repository
๐ŸŒ FreeProxy
ๅ…จ็ƒๆตท้‡้ซ˜่ดจ้‡ๅ…่ดนไปฃ็†้‡‡้›†ๅ™จ
StarsVersionLast Commit๐Ÿ›  Repository
๐ŸŒ MusicSquare
็ฎ€ๆ˜“้Ÿณไนๆœ็ดขไธ‹่ฝฝๅ’Œๆ’ญๆ”พ็ฝ‘้กต
StarsVersionLast Commit๐Ÿ›  Repository
๐ŸŒ FreeGPTHub
็œŸๆญฃๅ…่ดน็š„GPT็ปŸไธ€ๆŽฅๅฃ
StarsVersionLast Commit๐Ÿ›  Repository

๐Ÿ“š Citation

If you use this project in your research, please cite the repository.

@misc{freeproxy2022,
    author = {Zhenchao Jin},
    title = {FreeProxy: Collecting free proxies from internet},
    year = {2022},
    publisher = {GitHub},
    journal = {GitHub repository},
    howpublished = {\url{https://github.com/CharlesPikachu/freeproxy}},
}

๐ŸŒŸ Star History

Star History Chart

โ˜• Appreciation (่ตž่ต / ๆ‰“่ต)

WeChat Appreciation QR Code (ๅพฎไฟก่ตž่ต็ )Alipay Appreciation QR Code (ๆ”ฏไป˜ๅฎ่ตž่ต็ )

๐Ÿ“ฑ WeChat Official Account (ๅพฎไฟกๅ…ฌไผ—ๅท):

Charles็š„็šฎๅกไธ˜ (Charles_pikachu)
img