- // ==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>邮箱-->JamJamToday@protonmail.com</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();
- })();