Discuz论坛自动登录

支持一些基于 Discuz! 的论坛自登录,根据网页元素特征匹配单个论坛,需要一定的开发能力

// ==UserScript==
// @name         Discuz论坛自动登录
// @namespace    http://tampermonkey.net/
// @version      0.0.2
// @description  支持一些基于 Discuz! 的论坛自登录,根据网页元素特征匹配单个论坛,需要一定的开发能力
// @author       wzj042
// @match        *://*/*
// @icon         
// @grant        none
// @license     MIT
// ==/UserScript==

(function () {
  "use strict";
  // 等待网页加载
  const config = {
    username: "",
    password: "",
    auto_login: true,
    weight_limit: 2,
    // 如果存在发布页
    requirement_enable: false,
    // 发布页域名特征
    requirement_domain: [""],
    sample: [ "地址发布器下载", "发现以下行为将会被扣分处理"]
  };
  window.onload = function () {
    // 匹配域名
    // 此处可根据特定论坛的发布页自定义
    if (config.requirement_enable) {
      var domain = window.location.hostname;
      var is_discuz = config.requirement_domain.some((item) => {
        return domain.includes(item);
      });
      if (is_discuz) {
        const link = queryElement(".link");
        link.then((element) => {
          if (element.innerText.includes("最新地址")) {
            element.click();
          }
        });
        return;
      }
    }
    // 如果配置为空,提示用户在配置页面填写
    const data = config;
    if (!data.username || !data.password) {
      console.log("请在脚本源码页面填写用户名和密码");
      return;
    }

    // 匹配元素
    // 设置校验权重,通过大部分视为discuz子论坛
    var weight = 0;
    // 通过链接文本匹配,也可以自行拓展
    var links = document.getElementsByTagName("a");
    for (var i = 0; i < links.length; i++) {
      const { title, innerText } = links[i];

      config.sample.forEach((text) => {
        if (innerText.includes(text) || title.includes(text)) {
          weight += 1;
        }
      });
    }

    if (weight < config.weight_limit) {
      return;
    }

    // 假设未登录,查询表单
    const element = queryElement("#lsform");
    element.then((element) => {
      const username = element.querySelector('input[name="username"]');
      const password = element.querySelector('input[name="password"]');
      const auto_login = element.querySelector('input[name="cookietime"]');
      const submit = element.querySelector("button");
      if (!username || !password || !auto_login || !submit) {
        console.log("element not found");
        return;
      }
      // 填写表单
      username.value = data.username;
      password.value = data.password;
      auto_login.checked = data.auto_login;
      console.log("submit:", submit);

      // 提交表
      submit.click();
    });
  };
  // 异步查询确保元素加载
  async function queryElement(selector) {
    return new Promise((resolve, reject) => {
      const interval = setInterval(() => {
        const element = document.querySelector(selector);
        if (element) {
          clearInterval(interval);
          resolve(element);
        }
      }, 1000);
    });
  }
})();