您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
可以免费观看海角社区钻石和金币付费帖子、vip帖子,包括视频、图片、音频。
// ==UserScript== // @name 海角社区免费版 // @namespace http://tampermonkey.net/ // @version 0.1.2 // @description 可以免费观看海角社区钻石和金币付费帖子、vip帖子,包括视频、图片、音频。 // @author JamToday // @match https://*.haijiao.com/* // @include *://hj*.*/* // @include *://*.hj*.*/* // @include *://*.hai*.*/* // @include *://hai*.*/* // @include *://hj*/* // @include *://*.hj*/* // @include */post/details/* // @match *://*/post/details* // @exclude *://hjai*/* // @exclude *://haijiao.ai/* // @exclude *://haijiao.pro/* // @exclude *://*.kittymao.xyz/* // @exclude https://hjfb.org/* // @exclude *://tool.liumingye.cn/* // @icon https://www.hjadbf.top/images/common/project/favicon.ico // @grant none // @run-at document-start // ==/UserScript== (function () { let kitty_StatusColor = { success: "#67C23A", warning: "#E6A23C", info: "#909399", danger: "#F56C6C", 200: "#67C23A", 300: "#E6A23C", 400: "#909399", 500: "#F56C6C", }; let kitty_config = { name: "海角社区免费版", id: "hjfree", version: "0.1.2", homePageName: "kitty猫", homePageUrl: "www.kittymao.xyz", update: 3, logListMaxLength: 19, logItemLength: 20, updateUrl: "https://sleazyfork.org/zh-CN/scripts/440819-cao", requestHostList: ["https://baixiaodu.uk/api"], }; let kitty_isrun = { getNewVersion: false, }; let kitty_tabIndex = 0; let kitty_logListTarget = []; let kitty_logList = new Proxy(kitty_logListTarget, { set: function (target, property, value) { if (property === "length") { console.log("Cannot change the length of the array."); return true; } else { target[property] = value; let appendDiv = document.createElement("div"); appendDiv.innerHTML = value; let kitty_logListDiv = document.getElementsByClassName("kitty_logList")[0]; kitty_logListDiv.appendChild(appendDiv); return true; } }, }); function kitty_setCookie(cname, cvalue, exdays) { var d = new Date(); d.setTime(d.getTime() + exdays * 24 * 60 * 60 * 1000); var expires = "expires=" + d.toGMTString(); document.cookie = cname + "=" + cvalue + "; " + expires; } function kitty_insertStyle() { let style = document.createElement("style"); style.innerHTML = ` /* 整体-start */ #kitty_vipPanel { width: 310px; height: 500px; box-shadow: 0 0 0 1px rgb(0 0 0 / 5%), 0 2px 4px 1px rgb(0 0 0 / 9%); border-left: 1px solid transparent; border-right: none; border-top: 1px solid transparent; border-bottom: 1px solid transparent; background-color: #FFFFFF; position: fixed; left: 6px; bottom: 6px; z-index: 99999; font-size: 16px; --script-panel-main-color: #4178b0; } #kitty_vipPanel a { text-decoration: underline; } .kitty_panelMain { font-size: 0.85em; } .kitty_hiddenPanel { left: -310px !important; } /* 整体-end */ /* panelHead-start */ .kitty_panelHead { display: flex; border-bottom: 1px solid #ececec; } .kitty_panelHead>div { color: #444; padding: 0 10px; height: 40px; line-height: 40px; box-sizing: border-box; user-select: none; text-align: center; width: 76px; font-size: 1em; } .kitty_panelHead>div:not(.kitty_headDivActive):hover { border-bottom: 3px solid #ccc; cursor: pointer; } .kitty_headDivActive { border-bottom: 3px solid var(--script-panel-main-color); color: #444; font-weight: bold; } /* panelHead-end */ /* 界面显示按钮 */ .kitty_showPanelBtn, .kitty_jiexiBtn { position: absolute; left: 320px; top: 150px; width: 50px; height: 50px; line-height: 50px; color: var(--script-panel-main-color); user-select: none; background-color: #FFFFFF; position: absolute; bottom: 20px; display: none; cursor: pointer; border-radius: 50px; text-align: center; box-shadow:0 0 0 1px rgb(0 0 0 / 5%), 0 2px 4px 1px rgb(0 0 0 / 9%); } .kitty_jiexiBtn { top: 85px; } /* 身体 */ .kitty_panelBody { padding: 0 10px; } .kitty_panelBody p { margin: 10px 0; } /* 输入框-start */ .kitty_searchInput { width: 98%; border-radius: 24px; box-shadow: 0 0 0 1px rgb(0 0 0 / 5%), 0 2px 4px 1px rgb(0 0 0 / 9%); height: 40px; border-left: 1px solid transparent; border-right: none; border-top: 1px solid transparent; border-bottom: 1px solid transparent; overflow: hidden; margin: 0 auto; margin-top: 40px; margin-bottom: 50px; display: flex; } .kitty_searchInput:hover { border-top-left-radius: 24px; box-shadow: 0 0 0 1px rgb(0 0 0 / 10%), 0 2px 4px 1px rgb(0 0 0 / 18%); border-left: 1px solid transparent; border-right: none; border-top: 1px solid transparent; border-bottom: 1px solid transparent; } .kitty_searchInput input { height: 100%; border: 0; outline: 0; padding: 0 10px; color: black; width: 100%; } /* 输入框-end */ /* go按钮-start */ .kitty_goToVipBtn { color: #FFFFFF; font-weight: bold; background-color: var(--script-panel-main-color); height: 100px; width: 100px; border-radius: 50px; text-align: center; line-height: 100px; margin: 20px auto; box-shadow: 0 0 0 1px rgb(0 0 0 / 5%), 0 2px 4px 1px rgb(0 0 0 / 9%); user-select: none; } .kitty_goToVipBtn:hover { cursor: pointer; box-shadow: 0 0 0 0 rgb(0 0 0 / 5%), 0 2px 4px 1px rgb(0 0 0 / 18%); -webkit-box-shadow: 0 0 0 0 rgb(0 0 0 / 5%), 0 2px 4px 1px rgb(0 0 0 / 18%); -moz-box-shadow: 0 0 0 0 rgba(0,0,0,.05),0 2px 4px 1px rgba(0,0,0,.18); } /* 动画 */ @keyframes kitty_float { 0% { transform: translateY(0px); } 5% { transform: translateY(-10px); } 10%,100% { transform: translateY(0px); } } .kitty_navy { position: relative; } .kitty_navy span { position: relative; display: inline-block; color: white; animation: kitty_float 9s ease-in-out infinite; animation-delay: 2s; font-size: 1.5em; } /* go按钮-end */ .kitty_logOutput { color: #71777d; font-size: 0.9em; margin-top: 10px; } .kitty_logOutput div { margin: 0; padding: 0; line-height: 1.5; } .kitty_downloadText { font-size: 20px; font-weight: bold; } .kitty_downloadText a { cursor:pointer; } `; document.querySelector("head").appendChild(style); } function kitty_createPanel() { let panel = document.createElement("div"); panel.setAttribute("id", "kitty_vipPanel"); panel.innerHTML = ` <div class="kitty_showPanelBtn">显示</div> <div class="kitty_jiexiBtn">解析</div> <div class="kitty_panelMain"> <div class="kitty_panelHead"> <div class="kitty_headDivActive">运行日志</div> <div>重要说明</div> <div>使用指南</div> </div> <div class="kitty_panelBody kitty_panelBody_0"> <div class="kitty_logOutput"> <div>脚本--><span class="kitty_scriptName"></span>-<span class="kitty_version"></span>-<span class="kitty_update"></span></div> <div>主页--><a class="kitty_homepage" target="_blank" href="">主页地址</a></div> <div>邮箱-->[email protected]</div> <div>操作--><span style="color: red;cursor:pointer;" class="kitty_hiddenPanelBtn">点此隐藏此脚本操作界面<<</span></div> <div class="kitty_logList"> </div> </div> </div> <div class="kitty_panelBody kitty_panelBody_1" style="display:none;"> <p>+ 本脚本完全免费</p> <p>+ 本脚本无恶意代码放心使用</p> <p>+ 更多脚本可看 <a target="_blank" href="https://docs.kittymao.xyz">www.kittymao.xyz</a></p> <p>+ 脚本仅支持正版海角</p> <p>+ 如果脚本在非正版海角网站运行, 请关闭即可</p> </div> <div class="kitty_panelBody kitty_panelBody_2" style="display:none;"> <p>+ 使用方法线路1: <a target="_blank" href="https://www.kittymao.xyz">www.kittymao.xyz</a></p> </div> </div> `; document.body.appendChild(panel); let ishidden = localStorage.getItem("kitty_isHiddenPanel"); if (ishidden) { ishidden = JSON.parse(ishidden); if (ishidden) { kitty_hiddenPanel(); } else { kitty_showPanel(); } } } function kitty_eventBind() { let tabs = document.querySelectorAll(".kitty_panelHead>div"); for (let i = 0; i < tabs.length; i++) { tabs[i].addEventListener("click", function () { for (let ii = 0; ii < tabs.length; ii++) { tabs[ii].className = ""; } tabs[i].className = "kitty_headDivActive"; kitty_changeTab(i); }); } document .querySelector(".kitty_hiddenPanelBtn") .addEventListener("click", function () { kitty_hiddenPanel(); }); document .querySelector(".kitty_showPanelBtn") .addEventListener("click", function () { kitty_showPanel(); }); document .querySelector(".kitty_jiexiBtn") .addEventListener("click", function () { if (location.href.includes("post/details?pid")) { if (kitty_isLogin()) { document.querySelector(".kitty_jiexiBtn").innerHTML = "稍等"; } else { document.querySelector(".kitty_jiexiBtn").innerHTML = "暂无"; kitty_checkLogin(); kitty_showPanel(); } } else { document.querySelector(".kitty_jiexiBtn").innerHTML = "暂无"; } }); } function kitty_changeTab(index) { kitty_tabIndex = index; let panelBodys = document.querySelectorAll(".kitty_panelBody"); if (!panelBodys[kitty_tabIndex]) { return; } for (let i = 0; i < panelBodys.length; i++) { panelBodys[i].style.display = "none"; } panelBodys[kitty_tabIndex].style.display = "block"; } function kitty_hiddenPanel() { document.querySelector("#kitty_vipPanel").className = "kitty_hiddenPanel"; document.querySelector(".kitty_showPanelBtn").style.display = "block"; document.querySelector(".kitty_jiexiBtn").style.display = "block"; localStorage.setItem("kitty_isHiddenPanel", JSON.stringify(true)); } function kitty_showPanel() { document.querySelector("#kitty_vipPanel").className = ""; document.querySelector(".kitty_showPanelBtn").style.display = "none"; document.querySelector(".kitty_jiexiBtn").style.display = "none"; localStorage.setItem("kitty_isHiddenPanel", JSON.stringify(false)); } function kitty_getSuccessHost() { let successHost = localStorage.getItem("kitty_requestSuccessHost"); if (successHost) { let findIndex = kitty_config.requestHostList.indexOf(successHost); if (findIndex != -1) { kitty_config.requestHostList.splice(findIndex, 1); kitty_config.requestHostList.unshift(successHost); } } } function kitty_getHost(index) { return kitty_config.requestHostList[index]; } function kitty_getStatusTypeText(type) { let typeText = "提示"; switch (type) { case "success": typeText = "成功"; break; case "warning": typeText = "警告"; break; case "info": typeText = "信息"; break; case "danger": typeText = "失败"; break; case "200": typeText = "成功"; break; case "300": typeText = "警告"; break; case "400": typeText = "信息"; break; case "500": typeText = "失败"; break; } return typeText; } function kitty_logListPush(item, type, isDom) { if (kitty_logList.length >= kitty_config.logListMaxLength) { kitty_logListShift(); } let stringLength = item.length; let start = 0; let end = kitty_config.logItemLength - 1; let headLine = true; let typeText = `${kitty_getStatusTypeText(type)}-->`; let styleColor = ""; if (type) { styleColor = type ? `color: ${kitty_StatusColor[type]}` : ""; } if (isDom) { let pushStr = `<span style="${styleColor}">${typeText}${item}</span>`; kitty_logList.push(pushStr); } else { while (stringLength >= 0) { let pushStr = `<span style="${styleColor}">${ headLine ? typeText : '<span style="opacity: 0;">续行--</span>>' }${item.substring(start, end)}</span>`; kitty_logList.push(pushStr); start = end; end += end; stringLength = stringLength - kitty_config.logItemLength; headLine = false; } } // kitty_showLogList(); } function kitty_logListShift() { kitty_logListTarget.shift(); let kitty_logListChild0 = document.querySelectorAll(".kitty_logList div")[0]; kitty_logListChild0.remove(); // kitty_showLogList(); } function kitty_setConfig() { document.getElementsByClassName("kitty_scriptName")[0].innerHTML = kitty_config.name; document.getElementsByClassName( "kitty_version" )[0].innerHTML = `v${kitty_config.version}`; let homepage = document.getElementsByClassName("kitty_homepage")[0]; homepage.innerHTML = kitty_config.homePageName + `(${kitty_config.homePageUrl})`; homepage.href = "https://" + kitty_config.homePageUrl; if (kitty_config.update === 1) { let versionSpan = document.getElementsByClassName("kitty_update")[0]; versionSpan.innerHTML = `已最新`; versionSpan.style = `color: ${kitty_StatusColor.success};`; } else if (kitty_config.update === 2) { let versionSpan = document.getElementsByClassName("kitty_update")[0]; versionSpan.innerHTML = `<span class="kitty_toNewVersion" style="user-select: none;cursor: pointer;">点此更新</span>`; versionSpan.style = `color: ${kitty_StatusColor.warning};`; document .querySelector(".kitty_toNewVersion") .addEventListener("click", function () { window.open(kitty_config.updateUrl); }); } else { let versionSpan = document.getElementsByClassName("kitty_update")[0]; versionSpan.innerHTML = `<span class="kitty_checkVersion" style="user-select: none;cursor: pointer;">检查更新</span>`; versionSpan.style = `color: ${kitty_StatusColor.warning};`; document .querySelector(".kitty_checkVersion") .addEventListener("click", function () { kitty_getNewVersion(0, false); }); } } function kitty_getNewVersion(index, change) { if (kitty_isrun.getNewVersion && !change) { return; } let host = kitty_getHost(index); if (!change) { kitty_logListPush("检查版本号中请耐心等待...", "info"); } kitty_isrun.getNewVersion = true; let url = `${host}/getVersion`; fetch(url, { method: "post", headers: { "Content-Type": "application/json", }, body: JSON.stringify({ nickname: "hjfree", }), }) .then((res) => res.json()) .then((res) => { localStorage.setItem("kitty_requestSuccessHost", host); try { let data = res.data; if (data.version === kitty_config.version) { kitty_config.update = 1; kitty_logListPush("已是最新版", "success"); } else { kitty_config.update = 2; kitty_config.updateUrl = data.updateUrl; kitty_logListPush("不是最新版,可能无法使用", "warning"); } kitty_setConfig(); } catch (e) { kitty_logListPush("失败,返回值处理有问题", "danger"); console.log(e); } kitty_isrun.getNewVersion = false; }) .catch((e) => { if (e.toString().includes("JSON")) { kitty_logListPush("JSON解析失败,请联系作者", "danger"); kitty_isrun.getNewVersion = false; } else { console.log(e); index++; let getHost = kitty_getHost(index); if (getHost) { kitty_logListPush("请求失败,切换线路中请耐心等待...", "warning"); kitty_getNewVersion(index, true); } else { kitty_logListPush("请求失败,请联系作者", "danger"); kitty_isrun.getPermission = false; } } }); } function kitty_vipPanelInit() { kitty_insertStyle(); kitty_createPanel(); kitty_getSuccessHost(); kitty_eventBind(); kitty_setConfig(); } // ------------------------------------------ // ------------------------------------------ // ------------------------------------------ let kitty_icons = { toTop: "", close: "", }; let kitty_utils = { getCookie: function (name) { const cookies = document.cookie.split(";"); // 将 document.cookie 拆分为多个 Cookie 字符串 for (const cookie of cookies) { const [cookieName, cookieValue] = cookie.split("="); const trimmedCookieName = cookieName.trim(); // 去除空格 if (trimmedCookieName === name) { return decodeURIComponent(cookieValue); // 解码 Cookie 值 } } return null; // 没有找到匹配的 Cookie }, hjApiDecode: function (data) { let res; try { res = JSON.parse(atob(atob(atob(data)))); } catch (e) { console.log("ab error"); return ""; } return res; }, hjApiEecode: function (data) { return btoa(btoa(btoa(JSON.stringify(data)))); }, getElement: function (selector) { return new Promise((success, reject) => { let ele; function querySelectorAll_() { ele = document.querySelectorAll(selector); if (ele.length != 0) { success(ele); return true; } else { return false; } } if (!querySelectorAll_()) { let count = 1; let interval = setInterval(() => { if (count > 75) { reject("未获取元素: ", selector); clearInterval(interval); } if (!querySelectorAll_()) { count++; } else { success(ele); clearInterval(interval); } }, 50); } }); }, isMobileDevice: function () { return /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test( navigator.userAgent ); }, }; let isMobileDevice = kitty_utils.isMobileDevice(); function kitty_hjPicEdcoder() { var e = "ABCD*EFGHIJKLMNOPQRSTUVWX#YZabcdefghijklmnopqrstuvwxyz1234567890", t = ((this.encode = function (i) { var a, n, o, r, s, c, l = "", d = 0; for (i = t(i); d < i.length; ) (o = (a = i.charCodeAt(d++)) >> 2), (r = ((3 & a) << 4) | ((a = i.charCodeAt(d++)) >> 4)), (s = ((15 & a) << 2) | ((n = i.charCodeAt(d++)) >> 6)), (c = 63 & n), isNaN(a) ? (s = c = 64) : isNaN(n) && (c = 64), (l = l + e.charAt(o) + e.charAt(r) + e.charAt(s) + e.charAt(c)); return l; }), (this.decode = function (t) { var a, n, o, r, s, c, l = "", d = 0; for (t = t.replace(/[^A-Za-z0-9\*\#]/g, ""); d < t.length; ) (o = e.indexOf(t.charAt(d++))), (a = ((15 & (r = e.indexOf(t.charAt(d++)))) << 4) | ((s = e.indexOf(t.charAt(d++))) >> 2)), (n = ((3 & s) << 6) | (c = e.indexOf(t.charAt(d++)))), (l += String.fromCharCode((o << 2) | (r >> 4))), 64 != s && (l += String.fromCharCode(a)), 64 != c && (l += String.fromCharCode(n)); return i(l); }), function (e) { e = e.replace(/\r\n/g, "\n"); for (var t = "", i = 0; i < e.length; i++) { var a = e.charCodeAt(i); a < 128 ? (t += String.fromCharCode(a)) : (t = 127 < a && a < 2048 ? (t += String.fromCharCode((a >> 6) | 192)) + String.fromCharCode((63 & a) | 128) : (t = (t += String.fromCharCode((a >> 12) | 224)) + String.fromCharCode(((a >> 6) & 63) | 128)) + String.fromCharCode((63 & a) | 128)); } return t; }), i = function (e) { for (var t, i, a = "", n = 0, o = 0; n < e.length; ) (t = e.charCodeAt(n)) < 128 ? ((a += String.fromCharCode(t)), n++) : 191 < t && t < 224 ? ((o = e.charCodeAt(n + 1)), (a += String.fromCharCode(((31 & t) << 6) | (63 & o))), (n += 2)) : ((o = e.charCodeAt(n + 1)), (i = e.charCodeAt(n + 2)), (a += String.fromCharCode( ((15 & t) << 12) | ((63 & o) << 6) | (63 & i) )), (n += 3)); return a; }; } let kitty_topicData = null function kitty_coverAddContent(innerhtml) { kitty_utils.getElement(".kitty_coverInnerBox").then((ele) => { let element = ele[0]; let p = document.createElement("p"); p.innerHTML = innerhtml; element.append(p); }); } // 请求拦截 function kitty_xhrIntercept() { let xhrOpen = XMLHttpRequest.prototype.open; XMLHttpRequest.prototype.open = function (method, url, async) { if (location.href.includes("post/details?pid")) { if (url.includes("hjstore/images")) { kitty_cacheImgs(method, url, this); } const locationParams = new URLSearchParams(location.search); const pid = locationParams.get("pid"); if (url.includes("api/topic/" + pid)) { let kitty_topicDataTarget = { hasVideo: false, hasAudio: false, hasPic: false, saleType: 0, // 0:不出售 1:金币 2:钻石 vipLimit: 0, // 0:不需要vip 1:需要vip1级 2:需要vip2级 3:... picsList: [], audsList: [], videoData: null, isFree: false, topicId: 0, imageInserted: [], catchedImgs: null, wholeM3u8Url: null, wholeM3u8UrlType: "", picDomList: [], topicDataSetOver: false, createTime: "", isH5: isMobileDevice, runHref: "", codeList: null, }; kitty_topicData = new Proxy(kitty_topicDataTarget, { get: (target, key, proxy) => { return target[key]; }, set: (target, key, value, proxy) => { if (target[key] !== value) { target[key] = value; if (key == "topicDataSetOver") { kitty_topicDataSetOver(); } if (key == "wholeM3u8Url") { kitty_insertVideoDom(); } } return true; }, }); } let onreadystatechange_ = this.onreadystatechange; this.onreadystatechange = function () { if (this.readyState == 4 && this.status == 200) { kitty_xhrResponseProcess(method, url, this); } if (onreadystatechange_) { onreadystatechange_(); } }; if (isMobileDevice) { // 手机端 let onload_ = this.onload; this.onload = function () { kitty_xhrResponseProcess(method, url, this); if (onload_) { onload_(); } }; } } return xhrOpen.call(this, method, url, async); }; } // 请求前处理 function kitty_cacheImgs(method, url, xhr) { if (url.includes("hjstore/images")) { if (kitty_topicData.hasPic) { if (!kitty_topicData.catchedImgs) { kitty_topicData.catchedImgs = []; } let find = kitty_topicData.catchedImgs.find((item) => { return item.url == url; }); if (!find) { kitty_topicData.catchedImgs.push({ url: url, data: null, }); } } } } // 请求后返回值处理 function kitty_xhrResponseProcess(method, url, xhr) { const locationParams = new URLSearchParams(location.search); const pid = locationParams.get("pid"); if (url.includes("api/topic/" + pid)) { let responseText = JSON.parse(xhr.responseText); let decodeData = kitty_utils.hjApiDecode(responseText.data); let newData = kitty_utils.hjApiEecode(kitty_setTopicData(decodeData)); responseText.data = newData; let jsonRes = JSON.stringify(responseText); Object.defineProperty(xhr, "responseText", { get: () => { return jsonRes; }, }); Object.defineProperty(xhr, "response", { get: () => { return jsonRes; }, }); } if (url.includes("hjstore/images")) { let findCatchedImg = kitty_topicData.catchedImgs.find((item) => { return item.url == url; }); if (findCatchedImg) { if (!findCatchedImg.data) { findCatchedImg.data = new kitty_hjPicEdcoder().decode( xhr.responseText ); let findImgDom = kitty_topicData.picDomList.find((item) => { return item.dataset.imgUrl == url; }); if (findImgDom) { findImgDom.src = findCatchedImg.data; } } } } } // /api/topic/id 接口返回值处理 function kitty_setTopicData(data) { const locationParams = new URLSearchParams(location.search); const pid = locationParams.get("pid"); kitty_topicData.topicId = pid; if (data.sale) { // 付费类型 kitty_topicData.saleType = data.sale.money_type; } let hasAudio = false; let hasVideo = false; let hasPic = false; // 附件处理 data.attachments.forEach((item) => { if (item.category == "images") { hasPic = true; kitty_topicData.picsList.push(item.remoteUrl); } else if (item.category == "video") { hasVideo = true; kitty_topicData.videoData = item; } else if (item.category == "audio") { hasAudio = true; kitty_topicData.audsList.push(item.remoteUrl); } }); if (hasPic) { kitty_topicData.hasPic = true; } if (hasVideo) { kitty_topicData.hasVideo = true; } if (hasAudio) { kitty_topicData.hasAudio = true; } if (data.node) { kitty_topicData.vipLimit = data.node.vipLimit; // 去除viplimit弹框 data.node.vipLimit = 0; } // 是否是免费 if (!data.sale && kitty_topicData.vipLimit == 0) { kitty_topicData.isFree = true; } kitty_topicData.createTime = data.createTime; kitty_topicData.topicDataSetOver = true; //delete data.content return data; } // 如果是vip内容 function kitty_topicViplimit() { if (kitty_topicData.vipLimit > 0) { if (kitty_topicData.hasPic) { let count = 0; let interval = setInterval(() => { if (count >= kitty_topicData.picsList.length) { return clearInterval(interval); } let item = kitty_topicData.picsList[count]; let x = new XMLHttpRequest(); x.open("get", item); x.send(); count++; }, 500); } } } // 插入图片 function kitty_insertPayImgsDom(url) { kitty_utils.getElement(".kitty_coverInnerBox").then((ele) => { let element = ele[0]; kitty_topicData.picsList.forEach((url, index) => { if (!kitty_topicData.imageInserted.includes(url)) { let p = document.createElement("p"); let img = document.createElement("img"); img.className = "kitty_topicImg"; img.src = "/images/common/project/loading.gif"; img.title = "点击查看大图"; img.dataset.imgUrl = url; img.addEventListener("click", function () { img.classList.toggle("imgwidth100"); }); p.appendChild(img); element.appendChild(p); kitty_topicData.imageInserted.push(url); kitty_topicData.picDomList.push(img); } }); }); } function kitty_getVideoUrl() { if (kitty_topicData.isFree) { return; } if (kitty_topicData.hasVideo) { kitty_coverAddContent("正在获取视频信息,请稍后..."); fetch("https://baixiaodu.uk/api/hj/findu8", { method: "post", headers: { "Content-Type": "application/json", }, body: JSON.stringify({ pid: parseInt(kitty_topicData.topicId), }), }) .then((res) => res.json()) .then((res) => { if (res.success) { kitty_topicData.wholeM3u8UrlType = res.data.type; kitty_topicData.wholeM3u8Url = res.data.url; } else { kitty_logListPush(res.message, "warning"); kitty_coverAddContent(res.message); kitty_showPanel(); } }); } } // 插入视频 function kitty_insertVideoDom() { if (kitty_topicData.wholeM3u8UrlType == "page") { kitty_coverAddContent( `视频需至haijiao.ai观看: <a target='_blank' href="${kitty_topicData.wholeM3u8Url}">点此观看</a>` ); return; } kitty_coverAddContent( `请点击观看视频: <a target='_blank' href="https://file.kittymao.xyz/file/other/m3u8Player.html?url=${kitty_topicData.wholeM3u8Url}">点此播放</a>` ); } // 插入音频 function kitty_insertAudioDom() { kitty_topicData.audsList.forEach((item) => { let audio = document.createElement("audio"); audio.controls = true; let source = document.createElement("source"); source.type = "audio/mpeg"; source.src = item; audio.append(source); kitty_utils.getElement(".kitty_coverInnerBox").then((res) => { res[0].append(audio); }); }); } function KittyCover() { this.createCover = function () { let topicType = `${kitty_topicData.isFree ? "免费" : ""}${ kitty_topicData.vipLimit > 0 ? "vip" : "" }${kitty_topicData.saleType == 1 ? "金币" : ""}${ kitty_topicData.saleType == 2 ? "钻石" : "" }`; let coverDiv = document.querySelector(".kitty_coverBox") let cover = coverDiv?coverDiv:document.createElement("div"); cover.className = "kitty_coverBox kitty_coverBoxHidden"; cover.innerHTML = `<div class="kitty_coverInnerBox"> <div class="kitty_operateCover"> <img class="kitty_closeCover" src="${kitty_icons.close}"></img> <img class="kitty_toTop" src="${kitty_icons.toTop}"></img> <img class="kitty_toBottom" src="${kitty_icons.toTop}"></img> </div> <h2>海角社区脚本</h2> <p>这个帖是${topicType}帖,脚本已经获取${topicType}内容,包含${ kitty_topicData.hasAudio ? "音频 " : "" }${kitty_topicData.hasPic ? "图片 " : ""}${ kitty_topicData.hasVideo ? "视频 " : "" }</p> <p>点击图片可放大, 再次点击可缩小</p> </div>`; if (!coverDiv) { document.body.append(cover); } kitty_utils.getElement(".kitty_closeCover").then((res) => { res[0].addEventListener("click", this.hiddenCover); }); kitty_utils.getElement(".kitty_toTop").then((res) => { res[0].addEventListener("click", function () { kitty_utils.getElement(".kitty_coverInnerBox").then((box) => { box[0].scrollTop = 0; }); }); }); kitty_utils.getElement(".kitty_toBottom").then((res) => { res[0].addEventListener("click", function () { kitty_utils.getElement(".kitty_coverInnerBox").then((box) => { box[0].scrollTop = box[0].scrollHeight; }); }); }); kitty_utils.getElement("head").then((res) => { let style = document.createElement("style"); style.innerHTML = ` .kitty_coverInnerBox img.imgwidth100 { width: 100%; } .kitty_coverBoxHidden { display:none; }.kitty_coverBoxShow { display:block; } .kitty_coverBox { width: 100vw; height: 100vh; position: fixed; left: 0; top: 0; background: rgba(0,0,0, 0.5); z-index: 99999; } .kitty_coverInnerBox { position: relative; margin: 0 auto; width: ${isMobileDevice ? "100%" : "50%"}; min-width: 300px; height: 100vh; overflow-y: scroll; text-align:center; background-color: white; padding-bottom: 100px; } .kitty_coverInnerBox p { padding: 10px; margin: 10px; font-size: 16px; } .kitty_closeCover { margin-bottom: 100px; } .kitty_operateCover { position: sticky; left: 100%; width: 50px; top: 20px; height: 30px; } .kitty_coverInnerBox img { cursor: pointer; width: 250px; } .kitty_coverInnerBox .kitty_operateCover img { width: 30px; display: block; } .kitty_toBottom { transform: rotate(180deg); margin-top: 20px; } `; res[0].append(style); }); }; this.hiddenCover = function () { kitty_utils.getElement(".kitty_coverBox").then((kitty_coverBox) => { kitty_coverBox[0].classList.add("kitty_coverBoxHidden"); let audios = kitty_coverBox[0].querySelectorAll("audio"); audios.forEach((audio) => { audio.pause(); }); let videos = kitty_coverBox[0].querySelectorAll("video"); videos.forEach((video) => { video.pause(); }); }); }; this.showCover = function () { kitty_utils.getElement(".kitty_coverBox").then((kitty_coverBox) => { kitty_coverBox[0].classList.remove("kitty_coverBoxHidden"); }); }; } function kitty_topicDataSetOver() { let cover = new KittyCover(); cover.createCover(); kitty_logListPush( `${ kitty_topicData.isFree ? "<span class='kitty_contentGetOver'>这个帖子是免费的</span>" : "<span class='kitty_contentGetOver' style='cursor:pointer;'>帖子内容获取完毕, 请点此查看</span>" }`, "success", true ); if (kitty_topicData.isFree) { document.querySelector(".kitty_jiexiBtn").innerHTML = "免费"; } else { document.querySelector(".kitty_jiexiBtn").innerHTML = "解析"; } document .querySelector(".kitty_jiexiBtn") .addEventListener("click", function () { if (!location.href.includes("post/details?pid")) { document.querySelector(".kitty_jiexiBtn").innerHTML = "暂无"; return; } if (kitty_topicData.isFree) { document.querySelector(".kitty_jiexiBtn").innerHTML = "免费"; } else { document.querySelector(".kitty_jiexiBtn").innerHTML = "解析"; cover.showCover(); } }); kitty_utils.getElement(".kitty_contentGetOver").then((ele) => { ele[0].addEventListener("click", function () { if (!location.href.includes("post/details?pid")) { kitty_logListPush("没有帖子...", "warning"); return; } cover.showCover(); kitty_hiddenPanel(); }); }); if (kitty_topicData.vipLimit) { kitty_topicViplimit(); } if (kitty_topicData.hasPic) { kitty_insertPayImgsDom(); } if (kitty_topicData.hasAudio) { kitty_insertAudioDom(); } if (kitty_topicData.hasVideo) { // 发送请求到kittymao kitty_getVideoUrl(); } else { kitty_coverAddContent(`<span style='color:red;'>这个帖子没有视频</span>`); } //cover.showCover(); } function kitty_main() { kitty_xhrIntercept(); } function kitty_checkLogin() { if (!kitty_isLogin()) { let interval = setInterval(() => { kitty_logListPush("没有登录海角账号,可能无法解析", "warning"); if (kitty_isLogin()) { clearInterval(interval); location.reload(); } }, 1000); return false; } else { kitty_logListPush("脚本运行成功,请尝试观看帖子", "success"); return true; } } function kitty_isLogin() { if (kitty_utils.getCookie("uid") && kitty_utils.getCookie("token")) { return true; } else { return false; } } function kitty_copyTextToClipboard(text) { const textArea = document.createElement("textarea"); textArea.value = text; document.body.appendChild(textArea); textArea.select(); document.execCommand("copy"); document.body.removeChild(textArea); console.log("文本已复制到剪贴板"); } function kitty_isRun() { let run = false; if ( document.querySelector("#kitty_vipPanel") || document.querySelector("#vipPanel") ) { run = true; } if (!run) { console.log("panelInit"); kitty_vipPanelInit(); if (kitty_checkLogin()) { console.log("login"); kitty_main(); } else { kitty_showPanel(); } } } kitty_isRun(); })();