Overview

BotProxy is a powerful proxy server specifically designed for web scraping and bot automation. With advanced anti-detection capabilities and real-time IP rotation, it allows you to gather data seamlessly while minimizing the risk of bans. BotProxy provides access to a global network of proxies in geographically diverse locations, ensuring high performance and fresh IPs for every session.

Its streamlined integration process allows you to set up in minutes, making it compatible with any application supporting proxies. Ideal for developers and businesses, BotProxy ensures fast, reliable, and secure connections for large-scale data extraction and automated tasks.

By just configuring a single proxy server in your application, BotProxy automatically handles IP rotation and distribution, routing your requests through a network of proxies in real-time. This eliminates the need to manage proxy lists manually or worry about session persistence.

BotProxy’s scraping-optimized features include precise session control, custom location targeting, and support for concurrent connections, making it ideal for gathering data from multiple sources simultaneously. With a focus on reliability, speed, and ethical practices, BotProxy ensures your web scraping and automation projects run smoothly without interruptions.

Quick Start

Select your programming language to see how to integrate BotProxy into your application. Each request should be authenticated by login and password or by whitelisting origin IP address (see Authentication section below). In the examples below Bot Anti-Detect Mode is enabled so your client should be configured to accept insecure certificates.

With Bot Anti-Detect Mode Enabled:


curl --insecure --proxy x.botproxy.net:8080 --proxy-user user-key:key-password "https://httpbin.org/ip"
              

Normal proxy mode:


curl --proxy x.botproxy.net:8080 --proxy-user user-key:key-password "https://httpbin.org/ip"
              

package example

import (
	"crypto/tls"
	"encoding/base64"
	"fmt"
	"io/ioutil"
	"net/http"
	"net/url"
)

func basicAuth(username, password string) string {
	auth := username + ":" + password
	return base64.StdEncoding.EncodeToString([]byte(auth))
}

func main() {
	// Configure the transport to accept insecure certificates
	tr := &http.Transport{
		Proxy: func(req *http.Request) (*url.URL, error) {
			return url.Parse("http://x.botproxy.net:8080") // For secure proxy: url.Parse("https://x.botproxy.net:8443")
		},
		TLSClientConfig: &tls.Config{InsecureSkipVerify: true}, // Skip SSL certificate verification
	}

	client := &http.Client{Transport: tr}
	req, _ := http.NewRequest("GET", "https://httpbin.org/ip", nil)
	req.Header.Add("Proxy-Authorization", "Basic "+basicAuth("pxu10000-0", "ProxyUser_password"))

	res, err := client.Do(req)
	if err != nil {
		fmt.Println("HTTP error: ", err)
		return
	}

	defer res.Body.Close()
	page, _ := ioutil.ReadAll(res.Body)
	fmt.Println(string(page))
}
              

#!/usr/bin/env node
const request = require('request-promise');

// Configure the request with the proxy and disable SSL verification
const options = {
    url: 'https://httpbin.org/ip',
    proxy: 'http://user-key:[email protected]:8080',
    strictSSL: false // Disable SSL certificate verification
};

// Send the request
request(options)
    .then(function (data) {
        console.log(data);
    })
    .catch(function (err) {
        console.error(err);
    });
              

Bot Anti-Detect Mode Enabled:


package example;

import org.apache.http.HttpHost;
import org.apache.http.client.fluent.Executor;
import org.apache.http.client.fluent.Request;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.impl.conn.DefaultProxyRoutePlanner;
import org.apache.http.conn.ssl.NoopHostnameVerifier;
import org.apache.http.conn.ssl.TrustAllStrategy;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.ssl.SSLContextBuilder;

public class Example {
    public static void main(String[] args) throws Exception {
        // Create an SSLContext that accepts all certificates
        CloseableHttpClient httpClient = HttpClientBuilder.create()
            .setSSLContext(new SSLContextBuilder().loadTrustMaterial(null, TrustAllStrategy.INSTANCE).build())
            .setSSLHostnameVerifier(NoopHostnameVerifier.INSTANCE)
            .build();

        HttpHost proxy = new HttpHost("x.botproxy.net", 8080);

        // Set up the proxy
        DefaultProxyRoutePlanner routePlanner = new DefaultProxyRoutePlanner(proxy);

        // Configure the executor with the custom HttpClient
        Executor executor = Executor.newInstance(httpClient)
            .auth(proxy, "user-key", "key-password");

        // Execute the request via the proxy
        String res = executor.execute(
                Request.Get("https://httpbin.org/ip").viaProxy(proxy))
            .returnContent()
            .asString();

        System.out.println(res);
    }
}
              

