You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					258 lines
				
				7.4 KiB
			
		
		
			
		
	
	
					258 lines
				
				7.4 KiB
			| 
								 
											3 years ago
										 
									 | 
							
								# socks examples
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								## Example for SOCKS 'connect' command
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								The connect command is the most common use-case for a SOCKS proxy. This establishes a direct connection to a destination host through a proxy server. The destination host only has knowledge of the proxy server connecting to it and does not know about the origin client (you).
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								**Origin Client (you) <-> Proxy Server <-> Destination Server**
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								In this example, we are connecting to a web server on port 80, and sending a very basic HTTP request to receive a response. It's worth noting that there are many socks-http-agents that can be used with the node http module (and libraries such as request.js) to make this easier. This HTTP request is used as a simple example.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								The 'connect' command can be used via the SocksClient.createConnection() factory function as well as by creating a SocksClient instance and using event handlers.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								### Using createConnection with async/await
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Since SocksClient.createConnection returns a Promise, we can easily use async/await for flow control.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```typescript
							 | 
						||
| 
								 | 
							
								const SocksClient = require('socks').SocksClient;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const options  = {
							 | 
						||
| 
								 | 
							
								  proxy: {
							 | 
						||
| 
								 | 
							
								    host: '104.131.124.203',
							 | 
						||
| 
								 | 
							
								    port: 1081,
							 | 
						||
| 
								 | 
							
								    type: 5
							 | 
						||
| 
								 | 
							
								  },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  destination: {
							 | 
						||
| 
								 | 
							
								    host: 'ip-api.com', // host names are supported with SOCKS v4a and SOCKS v5.
							 | 
						||
| 
								 | 
							
								    port: 80
							 | 
						||
| 
								 | 
							
								  },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  command: 'connect'
							 | 
						||
| 
								 | 
							
								};
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								async function start() {
							 | 
						||
| 
								 | 
							
								  try {
							 | 
						||
| 
								 | 
							
								    const info = await SocksClient.createConnection(options);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    console.log(info.socket);
							 | 
						||
| 
								 | 
							
								    // <Socket ...>  (this is a raw net.Socket that is established to the destination host through the given proxy servers)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    info.socket.write('GET /json HTTP/1.1\nHost: ip-api.com\n\n');
							 | 
						||
| 
								 | 
							
								    info.socket.on('data', (data) => {
							 | 
						||
| 
								 | 
							
								      console.log(data.toString()); // ip-api.com sees that the last proxy (104.131.124.203) is connected to it and not the origin client (you).
							 | 
						||
| 
								 | 
							
								      /*
							 | 
						||
| 
								 | 
							
								        HTTP/1.1 200 OK
							 | 
						||
| 
								 | 
							
								        Access-Control-Allow-Origin: *
							 | 
						||
| 
								 | 
							
								        Content-Type: application/json; charset=utf-8
							 | 
						||
| 
								 | 
							
								        Date: Sun, 24 Dec 2017 03:47:51 GMT
							 | 
						||
| 
								 | 
							
								        Content-Length: 300
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        {
							 | 
						||
| 
								 | 
							
								          "as":"AS14061 Digital Ocean, Inc.",
							 | 
						||
| 
								 | 
							
								          "city":"Clifton",
							 | 
						||
| 
								 | 
							
								          "country":"United States",
							 | 
						||
| 
								 | 
							
								          "countryCode":"US",
							 | 
						||
| 
								 | 
							
								          "isp":"Digital Ocean",
							 | 
						||
| 
								 | 
							
								          "lat":40.8326,
							 | 
						||
| 
								 | 
							
								          "lon":-74.1307,
							 | 
						||
| 
								 | 
							
								          "org":"Digital Ocean",
							 | 
						||
| 
								 | 
							
								          "query":"104.131.124.203",
							 | 
						||
| 
								 | 
							
								          "region":"NJ",
							 | 
						||
| 
								 | 
							
								          "regionName":"New Jersey",
							 | 
						||
| 
								 | 
							
								          "status":"success",
							 | 
						||
| 
								 | 
							
								          "timezone":"America/New_York",
							 | 
						||
| 
								 | 
							
								          "zip":"07014"
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								      */
							 | 
						||
| 
								 | 
							
								  } catch (err) {
							 | 
						||
| 
								 | 
							
								    // Handle errors
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								start();
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								### Using createConnection with Promises
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```typescript
							 | 
						||
| 
								 | 
							
								const SocksClient = require('socks').SocksClient;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const options  = {
							 | 
						||
| 
								 | 
							
								  proxy: {
							 | 
						||
| 
								 | 
							
								    ipaddress: '104.131.124.203',
							 | 
						||
| 
								 | 
							
								    port: 1081,
							 | 
						||
| 
								 | 
							
								    type: 5
							 | 
						||
| 
								 | 
							
								  },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  destination: {
							 | 
						||
| 
								 | 
							
								    host: 'ip-api.com', // host names are supported with SOCKS v4a and SOCKS v5.
							 | 
						||
| 
								 | 
							
								    port: 80
							 | 
						||
| 
								 | 
							
								  },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  command: 'connect'
							 | 
						||
| 
								 | 
							
								};
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								SocksClient.createConnection(options)
							 | 
						||
