Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mattcg/socks5-http-client
SOCKS v5 HTTP client implementation in JavaScript for Node.js.
https://github.com/mattcg/socks5-http-client
proxy-client socks tor
Last synced: 2 months ago
JSON representation
SOCKS v5 HTTP client implementation in JavaScript for Node.js.
- Host: GitHub
- URL: https://github.com/mattcg/socks5-http-client
- Owner: mattcg
- Created: 2013-03-04T07:00:57.000Z (almost 12 years ago)
- Default Branch: master
- Last Pushed: 2019-09-19T07:21:15.000Z (over 5 years ago)
- Last Synced: 2024-11-07T18:17:09.847Z (3 months ago)
- Topics: proxy-client, socks, tor
- Language: JavaScript
- Size: 27.3 KB
- Stars: 255
- Watchers: 10
- Forks: 27
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-network-stuff - **239**星
README
# SOCKS5 HTTP Client #
[![Build Status](https://travis-ci.org/mattcg/socks5-http-client.png?branch=master)](https://travis-ci.org/mattcg/socks5-http-client)
SOCKS v5 HTTP client implementation in JavaScript for Node.js.
```js
var shttp = require('socks5-http-client');shttp.get('http://www.google.com/', function(res) {
res.setEncoding('utf8');
res.on('readable', function() {
console.log(res.read()); // Log response to console.
});
});
```URLs are parsed using `url.parse`. You may also pass an options hash as the first argument to `get` or `request`.
## Options ##
Specify the `socksHost` and `socksPort` options if your SOCKS server isn't running on `localhost:1080`. Tor runs its SOCKS server on port `9050` by default, for example.
Specify a username and password using `socksUsername` and `socksPassword`.
## Using with Tor ##
Works great for making HTTP requests through [Tor](https://www.torproject.org/).
Make sure a Tor server is running locally and run `node example/tor http://en.wikipedia.org/wiki/SOCKS` to test.
## Using with Request ##
To use with [Request](https://github.com/mikeal/request), just pass a reference to the `Agent` constructor.
```js
var Agent = require('socks5-http-client/lib/Agent');request({
url: 'http://en.wikipedia.org/wiki/SOCKS',
agentClass: Agent,
agentOptions: {
socksHost: 'my-tor-proxy-host', // Defaults to 'localhost'.
socksPort: 9050 // Defaults to 1080.
}
}, function(err, res) {
console.log(err || res.body);
});
```## HTTPS ##
This client only provides support for making HTTP requests. See [socks5-https-client](https://github.com/mattcg/socks5-https-client) for an HTTPS implementation.
## License ##
Copyright © 2013 [Matthew Caruana Galizia](http://twitter.com/mcaruanagalizia), licensed under an [MIT license](http://mattcg.mit-license.org/).