wssagent

1.1.4 • Public • Published

wssproxy-agent

A local proxy agent connecting to remote websocket proxy server. Abbreviated as wssagent

把远端的websocket加密代理服务器转换为本地的非加密普通代理服务器,简称为wssagent,支持CDN中转

支持DOH(DNS over https),保护用户隐私

使用

需要先运行pacproxy服务 , 运行后屏幕会显示 [WSSURL]

运行wssagent, 输入[WSSURL]

浏览器或者wifi设置代理服务器为 localhost , 代理端口为wssagent显示的端口, 就可以加密翻墙

也可以使用local pacurl来限制只一个浏览器翻墙,如只firefox翻墙可设置pacurl: http://localhost:[PROXY_PORT]/pac/firefox

运行

可下载直接点击绿色可执行文件,或在命令行执行,按以下顺序加上可选参数:

node ./wssagent.js [WSSURL] [PROXY_PORT] [-s] [DOH_SERVER] [WSSIP] [CONNECT_DOMAIN]

nohup ./wssagent-linux [WSSURL] [PROXY_PORT] [-s] [DOH_SERVER] [WSSIP] [CONNECT_DOMAIN]

或编辑wssagent同一目录下的 wss.env文件,设置运行参数

  • Linux系统下的可执行文件只能在命令行下执行,除了[WSSURL]外其它参数不是必须输入

  • 默认只本机能用代理,加 -s 可分享本机IP和端口给同一网段,其他参数说明见 wss.env文件

  • [WSSIP]是代理服务器的IP, 指定[WSSIP]将绕开DNS解析,避免域名劫持或DNS封锁

  • 如[WSSURL]是直连pacproxy,可设置一个编造的域名[CONNECT_DOMAIN],连接代理服务器时会自动替换[WSSURL]里的域名,以避开域名审查,隐藏真实域名。如果是CDN中转则不能用[CONNECT_DOMAIN]。编造域名需避开常见已知域名,尤其是已经被封锁的域名

  • [WSSIP]并不需要绑定域名记录。很多VPS可以动态增加IP地址,新加的IP地址重启pacproxy服务后就可以用作[WSSIP]

  • 如果同时指定了[WSSIP] 和 [DOH_SERVER],连接时会用[WSSIP]连接服务器,但屏幕会显示[DOH_SERVER]解析域名的结果用于核对IP地址和DOH服务

手机用户参照Android系统wssagent说明

用途

  • 很多软件不支持https加密的pacproxy代理, 用wssagent就可以在一台电脑上把pacproxy加密代理转换成普通代理,整个局域网都可以按普通方式代理上网

  • 利用CDN中转突破封锁或加强隐私。CDN中转后proxy服务器不知道访问者的真实IP,CDN服务器不知道访问目标。如果海外的pacproxy服务器被封了。可以自己在cloudflare之类的支持websocket的CDN上注册一个账户, 再注册一个域名, 再在CDN上把这个域名指向你远端的pacproxy服务器,SSL/TLS mode设置为FULL, 然后把[WSSURL]中的域名改成你注册的域名, 就又可以连上了。

  • wssagent可以利用CDN转发,但会将加密proxy转成普通代理。如果希望在某些不安全的设备或网络上,通过Firefox设置加密PAC URL实现端到端加密,可在参数[WSSURL]后加 /pac, [PROXY_PORT]设置为443,[SHARE_PROXY]设置为true, 可以在Firefox上设置带用户密码的PAC URL。 但需要本机hosts文件记录修改域名指向到wssagent的IP,或者用nextdns修改dns指向。不建议将真实DNS指向wssagent的IP, 有数字证书被盗用的风险。

  • 可参考使用案例

安全

  • 如果不信任中转流量的CDN, 则可以在CDN的[WSSURL]后面加 /tls , 此时穿越CDN的流量会加密,CDN不能探测你所访问的网站和内容,即使访问不加密的http网站对CDN也是不可知的。直连pacproxy服务器时一般不需要加/tls参数。

  • 如果直连pacproxy时指定了[CONNECT_DOMAIN], 会略过服务器数字证书验证。为避免域名或IP劫持, 可在直连的[WSSURL]后面加 /tls , 会在tls加密连接时验证服务器的数字证书,确保连接到了真的pacproxy服务器。

  • [WSSURL]后面加/pac 和 加/tls 一样,通过CDN中转时传输内容对CDN是加密的。直连时也一样会验证数字证书避免域名或IP劫持。

  • 由于常见的DOH服务经常会被封锁,所以能用[WSSIP]和本机hosts记录就尽量不用DOH, 需要用DOH或私有DNS服务时,可以用CDN中转DOH服务,避免DOH服务封锁。

  • 如果不信任pacproxy所运行的服务器, 则可以和无界,自由门混合使用。将无界,自由门的代理端口设置为wssagent的端口,浏览器则设置为无界/自由门的端口。这样pacproxy并不知道你具体访问的内容,如原来连不上无界,自由门此时也可以连上。可能也可以用此方法收看限定在无界/自由门上收看的新唐人晚会等节目。

推荐

推荐用prcproxy安全的访问以下网站:

Package Sidebar

Install

npm i wssagent

Weekly Downloads

10

Version

1.1.4

License

MIT

Unpacked Size

166 kB

Total Files

9

Last publish

Collaborators

  • wuhua68