2015-03-16 14:27:32 +08:00
AnyProxy
2014-08-08 17:50:56 +08:00
==========
2014-11-27 09:14:34 +08:00
[![NPM version][npm-image]][npm-url]
[![node version][node-image]][node-url]
[![npm download][download-image]][download-url]
[npm-image]: https://img.shields.io/npm/v/anyproxy.svg?style=flat-square
[npm-url]: https://npmjs.org/package/anyproxy
[node-image]: https://img.shields.io/badge/node.js-%3E=_0.10-green.svg?style=flat-square
[node-url]: http://nodejs.org/download/
[download-image]: https://img.shields.io/npm/dm/anyproxy.svg?style=flat-square
[download-url]: https://npmjs.org/package/anyproxy
2014-09-01 17:14:40 +08:00
A fully configurable proxy in NodeJS, which can handle HTTPS requests perfectly.
2014-12-22 09:26:40 +08:00
(Chinese in this doc is nothing but translation of some key points. Be relax if you dont understand.)
2014-09-05 14:45:01 +08:00
2015-02-02 11:13:34 +08:00
[中文wiki - 代理服务器的新轮子 ](https://github.com/alibaba/anyproxy/wiki/%E4%BB%A3%E7%90%86%E6%9C%8D%E5%8A%A1%E5%99%A8%E7%9A%84%E6%96%B0%E8%BD%AE%E5%AD%90%EF%BC%9Aanyproxy ) , 介绍我们为什么要再造一个代理服务器, anyproxy开放式的设计可以解决什么样的问题。
2014-09-05 13:53:12 +08:00
2015-03-02 10:40:52 +08:00
< img src = "http://gtms04.alicdn.com/tps/i4/TB1XfxDHpXXXXXpapXX20ySQVXX-512-512.png" width = "250" height = "250" alt = "anyproxy logo" / >
2014-08-22 16:06:05 +08:00
2014-12-22 09:26:40 +08:00
特性
------------
* 支持https明文代理
2014-12-22 09:29:55 +08:00
* 支持低网速模拟
2015-03-16 14:27:32 +08:00
* 支持二次开发, 可以用javascript控制代理的全部流程, 搭建前端个性化调试环境
2015-02-10 12:03:21 +08:00
* 提供web版界面, 观测请求情况
2014-11-13 10:05:56 +08:00
2014-08-21 17:40:02 +08:00
Feature
------------
* work as http or https proxy
2015-02-10 12:03:21 +08:00
* fully configurable, you could modify a request at any stage with your customized javascript code
2015-03-16 14:27:32 +08:00
* when working as https proxy, AnyProxy could intercept https requests for any domain without complaint by browser (after you trust its root CA)
* a web interface for you to watch realtime request details, where html with (almost) any charset could be shown correctly
2014-09-03 16:14:51 +08:00
2014-11-25 16:43:58 +08:00
Quick Start
2014-08-21 17:40:02 +08:00
--------------
2014-08-13 17:30:16 +08:00
### step 1 - install
2014-09-01 17:23:01 +08:00
* install [NodeJS ](http://nodejs.org/ )
2014-11-13 10:44:52 +08:00
* ``npm install -g anyproxy`` , may require ``sudo` `
* python is optional, it will be OK if you get some error about it during installing.
2014-08-08 17:50:56 +08:00
2015-03-16 15:05:23 +08:00
### step 2 - start proxy server
2014-08-09 11:41:02 +08:00
2014-08-21 17:40:02 +08:00
* start with default settings : ``anyproxy` `
2015-03-16 15:05:23 +08:00
* ...or start with a specific port: ``anyproxy --port 8001` `
* ...start with a rule file: ``anyproxy --rule ./rule_sample/rule_allow_CORS.js` `
2014-08-13 17:30:16 +08:00
2014-09-03 16:14:51 +08:00
### step 3 - launch web interface
2015-03-31 09:41:22 +08:00
* visit [http://127.0.0.1:8002 ](http://127.0.0.1:8002 ) ,you will see realtime requests in your browser
2015-03-16 15:05:23 +08:00
* be sure to use web interface with modern browsers

2014-09-03 16:14:51 +08:00
2014-09-11 11:09:12 +08:00
Rule module
2014-09-01 17:14:40 +08:00
-------------------
2015-03-16 15:03:06 +08:00
* Rule module is the specialty for AnyProxy. Think it as a middleware, you could write your own code to hack requests at any stage, no matter it is about to response or the proxy just gets the request. In this way, AnyProxy would be flexible to meet your own demands.
2014-09-11 11:09:12 +08:00
2014-11-18 20:07:20 +08:00
* It's highly recommended to read this guide before using: [What is rule file and how to write one ? ](https://github.com/alibaba/anyproxy/wiki/What-is-rule-file-and-how-to-write-one )
2014-09-11 11:09:12 +08:00
2014-11-24 16:22:39 +08:00
* An entire scheme of rule file could be found at [./rule_sample/rule__blank.js ](https://github.com/alibaba/anyproxy/blob/master/rule_sample/rule__blank.js ). Besides, there are some samples at [./rule_sample ](https://github.com/alibaba/anyproxy/tree/master/rule_sample ). That may help you a lot when writing your own rule files.
2014-08-13 17:30:16 +08:00
2014-11-24 16:25:37 +08:00
Https features
2014-08-21 17:40:02 +08:00
----------------
2015-03-16 14:27:32 +08:00
After configuring rootCA, AnyProxy could help to decrypt https requests, whose approach is also called Man-In-The-Middle(MITM).
2014-09-12 11:00:41 +08:00
2015-03-31 09:41:22 +08:00
A guide about configuring https features is here : [https://github.com/alibaba/anyproxy/wiki/How-to-config-https-proxy ](https://github.com/alibaba/anyproxy/wiki/How-to-config-https-proxy )
2015-03-30 11:11:05 +08:00
2015-03-31 09:41:22 +08:00
HTTPS配置中文教程 : [https://github.com/alibaba/anyproxy/wiki/HTTPS%E7%9B%B8%E5%85%B3%E6%95%99%E7%A8%8B ](https://github.com/alibaba/anyproxy/wiki/HTTPS%E7%9B%B8%E5%85%B3%E6%95%99%E7%A8%8B )
2014-08-09 11:41:02 +08:00
2014-09-01 17:14:40 +08:00
Others
2014-08-21 17:40:02 +08:00
-----------------
2014-10-23 11:07:02 +08:00
2015-03-08 12:00:39 +08:00
#### to save request data
2014-10-23 13:39:43 +08:00
* to save request data to local file, use ``` anyproxy --file /path/to/file ` ``
* anyproxy uses [nedb ](https://github.com/louischatriot/nedb ) to save request data. Since NeDB's persistence uses an append-only format, you may get some redundant record in local file. For those dupplicated ones with the same id, just use the lastest line of record.
2015-01-05 17:12:50 +08:00
* [TrafficeRecorder ](https://github.com/ottomao/TrafficRecorder ) is another tool based on anyproxy to help recording all request data, including header and body. You may have a try.
2014-10-23 11:07:02 +08:00
2014-10-29 16:20:18 +08:00
#### throttling
2014-11-18 20:02:35 +08:00
* for instance, ``` anyproxy --throttle 10 ` `` sets the speed limit to 10kb/s (kbyte/sec)
2014-10-29 16:20:18 +08:00
* this is just a rough throttling for downstream, not for network simulation
2014-10-23 11:07:02 +08:00
#### work as a module for nodejs
2014-11-18 20:02:35 +08:00
* use it as a module and develop your own proxy.
2014-08-14 10:59:49 +08:00
```
2014-09-01 17:14:40 +08:00
npm install anyproxy --save
2014-08-14 10:59:49 +08:00
```
```javascript
var proxy = require("anyproxy");
2014-09-04 11:22:35 +08:00
//create cert when you want to use https features
//please manually trust this rootCA when it is the first time you run it
2015-03-08 12:00:39 +08:00
!proxy.isRootCAFileExists() & & proxy.generateRootCA();
2014-09-04 11:22:35 +08:00
var options = {
2014-09-18 13:36:27 +08:00
type : "http",
port : 8001,
hostname : "localhost",
rule : require("path/to/my/ruleModule.js"),
2014-10-29 16:20:18 +08:00
dbFile : null, // optional, save request data to a specified file, will use in-memory db if not specified
webPort : 8002, // optional, port for web interface
socketPort : 8003, // optional, internal port for web socket, replace this when it is conflict with your own service
webConfigPort : 8088, // optional, internal port for web config(beta), replace this when it is conflict with your own service
2015-03-08 12:00:39 +08:00
throttle : 10, // optional, speed limit in kb/s
2015-03-30 11:11:05 +08:00
disableWebInterface : false, //optional, set it when you don't want to use the web interface
silent : false, //optional, do not print anything into terminal. do not set it when you are still debugging.
2014-09-04 11:22:35 +08:00
};
new proxy.proxyServer(options);
2014-08-14 10:59:49 +08:00
```
2014-11-17 14:33:08 +08:00
Contact
-----------------
2014-11-18 20:02:35 +08:00
* Please feel free to [raise issue ](https://github.com/alibaba/anyproxy/issues ), or give us some advice. :)
2015-03-16 14:27:32 +08:00
* AnyProxy用户旺旺群: 1203077233
2014-11-17 14:33:08 +08:00
License
-----------------
* Apache License, Version 2.0