Normal proxy mode:


package example;

import org.apache.http.HttpHost;
import org.apache.http.client.fluent.*;

public class Example {
  public static void main(String[] args) throws Exception {
    HttpHost proxy = new HttpHost("x.botproxy.net", 8080);
    String res = Executor.newInstance()
      .auth(proxy, "user-key", "key-password")
      .execute(Request.Get("https://httpbin.org/ip").viaProxy(proxy))
      .returnContent().asString();
    System.out.println(res);
  }
}
              

Bot Anti-Detect Mode Enabled:


using System;
using System.Net;
using System.Net.Security;
using System.Security.Cryptography.X509Certificates;

class Example
{
    static void Main()
    {
        // Bypass SSL certificate validation
        ServicePointManager.ServerCertificateValidationCallback = new RemoteCertificateValidationCallback(
            delegate { return true; });

        var client = new WebClient();
        client.Proxy = new WebProxy("x.botproxy.net:8080");
        client.Proxy.Credentials = new NetworkCredential("user-key", "key-password");

        try
        {
            string response = client.DownloadString("https://httpbin.org/ip");
            Console.WriteLine(response);
        }
        catch (Exception ex)
        {
            Console.WriteLine("Error: " + ex.Message);
        }
    }
}
              

Normal proxy mode:


using System;
using System.Net;

class Example
{
  static void Main()
  {
    var client = new WebClient();
    client.Proxy = new WebProxy("x.botproxy.net:8080");
    client.Proxy.Credentials = new NetworkCredential("user-key", "key-password");
    Console.WriteLine(client.DownloadString("https://httpbin.org/ip"));
  }
}
              

Bot Anti-Detect Mode Enabled:


Imports System.Net
Imports System.Net.Security
Imports System.Security.Cryptography.X509Certificates

Module Example
    Sub Main()
        ' Bypass SSL certificate validation
        ServicePointManager.ServerCertificateValidationCallback = New RemoteCertificateValidationCallback(Function(sender, certificate, chain, sslPolicyErrors) True)

        Dim Client As New WebClient
        Client.Proxy = New WebProxy("http://x.botproxy.net:8080")
        Client.Proxy.Credentials = New NetworkCredential("user-key", "key-password")

        Try
            Dim response As String = Client.DownloadString("https://httpbin.org/ip")
            Console.WriteLine(response)
        Catch ex As Exception
            Console.WriteLine("Error: " & ex.Message)
        End Try
    End Sub
End Module
              

Normal proxy mode:


Imports System.Net

Module Example
Sub Main()
Dim Client As New WebClient
Client.Proxy = New WebProxy("http://x.botproxy.net:8080")
Client.Proxy.Credentials = New NetworkCredential("user-key", "key-password")
Console.WriteLine(Client.DownloadString("https://httpbin.org/ip"))
End Sub
End Module
              

<?php
$curl = curl_init('https://httpbin.org/ip');
curl_setopt($curl, CURLOPT_PROXY, 'http://x.botproxy.net:8080');
curl_setopt($curl, CURLOPT_PROXYUSERPWD, 'user-key:key-password');
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false); // Disable SSL certificate verification
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false); // Ignore host verification
curl_exec($curl);
curl_close($curl); // Close the cURL session
?>
              

Standard Library example


#!/usr/bin/env python
import urllib.request
import ssl

# Create an SSL context that bypasses certificate verification
ssl_context = ssl.create_default_context()
ssl_context.check_hostname = False
ssl_context.verify_mode = ssl.CERT_NONE

# Create an opener with the proxy handler and SSL context
opener = urllib.request.build_opener(
    urllib.request.ProxyHandler(
        {
            'http': 'http://user-key:[email protected]:8080',
            'https': 'http://user-key:[email protected]:8080'
        }
    ),
    urllib.request.HTTPSHandler(context=ssl_context)  # Use the insecure SSL context
)

# Open the URL and print the response
response = opener.open('https://httpbin.org/ip').read()
print(response.decode('utf-8'))
              

Using python requests


import requests

res = requests.get(
    'https://httpbin.org/ip',  # Updated to use HTTPS
    proxies={
        'http': 'http://user-key:[email protected]:8080',
        'https': 'http://user-key:[email protected]:8080',
    },
    verify=False  # Disable SSL certificate verification
)

print(res.text)
              

#!/usr/bin/ruby

require 'uri'
require 'net/http'

uri = URI.parse('https://httpbin.org/ip')
proxy = Net::HTTP::Proxy('x.botproxy.net', 8080, 'user-key', 'key-password')

