Quickstart
Make your first proxied request in under a minute.
-
Create an account and pick a plan
Sign up at shifter.io/order and choose a plan.
-
Grab your credentials
Open the client dashboard and copy your proxy username and password (or API key for the Scraping/SERP APIs). They look like:
Username: customer-USERNAMEPassword: 5f8a9c2b1d3e4f6g7h8iGateway: p.shifter.io:443 -
Send your first request
Route any HTTP call through the gateway. The username encodes your targeting:
Terminal window curl -x customer-USERNAME-country-us-sid-9f3a2b7c-ttl-600:PASSWORD@p.shifter.io:443 \https://ipinfo.io/jsonimport requestsproxy = "customer-USERNAME-country-us-sid-9f3a2b7c-ttl-600:PASSWORD@p.shifter.io:443"proxies = {"http": proxy, "https": proxy}r = requests.get("https://ipinfo.io/json", proxies=proxies)print(r.text)import fetch from 'node-fetch';import { HttpsProxyAgent } from 'https-proxy-agent';const agent = new HttpsProxyAgent('customer-USERNAME-country-us-sid-9f3a2b7c-ttl-600:PASSWORD@p.shifter.io:443');const res = await fetch('https://ipinfo.io/json', { agent });console.log(await res.text());import axios from 'axios';import { HttpsProxyAgent } from 'https-proxy-agent';const agent = new HttpsProxyAgent('customer-USERNAME-country-us-sid-9f3a2b7c-ttl-600:PASSWORD@p.shifter.io:443');const { data } = await axios.get<string>('https://ipinfo.io/json', {httpAgent: agent,httpsAgent: agent,});console.log(data);const fetch = require('node-fetch');const { HttpsProxyAgent } = require('https-proxy-agent');const agent = new HttpsProxyAgent('customer-USERNAME-country-us-sid-9f3a2b7c-ttl-600:PASSWORD@p.shifter.io:443');fetch('https://ipinfo.io/json', { agent }).then((r) => r.text()).then(console.log);package mainimport ("fmt""io""net/http""net/url")func main() {proxyURL, _ := url.Parse("customer-USERNAME-country-us-sid-9f3a2b7c-ttl-600:PASSWORD@p.shifter.io:443")client := &http.Client{Transport: &http.Transport{Proxy: http.ProxyURL(proxyURL)},}resp, _ := client.Get("https://ipinfo.io/json")defer resp.Body.Close()body, _ := io.ReadAll(resp.Body)fmt.Println(string(body))}use reqwest::blocking::Client;use reqwest::Proxy;fn main() -> Result<(), Box<dyn std::error::Error>> {let proxy = Proxy::all("http://p.shifter.io:443")?.basic_auth("customer-USERNAME-country-us-sid-9f3a2b7c-ttl-600", "PASSWORD");let client = Client::builder().proxy(proxy).build()?;let body = client.get("https://ipinfo.io/json").send()?.text()?;println!("{body}");Ok(())}import java.net.*;import java.net.http.*;public class Main {public static void main(String[] args) throws Exception {HttpClient client = HttpClient.newBuilder().proxy(ProxySelector.of(new InetSocketAddress("p.shifter.io", 443))).authenticator(new Authenticator() {protected PasswordAuthentication getPasswordAuthentication() {return new PasswordAuthentication("customer-USERNAME-country-us-sid-9f3a2b7c-ttl-600","PASSWORD".toCharArray());}}).build();HttpRequest req = HttpRequest.newBuilder(URI.create("https://ipinfo.io/json")).build();HttpResponse<String> res = client.send(req, HttpResponse.BodyHandlers.ofString());System.out.println(res.body());}}using System.Net;using System.Net.Http;var handler = new HttpClientHandler{Proxy = new WebProxy("http://p.shifter.io:443"){Credentials = new NetworkCredential("customer-USERNAME-country-us-sid-9f3a2b7c-ttl-600","PASSWORD")},UseProxy = true};using var client = new HttpClient(handler);var ip = await client.GetStringAsync("https://ipinfo.io/json");Console.WriteLine(ip);<?phprequire 'vendor/autoload.php';$client = new GuzzleHttp\Client(['proxy' => 'customer-USERNAME-country-us-sid-9f3a2b7c-ttl-600:PASSWORD@p.shifter.io:443',]);$res = $client->get('https://ipinfo.io/json');echo $res->getBody(); -
Target a country, session, or ISP
Use parameters to control geo, session, and routing:
Parameter Example Effect country-XXcustomer-USERNAME-country-deRoute through Germany region-NAMEcustomer-USERNAME-region-californiaTarget a specific region/state city-NAMEcustomer-USERNAME-city-new_yorkTarget a specific city asn-NUMBERcustomer-USERNAME-asn-7922Target a specific ASN sid-IDcustomer-USERNAME-sid-abcSticky session (same IP held for the default TTL of 120s) ttl-SECONDScustomer-USERNAME-sid-abc-ttl-600Custom TTL in seconds for the sticky session (requires sid)strict-truecustomer-USERNAME-country-us-strict-trueFail with 502 instead of falling back to a broader pool
What’s next
Section titled “What’s next”- Authentication - API keys vs. username/password
- Choosing a product - pick the right Shifter product
- API Reference - every REST endpoint, every parameter