专业的国内动态IP
一站式大数据服务提供商

覆盖500+城市,超2000个服务器,亿量级IP

免费试用

1000万+IP

纯净住宅代理

200+地区

全国覆盖

99.9%

高可用率

24/7

实时技术支持

我们的核心优势

不限并发会话

支持无限并发会话,高带宽,无需额外费用,满足您的业务拓展需求。

城市级定位

提供国家、城市和州级精准定位IP,支持HTTP(S)/Socks5代理协议。

流量不过期

动态住宅代理的流量套餐不限使用时间,无需担心剩余流量过期。

代理快速响应

找IP吧代理高带宽,IP资源池24小时去重,保障动态住宅代理快速运行,平均响应时间为0.6秒。技术团队全程监测系统,客服团队随时解答用户问题。

数据统计中心

找IP吧个人中心实时统计代理使用数据,您可以随时查看账户余额信息和流量使用情况,支持添加多个IP白名单和认证账户,更有IP管理、认证账户管理等功能。

优质大数据采集解决方案

高性价比的代理资源,为企业提供完善代理服务

静态住宅代理

99.9%正常稳定运行的长效住宅IP

50万+静态住宅

查看价格
  • 原生独享IP
  • 不限流量
  • 支持HTTP(S)/Socks5代理协议

动态住宅代理

便于大数据采集的高匿轮转住宅IP

60万+动态住宅IP

查看价格
  • 无限并发会话
  • 城市级精准定位
  • 流量不过期

常见应用场景

为跨境电商、社交媒体、网络安全、市场调研等行业提供专业的大数据采集解决方案

数据采集

轻松实现高效数据采集,提高工作效率和质量

SEO监测

实时掌握有关竞争性SEO实践和策略的数据

竞品追踪

及时获取新的竞品信息及定价数据

广告验证

保障产品在全球范围内的广告投放准确性

品牌保护

防止假冒伪劣品牌损害正品形象和利益

市场调查

收集市场真实有效数据,保持竞争优势

账号管理

创建和管理不同平台的账号,满足多任务需求

网络安全

避免遭受网络恶意攻击,保护隐私安全

网站测试

帮助测试网站参数,保障网站本地化

旅游聚合

获取优惠的机票酒店价格,节约旅游成本

多种代码轻松集成

各种常见的爬虫编程语言代码示例以及API参数注释确保您可以快速开始使用

// demo.cpp : 定义控制台应用程序的入口点。

#include "stdafx.h"
#include "curl/curl.h"
#pragma comment(lib, "libcurl.lib")

// 在CURLOPT_WRITEFUNCTION设置属性下,使用回调write_buff_data进行处理
static size_t write_buff_data(char *buffer, size_t size, size_t nitems, void *outstream) {
    memcpy(outstream, buffer, nitems * size);
    return nitems * size;
}

/*
 使用http代理
*/
int GetUrlHTTP(char *url, char *buff) {
    CURL *curl;
    CURLcode res;
    curl = curl_easy_init();
    if (curl) {
        curl_easy_setopt(curl, CURLOPT_PROXY, "http://代理服务器地址:端口"); // 设置代理
        curl_easy_setopt(curl, CURLOPT_WRITEDATA, (void*)buff); // void* buff 将会传递给回调函数write_buff_data的第四个参数 void* outstream
        curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, write_buff_data); // 在CURLOPT_WRITEFUNCTION设置属性下,使用回调write_buff_data进行处理
        curl_easy_setopt(curl, CURLOPT_URL, url); // 设置访问的域名

        res = curl_easy_perform(curl); // 执行请求
        if (res != CURLE_OK) {
            fprintf(stderr, "curl_easy_perform() failed: %s\n", curl_easy_strerror(res));
        }

        curl_easy_cleanup(curl); // 清理
    }
    return 0;
}

                
package main

import (
    "fmt"
    "io/ioutil"
    "net/http"
    "net/url"
)

func writeBuffData(data []byte, buff *[]byte) {
    *buff = append(*buff, data...)
}

func GetUrlHTTP(targetUrl string, proxyUrl string) ([]byte, error) {
    proxy, err := url.Parse(proxyUrl)
    if err != nil {
        return nil, fmt.Errorf("invalid proxy URL: %v", err)
    }

    transport := &http.Transport{
        Proxy: http.ProxyURL(proxy),
    }

    client := &http.Client{
        Transport: transport,
    }

    resp, err := client.Get(targetUrl)
    if err != nil {
        return nil, fmt.Errorf("failed to get URL: %v", err)
    }
    defer resp.Body.Close()

    body, err := ioutil.ReadAll(resp.Body)
    if err != nil {
        return nil, fmt.Errorf("failed to read response body: %v", err)
    }

    return body, nil
}

func main() {
    url := "http://example.com"
    proxy := "http://代理服务器地址:端口"

    data, err := GetUrlHTTP(url, proxy)
    if err != nil {
        fmt.Printf("Error: %v\n", err)
        return
    }

    fmt.Printf("Response: %s\n", data)
}
                
const http = require('http');
const https = require('https');
const url = require('url');

