Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/oxylabs/puppeteer-proxy-integration-js

A tutorial for implementing Oxylabs` Residential and Datacenter proxies with Puppeteer using JavaScript
https://github.com/oxylabs/puppeteer-proxy-integration-js

github-proxy-list headless javascript nodejs proxy proxy-list proxy-list-github proxy-rotator proxy-site puppeteer puppeteer-demo residential-proxy rotating-proxy socks5-proxy-list socks5-server socks5-server-java webproxy

Last synced: 2 months ago
JSON representation

A tutorial for implementing Oxylabs` Residential and Datacenter proxies with Puppeteer using JavaScript

Awesome Lists containing this project

README

        

# Oxylabs' Proxy Integration with Puppeteer

[![Oxylabs promo code](https://user-images.githubusercontent.com/129506779/250792357-8289e25e-9c36-4dc0-a5e2-2706db797bb5.png)](https://oxylabs.go2cloud.org/aff_c?offer_id=7&aff_id=877&url_id=112)

[![](https://dcbadge.vercel.app/api/server/eWsVUJrnG5)](https://discord.gg/GbxmdGhZjq)

[](https://github.com/topics/javascript) [](https://github.com/topics/web-scraping) [](https://github.com/topics/rotating-proxies)
- [Requirements](#requirements)
- [Integrating Datacenter Proxies](#integrating-datacenter-proxies)
- [Integrating Residential Proxies](#integrating-residential-proxies)
## Requirements

### Puppeteer
```bash
npm install puppeteer
```

## Integrating Datacenter Proxies

### Getting a List of Proxies

Open the following URL in the browser and enter your credentials. You will see a list of proxies in plain text:

```
https://proxy.oxylabs.io/all
```

### Using Proxies

If you wish to select any of the provided proxies, save the proxy IP, along with the port in a variable.

To use all these proxies, first, save these proxies as an array in your code:

```javascript
let proxies = [
'127.0.0.1:60000',
'127.0.0.2:60000',
'127.0.0.3:60000',
'127.0.0.4:60000'
]
```

To select one of these proxies randomly, use the following line of code:

```JavaScript
var proxy = proxies[Math.floor(Math.random() * proxies.length)];
```

The proxy server you will use needs to be supplied as `--proxy-server` argument.

Create a variable that can contain all the arguments in an array.

Additionally, `launchOptions` can also contain other information, such as `headless` mode as following:

```JavaScript
const launchOptions = {
// Set the proxy server to the server variable
args: ['--proxy-server=' + proxy],

// Set additional launch options here
headless: false
};
```

After creating the `launchOptions` variable, create a `puppeteer` instance and launch the browser.

```javascript
const browser = await puppeteer.launch(launchOptions);
```

Finally, to authenticate using your credentials, call the `page.authenticate` function after creating a `page`.

```javascript
// Create a new page
const page = await browser.newPage();

// Set the username and password provided by Oxylabs
await page.authenticate({
username: 'USERNAME',
password: 'PASSWORD'
});
```

For the complete code sample, see [this file](datacenter_random.js).

## Integrating Residential Proxies

### Random Proxy Using the Proxy API
To get a random proxy, use the proxy server `pr.oxylabs.io:7777`.

As mentioned above, the proxy server you will use needs to be supplied as `--proxy-server` argument.

Create a variable that can contain all the arguments in an array.

Additionally, `launchOptions` can also contain other information, such as `headless` mode as following:

```JavaScript
const launchOptions = {
// Set the proxy server to the server variable
args: ['--proxy-server=pr.oxylabs.io:7777']
};
```

After creating the `launchOptions` variable, create a `puppeteer` instance and launch the browser.

```javascript
const browser = await puppeteer.launch(launchOptions);
```

Finally, to authenticate using your credentials, call the `page.authenticate` function after creating a `page`.

```javascript
// Create a new page
const page = await browser.newPage();

// Set the username and password provided by Oxylabs
await page.authenticate({
username: 'USERNAME',
password: 'PASSWORD'
});
```

For the complete code sample, see [this file](residential_random.js).

### Country Specific Proxies

If you wish to use country-specific proxies, all you need to do is change the `proxy` server.

For example, if you want to use a proxy for the United States, you can use the following code:

```javascript
const launchOptions = {
args: ['--proxy-server=us-pr.oxylabs.io:10001']
};

```

In this example, `us-pr.oxylabs.io:10000` is the country specific entry point for the United States.

Another example is `gb-pr.oxylabs.io:20000`, which is the country specific entry point for the United Kingdom.

For a complete list of all entry points, see [Country Specific Entry Nodes](https://oxy.yt/KrKF)