# Create an insecure SSL context
http = proxy.new(uri.host, uri.port)
http.use_ssl = true
http.verify_mode = OpenSSL::SSL::VERIFY_NONE # Disable SSL verification

req = Net::HTTP::Get.new(uri)

result = http.start do |http|
  http.request(req)
end

puts result.body
              

#!/usr/bin/perl
use LWP::UserAgent;
use IO::Socket::SSL;

# Disable SSL verification
$ENV{PERL_LWP_SSL_VERIFY_HOSTNAME} = 0;
IO::Socket::SSL::set_defaults(SSL_verify_mode => IO::Socket::SSL::SSL_VERIFY_NONE);

my $agent = LWP::UserAgent->new();
$agent->proxy(['http', 'https'], "http://user-key:key-password\@x.botproxy.net:8080");

my $response = $agent->get('https://httpbin.org/ip');

if ($response->is_success) {
    print $response->content();
} else {
    die "HTTP request failed: ", $response->status_line;
}
              

Make sure to disable Bot Anti-Detect Mode on your proxy user prior to configuring proxy in your browsers.

  1. Click the Chrome menu on the browser toolbar.
  2. Select "Settings".
  3. Click "Show advanced settings".
  4. In the "Network" section, click "Change proxy settings".
  5. Click "LAN settings".
  6. Select the "Use a proxy server for your LAN" check box.
  7. Enter "Address": x.botproxy.net
  8. Enter "Port": 8080
  9. Save changes by pressing "OK"

Authentication

Our proxies require authentication with each request. You need to provide proxy user login and password or whitelist your server IP addresses. These are not the login and password you used to sign up on our service. Proxy user login starts with pxu and looks like pxu1000-0.

You can find your proxy user credentials on your account page. Click on edit user button to access proxy user settings form where you can change password or whitelist IPs.

IP Rotation

Each request you make goes through our superproxy you connect to (x.botproxy.net or x1.botproxy.net) and one of the outgoing peer nodes. Superproxy selects outgoing peer randomly from the pool available to your account. Selected peer is stored in session and can be reused in next requests. Once the session expires (default is 60 seconds) a new session is started and a new IP address is selected. In addition to that all peers change their IPs at least every 24 hours or more often.

You can change maximum session age in proxy user details form to adjust for longer or shorter sessions. You can start a new session with each request to change IP every time, but we do not recommend doing so. Read more about session management in detail below.

Limitations

Our proxies are not designed to query a single website on a high volume or request rate. To ensure ethical use We limit request rate to a single website and block certain ports to prevent overloading of websites, sending spam or other illegal activity.

Please also check out Acceptable Use Policy. We ask that you not engage in prohibited activity on our network.

Demo Screencast

Watch the screencast to get the idea of using BotProxy username API to control your outgoing IP address. Please note that control headers are not supported anymore.

Bot Anti-Detect Mode

Overview

BotProxy’s Bot Anti-Detect Mode is a powerful feature designed to enhance anonymity and evade detection by anti-bot systems on target websites making web scraping easier. This mode works by spoofing TLS fingerprints, mimicking those of a Chrome browser on an Android phone, ensuring that bot detection mechanisms cannot differentiate your web scraping requests from legitimate ones.

TLS fingerprinting involves analyzing the unique characteristics of a device’s TLS handshake during secure connections. These characteristics, such as supported protocols, cipher suites, and extensions, create a unique signature. Anti-bot systems use these signatures to identify and block automated traffic.

How It Works

  1. TLS Spoofing:
    • BotProxy’s superproxy intercepts outgoing TLS connections from your application.
    • It modifies the TLS fingerprint to match the signature of a Chrome browser running on an Android phone.
    • This makes your web scraping requests indistinguishable from those of legitimate mobile users.
  2. MITM Proxy Mechanism:
    • Bot Anti-Detect Mode functions as a man-in-the-middle (MITM) proxy.
    • The superproxy establishes a secure TLS connection with the target website on behalf of the client and relays requests and responses between the two.
    • For this to work, clients must configure their software to operate in insecure mode, such as using the --insecure parameter in curl.
  3. Default Enabled:
    • The Bot Anti-Detect Mode is enabled by default for all proxy users.
    • Users can toggle this feature in the proxy user form in the account console.
    • Disable it to use regular proxy behavior without TLS fingerprint spoofing.

Configuring Insecure Mode

