Auto Click SSO Continue

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

You will need to install an extension such as Tampermonkey, Greasemonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey to install this script.

You will need to install an extension such as Tampermonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey or Userscripts to install this script.

You will need to install an extension such as Tampermonkey to install this script.

You will need to install a user script manager extension to install this script.

(I already have a user script manager, let me install it!)

Advertisement:

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

(I already have a user style manager, let me install it!)

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);
})();