function getUrlHTTP(targetUrl, proxyUrl, callback) {
    const parsedUrl = url.parse(targetUrl);
    const parsedProxyUrl = url.parse(proxyUrl);

    const options = {
        hostname: parsedProxyUrl.hostname,
        port: parsedProxyUrl.port,
        path: targetUrl,
        headers: {
            Host: parsedUrl.hostname
        }
    };

    const protocol = parsedProxyUrl.protocol === 'https:' ? https : http;

    const req = protocol.request(options, (res) => {
        let data = '';

        res.on('data', (chunk) => {
            data += chunk;
        });

        res.on('end', () => {
            callback(null, data);
        });
    });

    req.on('error', (err) => {
        callback(err);
    });

    req.end();
}

const targetUrl = 'http://example.com';
const proxyUrl = 'http://代理服务器地址:端口';

getUrlHTTP(targetUrl, proxyUrl, (err, data) => {
    if (err) {
        console.error('Error:', err);
    } else {
        console.log('Response:', data);
    }
});
                
//
function getUrlHTTP($targetUrl, $proxyUrl) {
    $proxy = parse_url($proxyUrl);

    $contextOptions = [
        'http' => [
            'proxy' => sprintf('tcp://%s:%s', $proxy['host'], $proxy['port']),
            'request_fulluri' => true,
        ],
    ];

    $context = stream_context_create($contextOptions);
    $response = file_get_contents($targetUrl, false, $context);

    if ($response === false) {
        throw new Exception('Failed to get URL: ' . $targetUrl);
    }

    return $response;
}

try {
    $url = 'http://example.com';
    $proxy = 'http://代理服务器地址:端口';

    $data = getUrlHTTP($url, $proxy);
    echo "Response: " . $data . "\n";
} catch (Exception $e) {
    echo "Error: " . $e->getMessage() . "\n";
}

                
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.InetSocketAddress;
import java.net.Proxy;
import java.net.URL;

public class HttpClient {

    public static String getUrlHTTP(String targetUrl, String proxyUrl, int proxyPort) throws Exception {
        URL url = new URL(targetUrl);
        Proxy proxy = new Proxy(Proxy.Type.HTTP, new InetSocketAddress(proxyUrl, proxyPort));
        HttpURLConnection connection = (HttpURLConnection) url.openConnection(proxy);

        connection.setRequestMethod("GET");
        connection.connect();

        int responseCode = connection.getResponseCode();
        if (responseCode != 200) {
            throw new Exception("Failed to fetch URL: " + targetUrl + " with HTTP response code: " + responseCode);
        }

        BufferedReader in = new BufferedReader(new InputStreamReader(connection.getInputStream()));
        StringBuilder response = new StringBuilder();
        String inputLine;

        while ((inputLine = in.readLine()) != null) {
            response.append(inputLine);
        }
        in.close();

        return response.toString();
    }

    public static void main(String[] args) {
        try {
            String targetUrl = "http://example.com";
            String proxyUrl = "代理服务器地址";
            int proxyPort = 端口;

            String response = getUrlHTTP(targetUrl, proxyUrl, proxyPort);
            System.out.println("Response: " + response);
        } catch (Exception e) {
            System.err.println("Error: " + e.getMessage());
        }
    }
}
                
import requests
from requests.exceptions import RequestException

def get_url_http(target_url, proxy_url):
    proxies = {
        'http': proxy_url,
        'https': proxy_url,
    }

    try:
        response = requests.get(target_url, proxies=proxies)
        response.raise_for_status()  # Raise an HTTPError if the HTTP request returned an unsuccessful status code
        return response.text
    except RequestException as e:
        raise Exception(f"Failed to get URL: {target_url}, error: {e}")

if __name__ == "__main__":
    try:
        url = "http://example.com"
        proxy = "http://代理服务器地址:端口"

        data = get_url_http(url, proxy)
        print("Response:", data)
    except Exception as e:
        print("Error:", e)

                
from selenium import webdriver
from selenium.webdriver.chrome.service import Service
from selenium.webdriver.common.by import By
from selenium.webdriver.chrome.options import Options
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
from selenium.common.exceptions import TimeoutException

def get_url_http_with_selenium(target_url, proxy_url, proxy_port):
    # Set up Chrome options to use a proxy
    chrome_options = Options()
    chrome_options.add_argument(f'--proxy-server={proxy_url}:{proxy_port}')

    # Set up the WebDriver (you need to have chromedriver installed and in your PATH)
    service = Service('path/to/chromedriver')  # Update the path to your chromedriver
    driver = webdriver.Chrome(service=service, options=chrome_options)

    try:
        driver.get(target_url)

        # Wait for the page to load completely
        WebDriverWait(driver, 10).until(EC.presence_of_element_located((By.TAG_NAME, 'body')))

        # Get the page source
        page_source = driver.page_source
        return page_source
    except TimeoutException as e:
        raise Exception(f"Failed to load URL: {target_url}, error: {e}")
    finally:
        driver.quit()

if __name__ == "__main__":
    try:
        url = "http://example.com"
        proxy = "代理服务器地址"
        port = 端口

        data = get_url_http_with_selenium(url, proxy, port)
        print("Response:", data)
    except Exception as e:
        print("Error:", e)

                

免费定制专属解决方案

专享专享代理资源池
自定义IP时效,满足多种业务需求
高性价比价格,节约企业成本
技术团队全程监测,保障系统稳定运行
一对一客户服务,随时解决问题
开始定制

找IP吧注册

获取验证码

忘记密码

获取验证码