To use Bot Anti-Detect Mode, the client application must allow insecure connections. Follow these steps to configure it:

  1. Modify Client Settings:
    • Update your client software to accept insecure connections.
    • For example, when using curl, add the --insecure parameter to your request: curl --proxy x.botproxy.net:8080 --insecure "https://example.com"
  2. Test the Connection:
    • Run a test request through the proxy to ensure the client is correctly configured to bypass certificate validation.

Limitations and Considerations

Compatibility: Some applications or libraries may have issues operating in insecure mode. Verify compatibility before enabling this mode.

Performance Impact: The MITM mechanism may introduce slight latency due to additional processing.

By leveraging the Bot Anti-Detect Mode, you can significantly enhance your web scraping scripts and reduce the likelihood of detection, allowing for seamless operation even in environments with strict anti-bot defenses.

Advanced Topics

Country and Location selection

By default we create a proxy user that has access to all locations available to your account except for OpenProxies. You can limit the locations using proxy user details form. Enter a comma separated list of location codes you want to use. For example if you want to make requests only from US locations enter us-ny,us-io,us-ca. To allow all locations except some add a minus sign in front of locations list. For example to exclude OpenProxies locations enter -xo.

You can have multiple proxy users on your account each with different available locations and other params.

There is also the possibility to adjust the country and location on each request. Read the Username API section for more details.

Username API

We provide username API to control outgoing locations using only proxy authentication credentials. To achieve this you should add special suffixes to your proxy user login as follows. Let assume your proxy user login is pxu1000-0

  • Specify COUNTRY by adding +CN suffix to login. For example to limit outgoing locations to US only use pxu1000-0+US as your proxy user login
  • Specify LOCATION by adding +loc suffix: use pxu1000-0+us-fl as your proxy username
  • Add SESSION identifier to country or location by adding one more suffix as follows: pxu1000-0+US+SESSIONID or pxu1000-0+us-fl+SESSIONID. If you do not want to limit country or location but want to use session leave country/location blank and specify session as follows: pxu1000-0++SESSIONID

The complete usage example to route outgoing traffic through US locations only and within session 123456 is:


$ curl --proxy x.botproxy.net:8080 --proxy-user "pxu1000-0+us+123456:password" "https://httpbin.org/ip"
      

Locations

Currently we have proxy peers in datacenters in the following locations:

LocationCodeCountry Code
Sydney, Australiaau-sydAU
Toronto, Canadaca-toCA
Frankfurt, Germanyde-fraDE
Madrid, Spaines-madES
Paris, Francefr-parFR
Bangalore, Indiain-bgIN
Amsterdam, Netherlandsnl-amNL
Singapore, Singaporesg-sgSG
London, United Kingdomuk-lonUK
US Central, Iowa, USAus-ioUS
US East, New York, USAus-nyUS
US West, San Francisco, USAus-caUS
Open Proxies (~1000 IPs, various countries)xoXO

You can find a list of locations available according with your current subscription in your account page as well as all current proxy IP addresses for each location.

Sessions: IP persistence

In many cases you may want to run several parallel sessions from the same client, use different outgoing IP per session, and be able to change them when needed. This can be done by utilizing sessions. Sessions provide you fine grained control over outgoing IP addresses.

Each request going through a proxy uses a session. Even when you do not provide session ID a so called default session is used. Session is a combination of proxy user login, country or location and a session ID. Only proxy user login is required, if other parameters are not provided they are added as blank strings to create internal session identifier in superproxy. Sessions are not shared between superproxies. Each session has an IP address. IP address is assigned to a session on session creation and does not change during session lifetime. Until you keep using the session and it is valid, the IP address stays the same.

Sessions has a maximum session age that can be set for each proxy user separately in user details form. When a session gets older it is invalidated and even if you provide the same location and session ID a new session with a new IP is created. You can set maximum session age to 0 to remove session age limit restriction. All sessions are invalidated after 5 minutes of inactivity.

Summary:

  1. IP is persistent within one Session until session Age Limit is reached.
  2. Session is login+country or location+session_id
  3. Each time Session is created a new IP is assigned as follows:
    • We take all IP addresses available to your proxy user (considering Limit Locations user settings)
    • Filter IPs to match requested country or location
    • Randomly select IP address from the remaining IPs
  4. When session age limit is reached IP is renewed
  5. If session is not used for 5 minutes it is deleted

Generate the random number on thread startup, and change it when you want to change the proxy peer assigned for the thread connection. Session ID can be any random string/counter: requests with the same session will use the same proxy peer (as long as possible).

To force an IP change, just modify the session ID.

HTTP Headers

We return outgoing proxy IP address in HTTP response headers. For HTTPS requests response headers are added immediately after HTTP/1.1 200 Connection established response from proxy:

