您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Greasy Fork is available in English.
点击【立即下载】后自动输入密码并继续,自动关闭弹窗,自动识别百度网盘链接和密码一键跳转
当前为
// ==UserScript== // @name gamer520自动跳转下载+关闭弹窗+百度网盘链接一键跳转 // @namespace http://tampermonkey.net/ // @version 0.4 // @description 点击【立即下载】后自动输入密码并继续,自动关闭弹窗,自动识别百度网盘链接和密码一键跳转 // @license AGPL-3.0-or-later // @author Yokior // @match https://www.gamer520.com/* // @match https://like.gamer520.com/* // @icon  // @grant none // ==/UserScript== (function() { 'use strict'; // 检查关闭按钮是否存在 const closeButton = document.querySelector("button[aria-label='Close this dialog']"); // 如果按钮存在,则触发点击事件 if (closeButton) { closeButton.click(); console.log("关闭对话框按钮已被点击。"); // 控制台输出点击事件 } else { console.warn("关闭对话框按钮未找到。"); // 控制台输出未找到按钮的警告 } // 选择要监控的目标元素 const targetElement = document.querySelector(".go-down"); // 函数:目标元素点击后执行 function handleClick() { let attempts = 0; // 尝试计数 const maxAttempts = 5; // 最大重试次数 const tryClickConfirm = () => { const confirmButton = document.querySelector(".swal2-confirm"); if (confirmButton) { // 等待 0.3 秒后点击确认按钮 setTimeout(() => { confirmButton.click(); console.log("确认按钮已被点击"); // 在控制台输出确认按钮已被点击 }, 300); // 300毫秒后执行点击 } else if (attempts < maxAttempts) { attempts++; console.warn(`确认按钮未找到,正在重试...(尝试次数:${attempts}/${maxAttempts})`); setTimeout(tryClickConfirm, 500); // 再次尝试 } else { console.warn("确认按钮未找到,达到最大重试次数,无法点击"); // 控制台输出未找到按钮的警告 } }; // 等待 0.5 秒后首次触发尝试 setTimeout(tryClickConfirm, 500); } // 检查目标元素是否存在 if (targetElement) { // 添加点击事件监听器 targetElement.addEventListener('click', handleClick); } else { console.warn("目标元素未找到,无法添加点击事件监听器。"); } // 选择指定的 h1 元素 const h1Element = document.querySelector(".article-content > div:nth-child(1) > div > header > h1"); // 检查元素是否存在 if (h1Element) { // 获取 h1 内容 const h1Content = h1Element.textContent.trim(); // 使用正则表达式检查内容格式并提取密码 const passwordPattern = /^密码保护:(.+)/; // 正则表达式匹配格式 const match = h1Content.match(passwordPattern); if (match && match[1]) { const password = match[1]; // 提取密码部分 // 选择输入框并输入密码 const passwordInput = document.querySelector("[name='post_password']"); if (passwordInput) { passwordInput.value = password; // 将密码输入到输入框 console.log(`已输入密码: ${password}`); // 在控制台输出输入的密码 // 触发提交按钮的点击事件 const submitButton = document.querySelector("input[type=submit]"); if (submitButton) { submitButton.click(); // 点击提交按钮 console.log("提交按钮已被点击。"); // 控制台输出点击事件 } else { console.warn("提交按钮未找到。"); } } else { console.warn("输入框未找到。"); } } else { console.warn("h1 内容不匹配预期格式。"); } } else { console.warn("指定的 h1 元素未找到。"); } // 百度网盘链接按钮 // 获取包含链接和提取码的容器 const entryContent = document.querySelector("div.entry-content"); // 获取所有的<p>标签 const paragraphs = entryContent.querySelectorAll("p"); // 定义链接和提取码 let linkUrl = ''; let extractionCode = ''; // 遍历所有<p>标签,寻找包含链接和提取码的信息 paragraphs.forEach(p => { const anchor = p.querySelector('a'); if (anchor && anchor.href.startsWith("https://pan.baidu.com")) { linkUrl = anchor.href; // 获取链接 } const codeMatch = p.textContent.match(/提取码:\s*(\w+)/); if (codeMatch) { extractionCode = codeMatch[1]; // 获取提取码 } }); // 如果找到了链接和提取码 if (linkUrl && extractionCode) { // 创建按钮元素 const button = document.createElement('button'); button.innerText = "一键打开百度网盘链接并输入密码"; // 美化按钮的样式 button.style.marginLeft = '10px'; // 添加一点样式,便于视觉效果 button.style.padding = '10px 15px'; // 内边距 button.style.borderRadius = '5px'; // 圆角 button.style.backgroundColor = '#4CAF50'; // 背景颜色 button.style.color = 'white'; // 字体颜色 button.style.border = 'none'; // 无边框 button.style.cursor = 'pointer'; // 光标样式 button.style.fontSize = '14px'; // 字体大小 button.style.transition = 'background-color 0.3s'; // 背景颜色过渡效果 // 设置按钮点击事件,跳转到带有提取码的链接,并在新标签中打开 button.onclick = function () { window.open(`${linkUrl}?pwd=${extractionCode}`, '_blank'); }; // 将按钮添加到找到的链接后面 const anchor = entryContent.querySelector(`a[href="${linkUrl}"]`); anchor.parentNode.insertBefore(button, anchor.nextSibling); } })();