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
						
					
					
				| # 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
 | |
| });
 | |
| ``` |