diff --git a/Rewrite/AdBlock/Bilibili.conf b/Rewrite/AdBlock/Bilibili.conf index cd957c0..7546128 100644 --- a/Rewrite/AdBlock/Bilibili.conf +++ b/Rewrite/AdBlock/Bilibili.conf @@ -9,13 +9,13 @@ // @TgChannel https://t.me/ddgksf2021 // @Contribute https://t.me/ddgksf2013_bot // @Feedback 📮 ddgksf2013@163.com 📮 -// @UpdateTime 2022-10-02 -// @ConfigVersion V0.0.81 +// @UpdateTime 2022-11-05 +// @ConfigVersion V0.0.84 // @Attention 如果广告仍然存在,请清除缓存或卸载应用重新安装 // @Attention 如需引用请注明出处,谢谢合作! // @Function 去广告配置(自用,不定期更新) // @Suitable 自行观看“# > ”注释内容 -// @ScriptURL https://gitlab.com/ddgksf2013/Cuttlefish/-/raw/master/Rewrite/AdBlock/Bilibili.conf +// @ScriptURL https://codeberg.org/ddgksf2013/Cuttlefish/raw/branch/master/Rewrite/AdBlock/Bilibili.conf // ==/UserScript== @@ -46,7 +46,7 @@ //2022-04-02 24、增加哔哩哔哩繁体CC字幕转中文简体功能 //2022-05-04 25、彻底去除追番页面顶部Banner轮播图中的AD,及其下部圆形图标中的AD(诸如:'五一旅行'、'专属称号'、'最后一天') //2022-05-04 26、移除我的页面墨鱼手记Tag -//2022-05-14 27、移除繁体CC字幕转中文简体,有需要的可以单独引用-> https://gitlab.com/ddgksf2013/Cuttlefish/-/raw/master/Rewrite/Function/Bilibili_CC.conf +//2022-05-14 27、移除繁体CC字幕转中文简体,有需要的可以单独引用-> https://codeberg.org/ddgksf2013/Cuttlefish/raw/branch/master/Rewrite/Function/Bilibili_CC.conf //2022-05-14 28、去除观影页面下部圆形图标中的AD(诸如:'正式营业'、'非正7') //2022-05-23 29、新增B站启动时开启直连模式 //2022-06-04 29、去除B站视频流(类似抖音界面)中的广告推送 @@ -56,6 +56,8 @@ //2022-08-24 33、去除部分无用重写匹配 //2022-09-12 34、屏蔽视频播放页面下方浮动方框的广告 //2022-10-02 35、B站解锁普通视频高码率仅适用国区粉色APP,外区为自我安慰 +//2022-11-04 36、修改B站首页右上角活动屏蔽方式,对应第30条,新的无需卸载重装@shiro + hostname = app.bilibili.com,api.live.bilibili.com,api.vc.bilibili.com, api.bilibili.com, manga.bilibili.com, grpc.biliapi.net,api.biliapi.net, -broadcast.chat.bilibili.com, -*cdn*.biliapi.net, -*tracker*.biliapi.net # ~ BiliBili_哔哩哔哩_屏蔽广告浮窗@ddgksf2013 @@ -65,23 +67,23 @@ hostname = app.bilibili.com,api.live.bilibili.com,api.vc.bilibili.com, api.bilib # ~ BiliBili_哔哩哔哩_屏蔽DefaultWord@ddgksf2013 ^https?:\/\/app\.bilibili\.com\/bilibili\.app\.interface\.v1\.Search\/Default url reject # ~ BiliBili_哔哩哔哩_屏蔽首页右上活动[卸载重装]@ddgksf2013 -^https?:\/\/app\.bilibili\.com\/x\/resource\/top\/activity url reject-dict +^https?:\/\/app\.bilibili\.com\/x\/resource\/top\/activity url script-response-body https://cdn.jsdelivr.net/gh/sve1r/Rules-For-Quantumult-X@develop/Scripts/AdBlock/Bilibili/bilibili_json.js # ~ BiliBili_哔哩哔哩_启动时开启直连模式[自行启用]@ddgksf2013 -;^https?:\/\/app\.bilibili\.com\/x\/resource\/domain url script-response-body https://gitlab.com/ddgksf2013/Cuttlefish/-/raw/master/Script/bilibili_startup_direct.js +;^https?:\/\/app\.bilibili\.com\/x\/resource\/domain url script-response-body https://cdn.jsdelivr.net/gh/sve1r/Rules-For-Quantumult-X@develop/Scripts/AdBlock/Bilibili/bilibili_startup_direct.js # ~ BiliBili_哔哩哔哩_繁体CC字幕转中文简体[自行启用]@ddgksf2013 -;^https?:\/\/i.\.hdslb\.com\/bfs\/subtitle\/.+\.json$ url script-response-body https://gitlab.com/ddgksf2013/Cuttlefish/-/raw/master/Script/bilibili_cc.js +;^https?:\/\/i.\.hdslb\.com\/bfs\/subtitle\/.+\.json$ url script-response-body https://cdn.jsdelivr.net/gh/sve1r/Rules-For-Quantumult-X@develop/Scripts/AdBlock/Bilibili/bilibili_cc.js # ~ BiliBili_哔哩哔哩_观影页面去广告@ddgksf2013 -^https?:\/\/api\.(bilibili|biliapi)\.(com|net)\/pgc\/page\/cinema\/tab\? url script-response-body https://gitlab.com/ddgksf2013/Cuttlefish/-/raw/master/Script/bilibili_json.js +^https?:\/\/api\.(bilibili|biliapi)\.(com|net)\/pgc\/page\/cinema\/tab\? url script-response-body https://cdn.jsdelivr.net/gh/sve1r/Rules-For-Quantumult-X@develop/Scripts/AdBlock/Bilibili/bilibili_json.js # ~ BiliBili_哔哩哔哩_应用开屏去广告@bm7 ^https://app.bilibili.com/x/v2/splash/show url reject-dict # ~ BiliBili_哔哩哔哩_应用开屏广告预加载@yjqiang -^https:\/\/app\.bilibili\.com\/x\/v2\/splash\/list url script-response-body https://gitlab.com/ddgksf2013/Cuttlefish/-/raw/master/Script/bilibili_json.js +^https:\/\/app\.bilibili\.com\/x\/v2\/splash\/list url script-response-body https://cdn.jsdelivr.net/gh/sve1r/Rules-For-Quantumult-X@develop/Scripts/AdBlock/Bilibili/bilibili_json.js # ~ BiliBili_哔哩哔哩_去除统一设置的皮肤@ddgksf2013 -^https?:\/\/app\.bilibili\.com\/x\/resource\/show\/skin\? url script-response-body https://gitlab.com/ddgksf2013/Cuttlefish/-/raw/master/Script/bilibili_json.js +^https?:\/\/app\.bilibili\.com\/x\/resource\/show\/skin\? url script-response-body https://cdn.jsdelivr.net/gh/sve1r/Rules-For-Quantumult-X@develop/Scripts/AdBlock/Bilibili/bilibili_json.js # ~ BiliBili_哔哩哔哩_1080P高码率+4K画质(番剧和影视除外)@ddgksf2013 -^https?:\/\/app\.bilibili\.com\/x\/v2\/account\/myinfo\? url script-response-body https://gitlab.com/ddgksf2013/Cuttlefish/-/raw/master/Script/bilibili_json.js +^https?:\/\/app\.bilibili\.com\/x\/v2\/account\/myinfo\? url script-response-body https://cdn.jsdelivr.net/gh/sve1r/Rules-For-Quantumult-X@develop/Scripts/AdBlock/Bilibili/bilibili_json.js # ~ BiliBili_哔哩哔哩_热搜发现@ddgksf2013 -^https://app.bilibili.com/x/v2/search/square url script-response-body https://gitlab.com/ddgksf2013/Cuttlefish/-/raw/master/Script/bilibili_json.js +^https://app.bilibili.com/x/v2/search/square url script-response-body https://cdn.jsdelivr.net/gh/sve1r/Rules-For-Quantumult-X@develop/Scripts/AdBlock/Bilibili/bilibili_json.js # ~ BiliBili_哔哩哔哩_Defaultword@ddgksf2013 ^https://app.bilibili.com/x/v2/search/defaultwords url reject-dict # ~ BiliBili_哔哩哔哩_Material_Ad@ddgksf2013 @@ -93,14 +95,14 @@ hostname = app.bilibili.com,api.live.bilibili.com,api.vc.bilibili.com, api.bilib # ~ BiliBili_哔哩哔哩_漫画去广告@ddgksf2013 ^https?:\/\/manga\.bilibili\.com\/twirp\/comic\.v\d\.Comic\/(Flash|ListFlash) url reject-dict # ~ BiliBili_哔哩哔哩_推荐去广告@ddgksf2013 -^https?:\/\/app\.bilibili\.com\/x\/v2\/feed\/index url script-response-body https://gitlab.com/ddgksf2013/Cuttlefish/-/raw/master/Script/bilibili_json.js +^https?:\/\/app\.bilibili\.com\/x\/v2\/feed\/index url script-response-body https://cdn.jsdelivr.net/gh/sve1r/Rules-For-Quantumult-X@develop/Scripts/AdBlock/Bilibili/bilibili_json.js # ~ BiliBili_哔哩哔哩_追番去广告@ddgksf2013 -^https?:\/\/api\.(bilibili|biliapi)\.(com|net)\/pgc\/page\/bangumi url script-response-body https://gitlab.com/ddgksf2013/Cuttlefish/-/raw/master/Script/bilibili_json.js +^https?:\/\/api\.(bilibili|biliapi)\.(com|net)\/pgc\/page\/bangumi url script-response-body https://cdn.jsdelivr.net/gh/sve1r/Rules-For-Quantumult-X@develop/Scripts/AdBlock/Bilibili/bilibili_json.js # ~ BiliBili_哔哩哔哩_直播去广告@bm7 -^https?:\/\/api\.live\.bilibili\.com\/xlive\/app-room\/v1\/index\/getInfoByRoom url script-response-body https://gitlab.com/ddgksf2013/Cuttlefish/-/raw/master/Script/bilibili_json.js +^https?:\/\/api\.live\.bilibili\.com\/xlive\/app-room\/v1\/index\/getInfoByRoom url script-response-body https://cdn.jsdelivr.net/gh/sve1r/Rules-For-Quantumult-X@develop/Scripts/AdBlock/Bilibili/bilibili_json.js # ~ BiliBili_哔哩哔哩_标签页处理@ddgksf2013 -^https?:\/\/app\.bilibili\.com\/x\/resource\/show\/tab url script-response-body https://gitlab.com/ddgksf2013/Cuttlefish/-/raw/master/Script/bilibili_json.js +^https?:\/\/app\.bilibili\.com\/x\/resource\/show\/tab url script-response-body https://cdn.jsdelivr.net/gh/sve1r/Rules-For-Quantumult-X@develop/Scripts/AdBlock/Bilibili/bilibili_json.js # ~ BiliBili_哔哩哔哩_我的页面处理@ddgksf2013 -^https?:\/\/app\.bilibili\.com\/x\/v2\/account\/mine url script-response-body https://gitlab.com/ddgksf2013/Cuttlefish/-/raw/master/Script/bilibili_json.js +^https?:\/\/app\.bilibili\.com\/x\/v2\/account\/mine url script-response-body https://cdn.jsdelivr.net/gh/sve1r/Rules-For-Quantumult-X@develop/Scripts/AdBlock/Bilibili/bilibili_json.js # ~ BiliBili_哔哩哔哩_Proto去广告@app2smile ^https:\/\/app\.bilibili\.com\/bilibili\.app\.(view\.v1\.View\/View|dynamic\.v2\.Dynamic\/DynAll)$ url script-response-body https://cdn.jsdelivr.net/gh/sve1r/Rules-For-Quantumult-X@develop/Scripts/Unlock/BiliBili-proto.js \ No newline at end of file diff --git a/Scripts/AdBlock/Bilibili/bilibili_json.js b/Scripts/AdBlock/Bilibili/bilibili_json.js index 7a2d42a..18344a4 100644 --- a/Scripts/AdBlock/Bilibili/bilibili_json.js +++ b/Scripts/AdBlock/Bilibili/bilibili_json.js @@ -2,11 +2,12 @@ 应用名称:自用B站去广告脚本 脚本作者:Cuttlefish 微信账号:公众号墨鱼手记 -更新时间:2022-10-11 -脚本版本:(69) +更新时间:2022-11-08 +脚本版本:(74) 通知频道:https://t.me/ddgksf2021 问题反馈:ddgksf2013@163.com */ + const scriptName = "BiliBili"; const storyAidKey = "bilibili_story_aid"; const blackKey = "bilibili_feed_black"; @@ -21,12 +22,11 @@ if (magicJS.read(blackKey)) { magicJS.write(blackKey, defaultList); blacklist = defaultList.split(";"); } - (() => { let body = null; if (magicJS.isResponse) { switch (true) { -// 推荐去广告,最后问号不能去掉,以免匹配到story模式 + // 推荐去广告,最后问号不能去掉,以免匹配到story模式 case /^https:\/\/app\.bilibili\.com\/x\/v2\/feed\/index\?/.test(magicJS.request.url): try { let obj = JSON.parse(magicJS.response.body); @@ -41,7 +41,7 @@ if (magicJS.read(blackKey)) { bannerItems.push(banner); } } -// 去除广告后,如果banner大于等于1个才添加到响应体 + // 去除广告后,如果banner大于等于1个才添加到响应体 if (bannerItems.length >= 1) { item["banner_item"] = bannerItems; items.push(item); @@ -50,7 +50,7 @@ if (magicJS.read(blackKey)) { !item.hasOwnProperty("ad_info") && !blacklist.includes(item["args"]["up_name"]) && item.card_goto.indexOf("ad") === -1 && - (item["card_type"] === "small_cover_v2" || item["card_type"] === "large_cover_v1"|| item["card_type"] === "large_cover_single_v9") + (item["card_type"] === "small_cover_v2" || item["card_type"] === "large_cover_v1" || item["card_type"] === "large_cover_single_v9") ) { items.push(item); } @@ -61,15 +61,13 @@ if (magicJS.read(blackKey)) { magicJS.logError(`推荐去广告出现异常:${err}`); } break; -// 匹配story模式,用于记录Story的aid - case /^https:\/\/app\.bilibili\.com\/x\/v2\/feed\/index\/story\?/.test(magicJS.request.url): + // 匹配story模式,用于记录Story的aid + case /^https?:\/\/app\.bilibili\.com\/x\/v2\/feed\/index\/story\?/.test(magicJS.request.url): try { let obj = JSON.parse(magicJS.response.body); let items = []; for (let item of obj["data"]["items"]) { - if ( - !item.hasOwnProperty("ad_info") && - item.card_goto.indexOf("ad") === -1) { + if (!item.hasOwnProperty("ad_info") && item.card_goto.indexOf("ad") === -1) { items.push(item); } } @@ -79,16 +77,22 @@ if (magicJS.read(blackKey)) { magicJS.logError(`记录Story的aid出现异常:${err}`); } break; - -// 标签页处理,如去除会员购等等 + //teenagers modified + case /^https?:\/\/app\.bilibili\.com\/x\/v\d\/account\/teenagers\/status\?/.test(magicJS.request.url): + try { + let obj = JSON.parse(magicJS.response.body); + obj.data.teenagers_status = 0; + body = JSON.stringify(obj); + } catch (err) { + magicJS.logError(`teenagers出现异常:${err}`); + } + break; + // 标签页处理,如去除会员购等等 case /^https?:\/\/app\.bilibili\.com\/x\/resource\/show\/tab/.test(magicJS.request.url): try { - const tabList = new Set([39, 40, 41, 774, 857, 545, 151, 442, 99, 100, 101, 554, 556]); - const topList = new Set([176, 107]); - - const bottomList = new Set([177, 178, 179, 181, 102, 104, 106, 486, 488, 489]); + const bottomList = new Set([177, 178, 179, 181, 102, 104, 106, 486, 488, 489]); let obj = JSON.parse(magicJS.response.body); if (obj["data"]["tab"]) { let tab = obj["data"]["tab"].filter((e) => { @@ -96,7 +100,7 @@ if (magicJS.read(blackKey)) { }); obj["data"]["tab"] = tab; } -// 将 id(222 & 107)调整为Story功能按钮 + // 将 id(222 & 107)调整为Story功能按钮 let storyAid = magicJS.read(storyAidKey); if (!storyAid) { storyAid = "246834163"; @@ -124,11 +128,10 @@ if (magicJS.read(blackKey)) { magicJS.logError(`标签页处理出现异常:${err}`); } break; -// 我的页面处理,去除一些推广按钮 + // 我的页面处理,去除一些推广按钮 case /^https?:\/\/app\.bilibili\.com\/x\/v2\/account\/mine/.test(magicJS.request.url): try { let obj = JSON.parse(magicJS.response.body); - const itemList = new Set([396, 397, 398, 399, 402, 404, 407, 410, 425, 426, 427, 428, 430, 432, 433, 434, 494, 495, 496, 497, 500, 501]); obj["data"]["sections_v2"].forEach((element, index) => { element["items"].forEach((e) => { @@ -144,35 +147,34 @@ if (magicJS.read(blackKey)) { delete obj["data"]["sections_v2"][index].be_up_title; delete obj["data"]["sections_v2"][index].tip_icon; delete obj["data"]["sections_v2"][index].tip_title; -//2022-02-16 add by ddgksf2013 + //2022-02-16 add by ddgksf2013 for (let ii = 0; ii < obj["data"]["sections_v2"].length; ii++) { - if(obj.data.sections_v2[ii].title=='推荐服务'||obj.data.sections_v2[ii].title=='推薦服務'){ -//obj.data.sections_v2[ii].items[0].title='\u516C\u773E\u865F'; -//obj.data.sections_v2[ii].items[1].title='\u58A8\u9B5A\u624B\u8A18'; + if (obj.data.sections_v2[ii].title == "推荐服务" || obj.data.sections_v2[ii].title == "推薦服務") { + //obj.data.sections_v2[ii].items[0].title='\u516C\u773E\u865F'; + //obj.data.sections_v2[ii].items[1].title='\u58A8\u9B5A\u624B\u8A18'; } - if(obj.data.sections_v2[ii].title=='更多服務'||obj.data.sections_v2[ii].title=='更多服务'){ - if(obj.data.sections_v2[ii].items[0].id==500){ -//obj.data.sections_v2[ii].items[0].title='\u516C\u773E\u865F'; + if (obj.data.sections_v2[ii].title == "更多服務" || obj.data.sections_v2[ii].title == "更多服务") { + if (obj.data.sections_v2[ii].items[0].id == 500) { + //obj.data.sections_v2[ii].items[0].title='\u516C\u773E\u865F'; } - if(obj.data.sections_v2[ii].items[1].id==501){ -//obj.data.sections_v2[ii].items[1].title='\u58A8\u9B5A\u624B\u8A18'; + if (obj.data.sections_v2[ii].items[1].id == 501) { + //obj.data.sections_v2[ii].items[1].title='\u58A8\u9B5A\u624B\u8A18'; } } - if(obj.data.sections_v2[ii].title=='创作中心'||obj.data.sections_v2[ii].title=='創作中心'){ + if (obj.data.sections_v2[ii].title == "创作中心" || obj.data.sections_v2[ii].title == "創作中心") { delete obj.data.sections_v2[ii].title; delete obj.data.sections_v2[ii].type; } - } delete obj.data.vip_section_v2; delete obj.data.vip_section; obj["data"]["sections_v2"][index]["items"] = items; -//2022-03-05 add by ddgksf2013 - if(obj.data.hasOwnProperty("live_tip")){ - obj["data"]["live_tip"]={}; + //2022-03-05 add by ddgksf2013 + if (obj.data.hasOwnProperty("live_tip")) { + obj["data"]["live_tip"] = {}; } - if(obj.data.hasOwnProperty("answer")){ - obj["data"]["answer"]={}; + if (obj.data.hasOwnProperty("answer")) { + obj["data"]["answer"] = {}; } obj["data"]["vip_type"] = 2; obj["data"]["vip"]["type"] = 2; @@ -185,7 +187,7 @@ if (magicJS.read(blackKey)) { magicJS.logError(`我的页面处理出现异常:${err}`); } break; -// 直播去广告 + // 直播去广告 case /^https?:\/\/api\.live\.bilibili\.com\/xlive\/app-room\/v1\/index\/getInfoByRoom/.test(magicJS.request.url): try { let obj = JSON.parse(magicJS.response.body); @@ -195,25 +197,38 @@ if (magicJS.read(blackKey)) { magicJS.logError(`直播去广告出现异常:${err}`); } break; -//屏蔽热搜 + // 右上角活动 + case /^https?:\/\/app\.bilibili\.com\/x\/resource\/top\/activity/.test(magicJS.request.url): + try { + let obj = JSON.parse(magicJS.response.body); + if(obj.data){ + obj.data.hash = "ddgksf2013"; + obj.data.online.icon = ""; + } + body = JSON.stringify(obj); + } catch (err) { + magicJS.logError(`右上角去广告出现异常:${err}`); + } + break; + //屏蔽热搜 case /^https?:\/\/app\.bilibili\.com\/x\/v2\/search\/square/.test(magicJS.request.url): try { let obj = JSON.parse(magicJS.response.body); - obj.data={ - "type": "history", - "title": "搜索历史", - "search_hotword_revision": 2 + obj.data = { + type: "history", + title: "搜索历史", + search_hotword_revision: 2, }; body = JSON.stringify(obj); } catch (err) { magicJS.logError(`热搜去广告出现异常:${err}`); } break; -//2022-03-05 add by ddgksf2013 + //2022-03-05 add by ddgksf2013 case /https?:\/\/app\.bilibili\.com\/x\/v2\/account\/myinfo\?/.test(magicJS.request.url): try { let obj = JSON.parse(magicJS.response.body); -//magicJS.logInfo(`公众号墨鱼手记`); + //magicJS.logInfo(`公众号墨鱼手记`); obj["data"]["vip"]["type"] = 2; obj["data"]["vip"]["status"] = 1; obj["data"]["vip"]["vip_pay_type"] = 1; @@ -223,18 +238,18 @@ if (magicJS.read(blackKey)) { magicJS.logError(`1080P出现异常:${err}`); } break; -// 追番去广告 + // 追番去广告 case /pgc\/page\/bangumi/.test(magicJS.request.url): try { let obj = JSON.parse(magicJS.response.body); obj.result.modules.forEach((module) => { -// 头部banner + // 头部banner if (module.style.startsWith("banner")) { -//i.source_content && i.source_content.ad_content - module.items = module.items.filter((i) => !(i.link.indexOf("play")==-1)); + //i.source_content && i.source_content.ad_content + module.items = module.items.filter((i) => !(i.link.indexOf("play") == -1)); } if (module.style.startsWith("function")) { - module.items = module.items.filter((i) => (i.blink.indexOf("www.bilibili.com")==-1)); + module.items = module.items.filter((i) => i.blink.indexOf("www.bilibili.com") == -1); } if (module.style.startsWith("tip")) { module.items = null; @@ -245,17 +260,17 @@ if (magicJS.read(blackKey)) { magicJS.logError(`追番去广告出现异常:${err}`); } break; -// 观影页去广告 + // 观影页去广告 case /pgc\/page\/cinema\/tab\?/.test(magicJS.request.url): try { let obj = JSON.parse(magicJS.response.body); obj.result.modules.forEach((module) => { -// 头部banner + // 头部banner if (module.style.startsWith("banner")) { - module.items = module.items.filter((i) => !(i.link.indexOf("play")==-1)); + module.items = module.items.filter((i) => !(i.link.indexOf("play") == -1)); } if (module.style.startsWith("function")) { - module.items = module.items.filter((i) => (i.blink.indexOf("www.bilibili.com")==-1)); + module.items = module.items.filter((i) => i.blink.indexOf("www.bilibili.com") == -1); } if (module.style.startsWith("tip")) { module.items = null; @@ -266,14 +281,14 @@ if (magicJS.read(blackKey)) { magicJS.logError(`观影页去广告出现异常:${err}`); } break; -// 动态去广告 + // 动态去广告 case /^https?:\/\/api\.vc\.bilibili\.com\/dynamic_svr\/v1\/dynamic_svr\/dynamic_(history|new)\?/.test(magicJS.request.url): try { let obj = JSON.parse(magicJS.response.body); let cards = []; obj.data.cards.forEach((element) => { if (element.hasOwnProperty("display") && element.card.indexOf("ad_ctx") <= 0) { -// 解决number类型精度问题导致B站动态中图片无法打开的问题 + // 解决number类型精度问题导致B站动态中图片无法打开的问题 element["desc"]["dynamic_id"] = element["desc"]["dynamic_id_str"]; element["desc"]["pre_dy_id"] = element["desc"]["pre_dy_id_str"]; element["desc"]["orig_dy_id"] = element["desc"]["orig_dy_id_str"]; @@ -287,26 +302,27 @@ if (magicJS.read(blackKey)) { magicJS.logError(`动态去广告出现异常:${err}`); } break; -// 去除统一设置的皮肤 + // 去除统一设置的皮肤 case /^https?:\/\/app\.bilibili\.com\/x\/resource\/show\/skin\?/.test(magicJS.request.url): try { let obj = JSON.parse(magicJS.response.body); - if (obj && obj.hasOwnProperty("data")&&obj.data.hasOwnProperty("common_equip")&&obj.data.common_equip.hasOwnProperty("package_url")) { -//obj["data"]["common_equip"]["package_url"] = ""; + if (obj && obj.hasOwnProperty("data") && obj.data.hasOwnProperty("common_equip") && obj.data.common_equip.hasOwnProperty("package_url")) { + //obj["data"]["common_equip"]["package_url"] = ""; } body = JSON.stringify(obj); } catch (err) { magicJS.logError(`去除强制设置的皮肤出现异常:${err}`); } break; -// 开屏广告(预加载)如果粗暴地关掉,那么就使用预加载的数据,就会导致关不掉 + // 开屏广告(预加载)如果粗暴地关掉,那么就使用预加载的数据,就会导致关不掉 case /^https:\/\/app\.bilibili\.com\/x\/v2\/splash\/list/.test(magicJS.request.url): try { let obj = JSON.parse(magicJS.response.body); - if(obj.data){ + if (obj.data) { for (let item of obj["data"]["list"]) { - item["duration"] = 0; // 显示时间 -// 2040 年 + item["duration"] = 0; + // 显示时间 + // 2040 年 item["begin_time"] = 2240150400; item["end_time"] = 2240150400; } @@ -324,11 +340,14 @@ if (magicJS.read(blackKey)) { magicJS.logWarning("触发意外的请求处理,请确认脚本或复写配置正常。"); } if (body) { - magicJS.done({ body }); + magicJS.done({ + body, + }); } else { magicJS.done(); } })(); + // prettier-ignore function MagicJS(scriptName="MagicJS",logLevel="INFO"){return new class{constructor(){if(this.version="2.2.3.3",this.scriptName=scriptName,this.logLevels={DEBUG:5,INFO:4,NOTIFY:3,WARNING:2,ERROR:1,CRITICAL:0,NONE:-1},this.isLoon="undefined"!=typeof $loon,this.isQuanX="undefined"!=typeof $task,this.isJSBox="undefined"!=typeof $drive,this.isNode="undefined"!=typeof module&&!this.isJSBox,this.isSurge="undefined"!=typeof $httpClient&&!this.isLoon,this.node={request:void 0,fs:void 0,data:{}},this.iOSUserAgent="Mozilla/5.0 (iPhone; CPU iPhone OS 13_3_1 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/13.0.5 Mobile/15E148 Safari/604.1",this.pcUserAgent="Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/84.0.4147.125 Safari/537.36 Edg/84.0.522.59",this.logLevel=logLevel,this._barkUrl="",this.isNode){this.node.fs=require("fs"),this.node.request=require("request");try{this.node.fs.accessSync("./magic.json",this.node.fs.constants.R_OK|this.node.fs.constants.W_OK)}catch(err){this.node.fs.writeFileSync("./magic.json","{}",{encoding:"utf8"})}this.node.data=require("./magic.json")}else this.isJSBox&&($file.exists("drive://MagicJS")||$file.mkdir("drive://MagicJS"),$file.exists("drive://MagicJS/magic.json")||$file.write({data:$data({string:"{}"}),path:"drive://MagicJS/magic.json"}))}set barkUrl(url){this._barkUrl=url.replace(/\/+$/g,"")}set logLevel(level){this._logLevel="string"==typeof level?level.toUpperCase():"DEBUG"}get logLevel(){return this._logLevel}get isRequest(){return"undefined"!=typeof $request&&"undefined"==typeof $response}get isResponse(){return"undefined"!=typeof $response}get request(){return"undefined"!=typeof $request?$request:void 0}get response(){return"undefined"!=typeof $response?($response.hasOwnProperty("status")&&($response.statusCode=$response.status),$response.hasOwnProperty("statusCode")&&($response.status=$response.statusCode),$response):void 0}get platform(){return this.isSurge?"Surge":this.isQuanX?"Quantumult X":this.isLoon?"Loon":this.isJSBox?"JSBox":this.isNode?"Node.js":"Unknown"}read(key,session=""){let val="";this.isSurge||this.isLoon?val=$persistentStore.read(key):this.isQuanX?val=$prefs.valueForKey(key):this.isNode?val=this.node.data:this.isJSBox&&(val=$file.read("drive://MagicJS/magic.json").string);try{this.isNode&&(val=val[key]),this.isJSBox&&(val=JSON.parse(val)[key]),session&&("string"==typeof val&&(val=JSON.parse(val)),val=val&&"object"==typeof val?val[session]:null)}catch(err){this.logError(err),val=session?{}:null,this.del(key)}void 0===val&&(val=null);try{val&&"string"==typeof val&&(val=JSON.parse(val))}catch(err){}return this.logDebug(`READ DATA [${key}]${session?`[${session}]`:""}(${typeof val})\n${JSON.stringify(val)}`),val}write(key,val,session=""){let data=session?{}:"";if(session&&(this.isSurge||this.isLoon)?data=$persistentStore.read(key):session&&this.isQuanX?data=$prefs.valueForKey(key):this.isNode?data=this.node.data:this.isJSBox&&(data=JSON.parse($file.read("drive://MagicJS/magic.json").string)),session){try{"string"==typeof data&&(data=JSON.parse(data)),data="object"==typeof data&&data?data:{}}catch(err){this.logError(err),this.del(key),data={}}this.isJSBox||this.isNode?(data[key]&&"object"==typeof data[key]||(data[key]={}),data[key].hasOwnProperty(session)||(data[key][session]=null),void 0===val?delete data[key][session]:data[key][session]=val):void 0===val?delete data[session]:data[session]=val}else this.isNode||this.isJSBox?void 0===val?delete data[key]:data[key]=val:data=void 0===val?null:val;"object"==typeof data&&(data=JSON.stringify(data)),this.isSurge||this.isLoon?$persistentStore.write(data,key):this.isQuanX?$prefs.setValueForKey(data,key):this.isNode?this.node.fs.writeFileSync("./magic.json",data):this.isJSBox&&$file.write({data:$data({string:data}),path:"drive://MagicJS/magic.json"}),this.logDebug(`WRITE DATA [${key}]${session?`[${session}]`:""}(${typeof val})\n${JSON.stringify(val)}`)}del(key,session=""){this.logDebug(`DELETE KEY [${key}]${session?`[${session}]`:""}`),this.write(key,null,session)}notify(title=this.scriptName,subTitle="",body="",opts=""){let convertOptions;if(opts=(_opts=>{let newOpts={};if("string"==typeof _opts)this.isLoon?newOpts={openUrl:_opts}:this.isQuanX?newOpts={"open-url":_opts}:this.isSurge&&(newOpts={url:_opts});else if("object"==typeof _opts)if(this.isLoon)newOpts.openUrl=_opts["open-url"]?_opts["open-url"]:"",newOpts.mediaUrl=_opts["media-url"]?_opts["media-url"]:"";else if(this.isQuanX)newOpts=_opts["open-url"]||_opts["media-url"]?_opts:{};else if(this.isSurge){let openUrl=_opts["open-url"]||_opts.openUrl;newOpts=openUrl?{url:openUrl}:{}}return newOpts})(opts),1==arguments.length&&(title=this.scriptName,subTitle="",body=arguments[0]),this.logNotify(`title:${title}\nsubTitle:${subTitle}\nbody:${body}\noptions:${"object"==typeof opts?JSON.stringify(opts):opts}`),this.isSurge)$notification.post(title,subTitle,body,opts);else if(this.isLoon)opts?$notification.post(title,subTitle,body,opts):$notification.post(title,subTitle,body);else if(this.isQuanX)$notify(title,subTitle,body,opts);else if(this.isNode){if(this._barkUrl){let content=encodeURI(`${title}/${subTitle}\n${body}`);this.get(`${this._barkUrl}/${content}`,()=>{})}}else if(this.isJSBox){let push={title:title,body:subTitle?`${subTitle}\n${body}`:body};$push.schedule(push)}}notifyDebug(title=this.scriptName,subTitle="",body="",opts=""){"DEBUG"===this.logLevel&&(1==arguments.length&&(title=this.scriptName,subTitle="",body=arguments[0]),this.notify(title,subTitle,body,opts))}log(msg,level="INFO"){this.logLevels[this._logLevel]void 0===_options.body?"":`${encodeURIComponent(key)}=${encodeURIComponent(_options.body[key])}`).join("&");_options.url.indexOf("?")<0&&(_options.url+="?"),_options.url.lastIndexOf("&")+1!=_options.url.length&&_options.url.lastIndexOf("?")+1!=_options.url.length&&(_options.url+="&"),_options.url+=qs,delete _options.body}return this.isQuanX?(_options.hasOwnProperty("body")&&"string"!=typeof _options.body&&(_options.body=JSON.stringify(_options.body)),_options.method=method):this.isNode?(delete _options.headers["Accept-Encoding"],"object"==typeof _options.body&&("GET"===method?(_options.qs=_options.body,delete _options.body):"POST"===method&&(_options.json=!0,_options.body=_options.body))):this.isJSBox&&(_options.header=_options.headers,delete _options.headers),_options}adapterHttpResponse(resp){let _resp={body:resp.body,headers:resp.headers,json:()=>JSON.parse(_resp.body)};return resp.hasOwnProperty("statusCode")&&resp.statusCode&&(_resp.status=resp.statusCode),_resp}get(options,callback){let _options=this.adapterHttpOptions(options,"GET");this.logDebug(`HTTP GET: ${JSON.stringify(_options)}`),this.isSurge||this.isLoon?$httpClient.get(_options,callback):this.isQuanX?$task.fetch(_options).then(resp=>{resp.status=resp.statusCode,callback(null,resp,resp.body)},reason=>callback(reason.error,null,null)):this.isNode?this.node.request.get(_options,(err,resp,data)=>{resp=this.adapterHttpResponse(resp),callback(err,resp,data)}):this.isJSBox&&(_options.handler=resp=>{let err=resp.error?JSON.stringify(resp.error):void 0,data="object"==typeof resp.data?JSON.stringify(resp.data):resp.data;callback(err,resp.response,data)},$http.get(_options))}getPromise(options){return new Promise((resolve,reject)=>{magicJS.get(options,(err,resp)=>{err?reject(err):resolve(resp)})})}post(options,callback){let _options=this.adapterHttpOptions(options,"POST");if(this.logDebug(`HTTP POST: ${JSON.stringify(_options)}`),this.isSurge||this.isLoon)$httpClient.post(_options,callback);else if(this.isQuanX)$task.fetch(_options).then(resp=>{resp.status=resp.statusCode,callback(null,resp,resp.body)},reason=>{callback(reason.error,null,null)});else if(this.isNode){let resp=this.node.request.post(_options,callback);resp.status=resp.statusCode,delete resp.statusCode}else this.isJSBox&&(_options.handler=resp=>{let err=resp.error?JSON.stringify(resp.error):void 0,data="object"==typeof resp.data?JSON.stringify(resp.data):resp.data;callback(err,resp.response,data)},$http.post(_options))}get http(){return{get:this.getPromise,post:this.post}}done(value={}){"undefined"!=typeof $done&&$done(value)}isToday(day){if(null==day)return!1;{let today=new Date;return"string"==typeof day&&(day=new Date(day)),today.getFullYear()==day.getFullYear()&&today.getMonth()==day.getMonth()&&today.getDay()==day.getDay()}}isNumber(val){return"NaN"!==parseFloat(val).toString()}attempt(promise,defaultValue=null){return promise.then(args=>[null,args]).catch(ex=>(this.logError(ex),[ex,defaultValue]))}retry(fn,retries=5,interval=0,callback=null){return(...args)=>new Promise((resolve,reject)=>{function _retry(...args){Promise.resolve().then(()=>fn.apply(this,args)).then(result=>{"function"==typeof callback?Promise.resolve().then(()=>callback(result)).then(()=>{resolve(result)}).catch(ex=>{retries>=1?interval>0?setTimeout(()=>_retry.apply(this,args),interval):_retry.apply(this,args):reject(ex),retries--}):resolve(result)}).catch(ex=>{this.logRetry(ex),retries>=1&&interval>0?setTimeout(()=>_retry.apply(this,args),interval):retries>=1?_retry.apply(this,args):reject(ex),retries--})}_retry.apply(this,args)})}formatTime(time,fmt="yyyy-MM-dd hh:mm:ss"){var o={"M+":time.getMonth()+1,"d+":time.getDate(),"h+":time.getHours(),"m+":time.getMinutes(),"s+":time.getSeconds(),"q+":Math.floor((time.getMonth()+3)/3),S:time.getMilliseconds()};/(y+)/.test(fmt)&&(fmt=fmt.replace(RegExp.$1,(time.getFullYear()+"").substr(4-RegExp.$1.length)));for(let k in o)new RegExp("("+k+")").test(fmt)&&(fmt=fmt.replace(RegExp.$1,1==RegExp.$1.length?o[k]:("00"+o[k]).substr((""+o[k]).length)));return fmt}now(){return this.formatTime(new Date,"yyyy-MM-dd hh:mm:ss")}today(){return this.formatTime(new Date,"yyyy-MM-dd")}sleep(time){return new Promise(resolve=>setTimeout(resolve,time))}}(scriptName)} \ No newline at end of file