Auto Click SSO Continue

在 SSO 认证页自动点击 Continue 按钮

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey, Greasemonkey или Violentmonkey.

Для установки этого скрипта вам необходимо установить расширение, такое как Tampermonkey.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey или Violentmonkey.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey или Userscripts.

Чтобы установить этот скрипт, сначала вы должны установить расширение браузера, например Tampermonkey.

Чтобы установить этот скрипт, вы должны установить расширение — менеджер скриптов.

(у меня уже есть менеджер скриптов, дайте мне установить скрипт!)

Advertisement:

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

(у меня уже есть менеджер стилей, дайте мне установить скрипт!)

Advertisement:

// ==UserScript==
// @name         Auto Click SSO Continue
// @namespace    local-auto-sso-continue
// @version      1.0
// @description  在 SSO 认证页自动点击 Continue 按钮
// @match        https://github.com/*
// @match        https://*.okta.com/*
// @match        https://*.pingidentity.com/*
// @match        https://*/sso/*
// @match        https://*/saml/*
// @run-at       document-idle
// @grant        none
// @license MIT
// ==/UserScript==

(function () {
  'use strict';

  // 关键词:按钮文字匹配,避免依赖具体 class(SSO 模板可能变化)
  const BUTTON_TEXT = 'continue';

  function findContinueButton() {
    const candidates = document.querySelectorAll('button, a, input[type="submit"]');
    for (const el of candidates) {
      const text = (el.innerText || el.value || '').trim().toLowerCase();
      if (text === BUTTON_TEXT) {
        return el;
      }
    }
    return null;
  }

  function tryClick() {
    const btn = findContinueButton();
    if (btn && !btn.disabled) {
      btn.click();
      return true;
    }
    return false;
  }

  // 页面加载后立即尝试一次
  if (tryClick()) return;

  // 用 MutationObserver 监听 SSO 页面动态渲染(很多 SSO 页面是 SPA,按钮可能延迟出现)
  const observer = new MutationObserver(() => {
    if (tryClick()) {
      observer.disconnect();
    }
  });

  observer.observe(document.body, { childList: true, subtree: true });

  // 兜底:10秒后停止监听,避免无限占用资源
  setTimeout(() => observer.disconnect(), 10000);
})();