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