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.
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.
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.
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.
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.
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.
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.
--insecure
parameter in curl
.To use Bot Anti-Detect Mode, the client application must allow insecure connections. Follow these steps to configure it:
curl --proxy x.botproxy.net:8080 --insecure "https://example.com"
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.
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.
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
+CN
suffix to login. For example to limit outgoing locations to US only use pxu1000-0+US
as your proxy user login+loc
suffix: use pxu1000-0+us-fl
as your proxy usernamepxu1000-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"
Currently we have proxy peers in datacenters in the following locations:
Location | Code | Country Code |
---|---|---|
Sydney, Australia | au-syd | AU |
Toronto, Canada | ca-to | CA |
Frankfurt, Germany | de-fra | DE |
Madrid, Spain | es-mad | ES |
Paris, France | fr-par | FR |
Bangalore, India | in-bg | IN |
Amsterdam, Netherlands | nl-am | NL |
Singapore, Singapore | sg-sg | SG |
London, United Kingdom | uk-lon | UK |
US Central, Iowa, USA | us-io | US |
US East, New York, USA | us-ny | US |
US West, San Francisco, USA | us-ca | US |
Open Proxies (~1000 IPs, various countries) | xo | XO |
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.
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:
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.
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:
Header | Description | Values |
---|---|---|
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]
Proxy can respond only with the following error codes. All other codes are returned from the website you are connecting to:
HTTP status | Message | Comment |
---|---|---|
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. |
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).
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:
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.
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.
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.
Requests and data are encrypted all the way through. Most secure option.