| 
								 | 
							
								.then(info => {
							 | 
						||
| 
								 | 
							
								  console.log(info.socket);
							 | 
						||
| 
								 | 
							
								  // <Socket ...>  (this is a raw net.Socket that is established to the destination host through the given proxy servers)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  info.socket.write('GET /json HTTP/1.1\nHost: ip-api.com\n\n');
							 | 
						||
| 
								 | 
							
								  info.socket.on('data', (data) => {
							 | 
						||
| 
								 | 
							
								    console.log(data.toString()); // ip-api.com sees that the last proxy (104.131.124.203) is connected to it and not the origin client (you).
							 | 
						||
| 
								 | 
							
								    /*
							 | 
						||
| 
								 | 
							
								      HTTP/1.1 200 OK
							 | 
						||
| 
								 | 
							
								      Access-Control-Allow-Origin: *
							 | 
						||
| 
								 | 
							
								      Content-Type: application/json; charset=utf-8
							 | 
						||
| 
								 | 
							
								      Date: Sun, 24 Dec 2017 03:47:51 GMT
							 | 
						||
| 
								 | 
							
								      Content-Length: 300
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      {
							 | 
						||
| 
								 | 
							
								        "as":"AS14061 Digital Ocean, Inc.",
							 | 
						||
| 
								 | 
							
								        "city":"Clifton",
							 | 
						||
| 
								 | 
							
								        "country":"United States",
							 | 
						||
| 
								 | 
							
								        "countryCode":"US",
							 | 
						||
| 
								 | 
							
								        "isp":"Digital Ocean",
							 | 
						||
| 
								 | 
							
								        "lat":40.8326,
							 | 
						||
| 
								 | 
							
								        "lon":-74.1307,
							 | 
						||
| 
								 | 
							
								        "org":"Digital Ocean",
							 | 
						||
| 
								 | 
							
								        "query":"104.131.124.203",
							 | 
						||
| 
								 | 
							
								        "region":"NJ",
							 | 
						||
| 
								 | 
							
								        "regionName":"New Jersey",
							 | 
						||
| 
								 | 
							
								        "status":"success",
							 | 
						||
| 
								 | 
							
								        "timezone":"America/New_York",
							 | 
						||
| 
								 | 
							
								        "zip":"07014"
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    */
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								.catch(err => {
							 | 
						||
| 
								 | 
							
								  // handle errors
							 | 
						||
| 
								 | 
							
								});
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								### Using createConnection with callbacks
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								SocksClient.createConnection() optionally accepts a callback function as a second parameter.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								**Note:** If a callback function is provided, a Promise is still returned from the function, but the promise will always resolve regardless of if there was en error. (tldr: Do not mix callbacks and Promises).
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```typescript
							 | 
						||
| 
								 | 
							
								const SocksClient = require('socks').SocksClient;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const options  = {
							 | 
						||
| 
								 | 
							
								  proxy: {
							 | 
						||
| 
								 | 
							
								    ipaddress: '104.131.124.203',
							 | 
						||
| 
								 | 
							
								    port: 1081,
							 | 
						||
| 
								 | 
							
								    type: 5
							 | 
						||
| 
								 | 
							
								  },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  destination: {
							 | 
						||
| 
								 | 
							
								    host: 'ip-api.com', // host names are supported with SOCKS v4a and SOCKS v5.
							 | 
						||
| 
								 | 
							
								    port: 80
							 | 
						||
| 
								 | 
							
								  },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  command: 'connect'
							 | 
						||
| 
								 | 
							
								};
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								SocksClient.createConnection(options, (err, info) => {
							 | 
						||
| 
								 | 
							
								  if (err) {
							 | 
						||
| 
								 | 
							
								    // handle errors
							 | 
						||
| 
								 | 
							
								  } else {
							 | 
						||
| 
								 | 
							
								    console.log(info.socket);
							 | 
						||
| 
								 | 
							
								    // <Socket ...>  (this is a raw net.Socket that is established to the destination host through the given proxy servers)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    info.socket.write('GET /json HTTP/1.1\nHost: ip-api.com\n\n');
							 | 
						||
| 
								 | 
							
								    info.socket.on('data', (data) => {
							 | 
						||
| 
								 | 
							
								      console.log(data.toString()); // ip-api.com sees that the last proxy (104.131.124.203) is connected to it and not the origin client (you).
							 | 
						||
| 
								 | 
							
								      /*
							 | 
						||
| 
								 | 
							
								        HTTP/1.1 200 OK
							 | 
						||
| 
								 | 
							
								        Access-Control-Allow-Origin: *
							 | 
						||
| 
								 | 
							
								        Content-Type: application/json; charset=utf-8
							 | 
						||
| 
								 | 
							
								        Date: Sun, 24 Dec 2017 03:47:51 GMT
							 | 
						||
| 
								 | 
							
								        Content-Length: 300
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        {
							 | 
						||
| 
								 | 
							
								          "as":"AS14061 Digital Ocean, Inc.",
							 | 
						||
| 
								 | 
							
								          "city":"Clifton",
							 | 
						||
| 
								 | 
							
								          "country":"United States",
							 | 
						||
| 
								 | 
							
								          "countryCode":"US",
							 | 
						||
| 
								 | 
							
								          "isp":"Digital Ocean",
							 | 
						||
| 
								 | 
							
								          "lat":40.8326,
							 | 
						||
| 
								 | 
							
								          "lon":-74.1307,
							 | 
						||
| 
								 | 
							
								          "org":"Digital Ocean",
							 | 
						||
| 
								 | 
							
								          "query":"104.131.124.203",
							 | 
						||
| 
								 | 
							
								          "region":"NJ",
							 | 
						||
| 
								 | 
							
								          "regionName":"New Jersey",
							 | 
						||
| 
								 | 
							
								          "status":"success",
							 | 
						||
| 
								 | 
							
								          "timezone":"America/New_York",
							 | 
						||
| 
								 | 
							
								          "zip":"07014"
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								      */
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								### Using event handlers
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								SocksClient also supports instance creation of a SocksClient. This allows for event based flow control.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```typescript
							 | 
						||
| 
								 | 
							
								const SocksClient = require('socks').SocksClient;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const options  = {
							 | 
						||
| 
								 | 
							
								  proxy: {
							 | 
						||
| 
								 | 
							
								    ipaddress: '104.131.124.203',
							 | 
						||
| 
								 | 
							
								    port: 1081,
							 | 
						||
| 
								 | 
							
								    type: 5
							 | 
						||
| 
								 | 
							
								  },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  destination: {
							 | 
						||
| 
								 | 
							
								    host: 'ip-api.com', // host names are supported with SOCKS v4a and SOCKS v5.
							 | 
						||
| 
								 | 
							
								    port: 80
							 | 
						||
| 
								 | 
							
								  },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  command: 'connect'
							 | 
						||
| 
								 | 
							
								};
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const client = new SocksClient(options);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								client.on('established', (info) => {
							 | 
						||
| 
								 | 
							
								  console.log(info.socket);
							 | 
						||
| 
								 | 
							
								  // <Socket ...>  (this is a raw net.Socket that is established to the destination host through the given proxy servers)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  info.socket.write('GET /json HTTP/1.1\nHost: ip-api.com\n\n');
							 | 
						||
| 
								 | 
							
								  info.socket.on('data', (data) => {
							 | 
						||
| 
								 | 
							
								    console.log(data.toString()); // ip-api.com sees that the last proxy (104.131.124.203) is connected to it and not the origin client (you).
							 | 
						||
| 
								 | 
							
								    /*
							 | 
						||
| 
								 | 
							
								      HTTP/1.1 200 OK
							 | 
						||
| 
								 | 
							
								      Access-Control-Allow-Origin: *
							 | 
						||
| 
								 | 
							
								      Content-Type: application/json; charset=utf-8
							 | 
						||
| 
								 | 
							
								      Date: Sun, 24 Dec 2017 03:47:51 GMT
							 | 
						||
| 
								 | 
							
								      Content-Length: 300
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      {
							 | 
						||
| 
								 | 
							
								        "as":"AS14061 Digital Ocean, Inc.",
							 | 
						||
| 
								 | 
							
								        "city":"Clifton",
							 | 
						||
| 
								 | 
							
								        "country":"United States",
							 | 
						||
| 
								 | 
							
								        "countryCode":"US",
							 | 
						||
| 
								 | 
							
								        "isp":"Digital Ocean",
							 | 
						||
| 
								 | 
							
								        "lat":40.8326,
							 | 
						||
| 
								 | 
							
								        "lon":-74.1307,
							 | 
						||
| 
								 | 
							
								        "org":"Digital Ocean",
							 | 
						||
| 
								 | 
							
								        "query":"104.131.124.203",
							 | 
						||
| 
								 | 
							
								        "region":"NJ",
							 | 
						||
| 
								 | 
							
								        "regionName":"New Jersey",
							 | 
						||
| 
								 | 
							
								        "status":"success",
							 | 
						||
| 
								 | 
							
								        "timezone":"America/New_York",
							 | 
						||
| 
								 | 
							
								        "zip":"07014"
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    */
							 | 
						||
| 
								 | 
							
								});
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// Failed to establish proxy connection to destination.
							 | 
						||
| 
								 | 
							
								client.on('error', () => {
							 | 
						||
| 
								 | 
							
								  // Handle errors
							 | 
						||
| 
								 | 
							
								});
							 | 
						||
| 
								 | 
							
								```
							 |