您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
用户登录(不可用)后进入微博主页,获取超级话题并自动签到
当前为
// ==UserScript== // @name 微博超话自动签到 // @description 用户登录(不可用)后进入微博主页,获取超级话题并自动签到 // @homepageURL https://github.com/Deuscx/WB_SIGN_EXT // @supportURL https://github.com/Deuscx/WB_SIGN_EXT/issues // @grant none // @version 2.0.2 // @author deus // @match https://weibo.com/* // @match https://www.weibo.com/* // @require https://cdn.jsdelivr.net/combine/npm/@violentmonkey/dom@1,npm/@violentmonkey/[email protected] // @require https://cdn.jsdelivr.net/npm/[email protected]/dist/axios.min.js // @namespace https://deuscx.github.io/ // ==/UserScript== (function() { "use strict"; var e = ".configContainer{display:flex;flex-direction:column;position:fixed;--bg-opacity:1;background-color:#fff;background-color:rgba(255,255,255,var(--bg-opacity));z-index:10;border-radius:.25rem;border-width:1px;--border-opacity:1;border-color:#cbd5e0;border-color:rgba(203,213,224,var(--border-opacity));padding:.75rem .5rem;max-width:190px;bottom:80px;right:0;transform:translateX(100%);transition-duration:.5s;transition-timing-function:cubic-bezier(.22,1,.36,1);transition-property:transform}.configContainer .cItem{font-size:.875rem;display:flex;justify-content:space-between;cursor:pointer}.configContainer .cItem .des{--text-opacity:1;color:#718096;color:rgba(113,128,150,var(--text-opacity))}#TIMEOUT{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:inline-block;width:60px}.configContainer .action{padding-top:.5rem;padding-bottom:.5rem;border-radius:.25rem;background-color:#fff;cursor:pointer;position:absolute;top:50%;left:0;transform:translate3d(-100%,-50%,0)}.configContainer .action:hover{color:#ccc}.active{transform:translateX(0)}"; const t = (new Date).getTimezoneOffset() + 480; const o = Date.now; const isNewDay = e => { if (!e) return true; const o = new Date(e); o.setMinutes(o.getMinutes() + t); o.setHours(0, 0, 0, 0); const n = new Date; n.setMinutes(o.getMinutes() + t); return n - o > 864e5; }; const n = function() { const set = function(e, t) { localStorage.setItem(e, JSON.stringify(t)); }; const get = function(e) { const t = localStorage.getItem(e); try { return JSON.parse(t); } catch (e) { return t; } }; const remove = function(e) { localStorage.removeItem(e); }; const has = function(e) { return Reflect.has(localStorage, e); }; return { set: set, get: get, remove: remove, has: has }; }(); const r = (e => () => e++)(0); const a = "WB"; const c = `${a}_SIGNED_ARR`; const s = "WB_CONFIG"; const i = { DEFAULT: "default", SUCCESS: "success", ERROR: "error", INFO: "info", WARNING: "warning" }; let l = n.get(s); function ConfigPanel() { const handleAutoSign = e => { const t = e.target.checked; const o = Object.assign({}, l, { AUTO_SIGN: t }); l = o; n.set(s, l); }; const handleShowToast = e => { const t = e.target.checked; const o = Object.assign({}, l, { SHOW_TOAST: t }); l = o; n.set(s, l); }; const handleTimeout = e => { const t = e.target.value; const o = Object.assign({}, l, { TIMEOUT: t }); l = o; n.set(s, l); }; const toggleClassList = () => { document.querySelector(".configContainer").classList.toggle("active"); }; return VM.createElement(VM.Fragment, null, VM.createElement("div", { className: "configContainer" }, VM.createElement("label", { htmlFor: "AUTO_SIGN", className: "cItem" }, VM.createElement("span", { className: "des" }, "自动签到"), VM.createElement("input", { id: "AUTO_SIGN", type: "checkbox", onInput: handleAutoSign, checked: l.AUTO_SIGN })), VM.createElement("label", { htmlFor: "SHOW_TOAST", className: "cItem" }, VM.createElement("span", { className: "des" }, "是否展示气泡"), VM.createElement("input", { id: "SHOW_TOAST", type: "checkbox", onInput: handleShowToast, checked: l.SHOW_TOAST })), VM.createElement("label", { htmlFor: "TIMEOUT", className: "cItem" }, VM.createElement("span", { className: "des" }, "气泡展示时间"), VM.createElement("input", { id: "TIMEOUT", type: "number", onInput: handleTimeout, min: "0", value: parseInt(l.TIMEOUT, 10), placeholder: "单位为毫秒" })), VM.createElement("div", { className: "action", onClick: toggleClassList }, "收放")), VM.createElement("style", null, e)); } var m = ".msgContainer{position:fixed;background-color:initial;top:4rem;right:40px}@keyframes slide-in-right{0%{transform:translateX(1000px);opacity:0}to{transform:translateX(0);opacity:1}}@keyframes slide-out-right{0%{transform:translateX(0);opacity:1}to{transform:translateX(1000px);opacity:0}}.removing{animation:slide-out-right .5s cubic-bezier(.55,.085,.68,.53) both}.toastItem{background-color:#fff;background-color:rgba(255,255,255,var(--bg-opacity));border-width:1px;--border-opacity:1;border-color:#cbd5e0;border-color:rgba(203,213,224,var(--border-opacity));border-radius:.375rem;max-width:20rem;--text-opacity:1;color:#fff;color:rgba(255,255,255,var(--text-opacity));z-index:10;padding:1rem 1.5rem;cursor:pointer;--bg-opacity:1;background-color:#3182ce;background-color:rgba(49,130,206,var(--bg-opacity));opacity:.8;margin-bottom:.5rem;animation:slide-in-right .5s cubic-bezier(.25,.46,.45,.94) both}.toast-info{--bg-opacity:1;background-color:#63b3ed;background-color:rgba(99,179,237,var(--bg-opacity))}.toast-default{--bg-opacity:1;background-color:#3182ce;background-color:rgba(49,130,206,var(--bg-opacity))}.toast-success{--bg-opacity:1;background-color:#48bb78;background-color:rgba(72,187,120,var(--bg-opacity))}.toast-error{background-color:#ff5252}.toast-warning{--bg-opacity:1;background-color:#f6e05e;background-color:rgba(246,224,94,var(--bg-opacity))}"; const d = 8; let u = 0; const innerToast = e => { const {content: t, type: o, timeout: n} = e; function remove() { const t = document.querySelector(`[data-tid='${e.id}']`); t.classList.add("removing"); requestAnimationFrame((() => { t.parentNode.removeChild(t); u--; })); } n && setTimeout((() => { remove(); }), n); return VM.createElement(VM.Fragment, null, VM.createElement("div", { "data-tid": e.id, className: `toastItem toast-${o}`, onClick: remove }, t)); }; const ToastContainer = () => VM.createElement("div", { className: "msgContainer" }, VM.createElement("style", null, m)); const g = { type: i.INFO, timeout: 5e3 }; const toastFactory = () => { const e = ToastContainer(); const t = document.body.appendChild(e); const toast = (e, o) => { if (!n.get(s).SHOW_TOAST) return; const a = Object.assign({}, g, { id: r() }, o, { content: e }); if (u < d) { u++; t.appendChild(innerToast(a)); } }; toast.success = (e, t) => toast(e, Object.assign({}, t, { type: i.SUCCESS })); toast.error = (e, t) => toast(e, Object.assign({}, t, { type: i.ERROR })); toast.info = (e, t) => toast(e, Object.assign({}, t, { type: i.INFO })); toast.warn = (e, t) => toast(e, Object.assign({}, t, { type: i.WARNING })); return toast; }; const p = toastFactory(); const b = { AUTO_SIGN: true, SHOW_TOAST: true, TIMEOUT: 1e3 }; const f = axios.create({ baseURL: "https://weibo.com/", timeout: 1e3 * 5 }); f.defaults.headers.post["Content-Type"] = "application/x-www-form-urlencoded"; f.interceptors.request.use((e => e), (e => Promise.error(e))); f.interceptors.response.use((e => 200 === e.status ? Promise.resolve(e) : Promise.reject(e)), (e => { const {response: t} = e; if (t) { console.log("发送请求失败", t); return Promise.reject(t); } if (!window.navigator.onLine) console.error("断网"); else return Promise.reject(e); })); class BaseFeature { constructor({name: e}) { this.launch = () => {}; this.name = e; } get store() { const e = n.get(this.name); if (e) return e; n.set(this.name, void 0); return; } set store(e) { n.set(this.name, e); } init() { return new Promise(((e, t) => { try { this.launch(); e(this); } catch (e) { console.log(`run ${this.name} error`); t(e); } })); } } function isCheck() { return n.get("isCheck") || false; } const h = n.get("lastCheck"); const signInterestAPI = e => f({ url: "p/aj/general/button", params: { ajwvr: 6, api: "http://i.huati.weibo.com/aj/super/checkin", texta: encodeURI("签到"), textb: encodeURI("已签到"), status: 0, id: e, __rnd: (new Date).getTime() } }); let y = n.get(c) || []; const signInterest = ({id: e, name: t}) => new Promise(((r, a) => { signInterestAPI(e).then((e => { const {data: s} = e; if ("100000" === s.code) { window.toast.success(`[${t}签到成功]${s.msg} ---${s.data.alert_title}`); n.set("lastCheck", o()); y.push(t); y = Array.from(new Set(y)); n.set(c, y); } else { window.toast.warn(`[${t}超话签到]${s.msg}`); if (382004 !== s.code) a("error"); else { n.set("lastCheck", o()); y.push(t); y = Array.from(new Set(y)); n.set(c, y); } } r(); }), (e => { a(e); window.toast.error(`[${t}超话签到]签到失败,请检查网络`); })); })); function getInterestNameAId(e = 1) { return new Promise(((t, o) => { f({ url: `ajax/profile/topicContent?tabid=231093_-_chaohua&page=${e}` }).then((n => { const {data: {data: r, ok: a}} = n; if (1 !== a) o({ err: "获取关注超话失败", data: r }); const c = r.list; const s = r.total_number; function extractId(e) { return e.slice(5); } const i = c.map((({oid: e, topic_name: t}) => ({ id: extractId(e), name: t }))); if (0 !== s) getInterestNameAId(e + 1).then((e => { t(i.concat(e)); })); else t(i); }), (e => { console.error(`[${a}]`, e); o("获取hash失败"); })); })); } class Interest extends BaseFeature { constructor() { super({ name: s }); this.launch = async () => { const e = super.store; if (!e.AUTO_SIGN) return; if (isCheck() && !isNewDay(h)) { window.toast.info("今日已签到"); return; } if (isNewDay(h)) { n.remove(c); n.set("isCheck", false); } let t = await getInterestNameAId(); const o = n.get(c); if (o && o.length) t = t.filter((e => !o.includes(e.name))); Promise.all(t.map((({name: e, id: t}) => signInterest({ id: t, name: e })))).then((() => { n.set("isCheck", true); })); }; } run() { this.init().then((e => {})); } } var I = new Interest; function initConfig() { if (!n.get(s)) n.set(s, b); } function initDOM() { return new Promise(((e, t) => { try { const e = ConfigPanel(); document.body.appendChild(e); } catch (e) { throw new Error("初始化DOM失败"); } })); } function BaseInit() { initConfig(); window.toast = p; } function OtherInit() { initDOM(); } function main() { BaseInit(); OtherInit(); I.run(); } main(); })();
QingJ © 2025
镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址