Shadowsocks PAC自定义规则介绍

Shadowsocks的PAC自定义规则使用Adblock Plus的部分语法,本文主要介绍几种常用配置方法
原文地址:https://adblockplus.org/en/filter-cheatsheet

一、匹配url部分字符串

示例:/banner/*/img^

解释:*表示0~多个任意字符,^表示分隔符,例如?/等,也可以表示字符结尾

匹配:上述配置匹配以下几个url

http://example.com/banner/foo/img (img后面没有字符了,可以匹配)
http://example.com/banner/foo/bar/img?param (img后面是个“?”,属于分隔符,可以匹配)
http://example.com/banner//img/foo (“*”表示0~任意个字符,这里为0个,img后面是“/”,也是个分隔符,可以匹配)

不匹配:上述配置不能匹配下面的url

http://example.com/banner/img (banner后面只有一个“/”而规则里,只有“*”部分可以没有,此时会出现两个“/”)
http://example.com/banner/foo/imgraph (img后面不是分隔符,而是字母)
http://example.com/banner/foo/img.gif (“.”不算做分隔符)

二、域名匹配

示例:||ads.example.com^

解释:||表示规则为域名,ads.example.com是域名中必须存在的一部分,^表示域名的结尾,通常是“/”或“:”(例如http://xxx.com/、http://xxx.com:8080/)

匹配:上述配置匹配以下url

http://ads.example.com/foo.gif (ads.example.com是域名的一部分)
http://server1.ads.example.com/foo.gif (server1.ads.example.com包含了ads.example.com,即写一个根域名,可以匹配其子域名)
https://ads.example.com:8000/ (域名ads.example.com与配置规则一致)

不匹配:上述配置不匹配下面的url

http://ads.example.com.ua/foo.gif (虽然ads.example.com.ua包含了ads.example.com,但由于规则后面有“^”,所以期望域名必须是以ads.example.com结尾,而不是出现在域名中的一部分)
http://example.com/redirect/http://ads.example.com/ (虽然url有ads.example.com,但这已经不是这个url的域名部分,而属于path的一部分,所以不能匹配)

三、精确匹配

示例:|http://example.com/|

解释:第一个“|”表示url起始,最后一个“|”表示url结束,中间部分必须完全一致才可以匹配

匹配:http://example.com/ (必须完全一样)

不匹配:

http://example.com/foo.gif (与规则不一致)
http://example.info/redirect/http://example.com/ (http://example.com/不符合是url的开头且是url的结尾)

四、例外

@@表示例外,@@||ads.example.com/notbanner^ 表示不匹配||ads.example.com/notbanner规则,例如:
||ads.example.com^
@@||ads.example.com/notbanner^
上面两条规则指定了匹配ads.example.com及子域名下除/notbanner开头的页面
它可以匹配http://ads.example.com/example、http://subdomain.ads.example.com/example,http://subdomain.ads.example.com/notbannerxxx,但不匹配http://ads.example.com/notbanner (第二条排除了)

五、注意

更改完用户规则后,可能需要重启shadowsocks才能使配置生效

BroadcastChannel跨页面通信API

BroadcastChannel可以用于同源页面之间的通信,可以用来做用户访问追踪等

演示地址(建议使用新版Chrome):https://demo.lyz810.com/broadcastChannel/

一、初始化信道

const channel = new BroadcastChannel(channelName);

其中channelName为通信信道的名称,希望通信的同源页面之间只要设置了相同的channelName就可以互相通信了

二、监听信道

channel.onmessage = ({ data }) => {
  console.log(data);
};

三、发送信息

channel.postMessage(anything);

发送的内容可以是数组、对象、字符串、数字等,但不能发送如函数、Symbol等特殊的数据

四、关闭信道

channel.close();

五、兼容性
IE系列(包括Edge):不支持
Firefox:38+
Chrome:54+
Safari:不支持