Flclash覆写脚本分享7-新增倍率过滤,匹配逻辑与架构全面优化
LINUX DO - 最新话题 (ZipZhu)现在是下半夜,不知道有没有佬友没睡着还在逛论坛。

在 scripts6 的基础上做了一点改动,分享一下。
scripts6 地址:Flclash脚本分享6-将 icon 与 rule 从硬编码 URL改为变量拼接
脚本仓库:GitHub - ZipZhu/Flclash-scripts: A repository for Flclash scripts
scripts7 在 scripts6 的基础上进行优化:
- 新增“倍率过滤”,当前设置为过滤3倍以上的节点
- 全量遍历优化为基于
.some()方法的短路检测,避免不必要的计算 - 调整正则匹配策略,关键词过滤移除了
i标记,改为严格匹配大小写 - 优化了代码结构与可读性:
- 代码严格按照
常量定义 -> 数据清洗 (Filter) -> 地区探测 (Detect) -> 组装 (Build)的顺序排列,符合人类阅读习惯 - 将地区定义改为标准的
REGIONS数组对象,直接遍历,去除了所有不必要的中间转换 - 移除了
URL_TEST_DEFAULT等利用率低的中间变量
- 代码严格按照
以下是脚本:
function main(config) {
const ICON_BASE = "https://cdn.jsdelivr.net/gh/Koolson/Qure@master/IconSet/Color/";
const RULE_BASE = "https://cdn.jsdelivr.net/gh/ACL4SSR/ACL4SSR@master/Clash/";
const maxRatio = 3.0;
const ratioRegex = /(?:x|X|倍率?)\s?(\d+\.?\d*)/;
const filterKeywords = [
'群', '邀请', '返利', '官网', '官方', '网址', '订阅', '购买', '续费', '剩余',
'到期', '过期', '流量', '备用', '邮箱', '客服', '联系', '工单', '倒卖', '防止',
'节点', '代理', '梯子', 'tg', '发布', '重置', '测试'
];
const blackListRegex = new RegExp(filterKeywords.join('|'));
const originalProxies = config.proxies || [];
const filteredProxies = originalProxies.filter(proxy => {
if (blackListRegex.test(proxy.name)) return false;
const ratioMatch = proxy.name.match(ratioRegex);
if (ratioMatch) {
const ratio = parseFloat(ratioMatch[1]);
if (ratio > maxRatio) return false;
}
return true;
});
if (filteredProxies.length === 0) return config;
const REGIONS = [
{ name: "美国节点", pattern: "美|波特兰|达拉斯|俄勒冈|凤凰城|费利蒙|硅谷|拉斯维加斯|洛杉矶|圣何塞|圣克拉拉|西雅图|芝加哥|US|United States", icon: "United_States.png" },
{ name: "日本节点", pattern: "日本|东京|大阪|JP|Japan", icon: "Japan.png" },
{ name: "狮城节点", pattern: "新加坡|狮城|SG|Singapore", icon: "Singapore.png" },
{ name: "香港节点", pattern: "港|HK|Hong Kong", icon: "Hong_Kong.png" },
{ name: "台湾节点", pattern: "台|新北|彰化|TW|Taiwan", icon: "Taiwan.png" }
];
const validRegions = [];
for (const region of REGIONS) {
const regex = new RegExp(region.pattern);
if (filteredProxies.some(proxy => regex.test(proxy.name))) {
validRegions.push(region);
}
}
const validRegionNames = validRegions.map(r => r.name);
const proxyGroups = [];
proxyGroups.push({
name: "节点选择",
icon: `${ICON_BASE}Proxy.png`,
type: "select",
proxies: [...validRegionNames, "手动切换"]
});
for (const region of validRegions) {
proxyGroups.push({
name: region.name,
icon: `${ICON_BASE}${region.icon}`,
"include-all": true,
filter: region.pattern,
type: "url-test",
interval: 300,
tolerance: 50
});
}
proxyGroups.push({
name: "手动切换",
icon: `${ICON_BASE}Available.png`,
"include-all": true,
type: "select"
});
proxyGroups.push({
name: "GLOBAL",
icon: `${ICON_BASE}Global.png`,
type: "select",
proxies: ["节点选择", ...validRegionNames, "手动切换", "DIRECT"]
});
config["proxy-groups"] = proxyGroups;
config["rule-providers"] = {
LocalAreaNetwork: { url: `${RULE_BASE}LocalAreaNetwork.list`, path: "./ruleset/LocalAreaNetwork.list", behavior: "classical", interval: 86400, format: "text", type: "http" },
UnBan: { url: `${RULE_BASE}UnBan.list`, path: "./ruleset/UnBan.list", behavior: "classical", interval: 86400, format: "text", type: "http" },
BanAD: { url: `${RULE_BASE}BanAD.list`, path: "./ruleset/BanAD.list", behavior: "classical", interval: 86400, format: "text", type: "http" },
BanProgramAD: { url: `${RULE_BASE}BanProgramAD.list`, path: "./ruleset/BanProgramAD.list", behavior: "classical", interval: 86400, format: "text", type: "http" },
ProxyGFWlist: { url: `${RULE_BASE}ProxyGFWlist.list`, path: "./ruleset/ProxyGFWlist.list", behavior: "classical", interval: 86400, format: "text", type: "http" },
ChinaDomain: { url: `${RULE_BASE}ChinaDomain.list`, path: "./ruleset/ChinaDomain.list", behavior: "domain", interval: 86400, format: "text", type: "http" },
ChinaCompanyIp: { url: `${RULE_BASE}ChinaCompanyIp.list`, path: "./ruleset/ChinaCompanyIp.list", behavior: "classical", interval: 86400, format: "text", type: "http" },
Download: { url: `${RULE_BASE}Download.list`, path: "./ruleset/Download.list", behavior: "classical", interval: 86400, format: "text", type: "http" }
};
config["rules"] = [
"RULE-SET,LocalAreaNetwork,DIRECT",
"RULE-SET,UnBan,DIRECT",
"RULE-SET,BanAD,REJECT",
"RULE-SET,BanProgramAD,REJECT",
"RULE-SET,ProxyGFWlist,节点选择",
"RULE-SET,ChinaDomain,DIRECT",
"RULE-SET,ChinaCompanyIp,DIRECT",
"RULE-SET,Download,DIRECT",
"GEOIP,CN,DIRECT",
"MATCH,节点选择"
];
config.proxies = filteredProxies;
return config;
}
如果这对你有帮助,给点个赞呗~

5 posts - 4 participants
Generated by RSStT. The copyright belongs to the original author.