HeaderDescriptionValues
Response headers
X-PROXY-IP IP address of the outgoing proxy server. This is the address that a remote website sees when processing your requests through botproxy. IPv4 or IPv6 Address

CONNECT httpbin.org:443 HTTP/1.1
Proxy-Authorization: Basic bG90...

HTTP/1.0 200 Connection established
X-RPOXY-IP: xx.xx.xx.xx
[encrypted data]
      

Errors

Proxy can respond only with the following error codes. All other codes are returned from the website you are connecting to:

HTTP statusMessageComment
407 Basic Authentication Required
Invalid Basic Auth
You did not provide authentication data or provided data does not conform to Basic authentication schema format
401 Access Denied on Proxy
Login or Password are incorrect or user does not exist.
402 Access Suspended
Access suspended. Please check your account dashboard for more information. You may exhausted your plan quota or there are some other issues with your account.
502 Peer Error
Connection error to destination host from peer node. Additional details are provided with the error message.
504 Timeout waiting host connect slot
We are limiting requests to a destination host from peer nodes. If there are too many requests they are waiting in a queue up to 60 seconds.
520 Error connecting upstream proxy
No proxy available
Superproxy monitors health and connectivity of outgoing peers and automatically retry connection up to 3 different nodes in case of connection errors. If all 3 requests in a row fail you will get the "error connecting to upstream" proxy message.
No proxy available in the location/country you specified. You may see such error when requesting OpenProxies locations or in other cases when superproxy cannot connect to peer node if failover is not enabled for your proxy user.
515 Internal Proxy Error
Something bad happened. Most likely we already investigating the issue. Subscribe to our status page to get actual information.
555 Cannot parse destination host
Cannot parse destination port
This port is blacklisted
This site is blacklisted
You have provided incorrect host address, invalid port or connecting to blacklisted website or port.

Open Proxies

We maintain a list of known open proxy servers. If you choose "OpenProxies" location your request will be routed through one of these proxies. Your requests are forwarded through less reliable & higher latency servers. Open proxies IPs are located in many different countries around the world. These open proxy IPs typically do not stay online very long, and are not operated on reliable infrastructure. The tradeoff for this lack of reliability is a huge increase in quantity & variability of IP addresses.

The list is regularly updated and contains around 1000 working IP addresses around the world. If any request through an open proxy fails due to a proxy error, that error is recorded, and the request is re-tried up to 3 more times, using a different proxy for each retry. Failed proxy is immediately removed from the list.

By default Open Proxies location is disabled on a proxy user. You need to manually enable it in your account dashboard.

OpenProxies location code is xo. You can additionally specify the desired country by adding 2 letter ISO country code after a minus sign: xo-us (example location code for US).

Secure Proxy (HTTPS/SSL)

A secure web proxy is a web proxy that the browser (or your other software) communicates with via encrypted connection, as opposed to clear text. In insecure public networks, such as airports or cafes, browsing over HTTP may leave the user vulnerable to cookie stealing, session hijacking or worse. A secure web proxy can add a significant layer of defense in these cases. Diagrams below explain different scenarios in detail. Please note: not all clients (browsers) support secure proxies. Refer your client documentation and set HTTPS proxy as needed.

We provide a secure proxy at the following address: x.botproxy.net:8443 You can connect using the same proxy users.

To use secure proxy in your applications you need to first establish a TLS connection to our secure proxy and then initiate regular HTTP proxy connection over established encrypted connection. Some other programs and libraries have built in support for secure proxies such as curl or Go http client.

Find below an explanation of how requests go when using different kind of proxies:

HTTP request using HTTP proxy

path of HTTP request through HTTP Proxy

In this case request is sent from your client in plain text thus allowing your local network administrator or an attacker to intercept it and access all the data being sent. This is the least secure option.

HTTPS request using HTTP proxy

path of HTTPS request through HTTP Proxy

Target host name alongside your BotProxy proxy user credentials are transferred in plain text. Your client requests to create a tunnel to the specific host and port with CONNECT command and then makes secure communication via this tunnel. Parties on local network cannot intercept or hijack any data being transferred between you and remote host.

HTTP request using Secure (HTTPS) proxy

path of HTTP request through HTTPS Proxy

In this case your client establishes secure connection with our proxy server and no one can know what data is being transferred between you and target host. Moreover nobody in local network can know what is the target host. Even though the target host can be accessed using plain text HTTP protocol.

HTTPS request using Secure (HTTPS) proxy

path of HTTPS request through HTTPS Proxy

Requests and data are encrypted all the way through. Most secure option.

Web Scraping Knowledge Base