// ==UserScript== // @name 蓝奏云重定向+记住密码 // @namespace https://greasyfork.org/zh-CN/scripts?set=589091 // @version 1.33 // @description 自动将所有蓝奏云链接重定向至lanzn.com。自动记住并填写蓝奏云密码。直接下载APK文件。 // @author 呆呆 // @include https://*lanz*.com/* // @include https://*lanosso.com/* // @include https://*lanpw.com/* // @include https://*lanpv.com/* // @match https://*lanz*.com/* // @match https://*lanosso.com/* // @match https://*lanpw.com/* // @match https://*lanpv.com/* // @grant GM_registerMenuCommand // @grant GM_setValue // @grant GM_getValue // @grant GM_listValues // @grant GM_deleteValue // @grant GM_notification // @require https://cdn.jsdelivr.net/npm/sweetalert2@11 // @downloadURL none // ==/UserScript== function Toast(text) { if (typeof(window.via) == "object") window.via.toast(text); else if (typeof(window.mbrowser) == "object") window.mbrowser.showToast(text); } // 获取当前网页链接 var currentUrl = window.location.href; // 检查当前网址 if (!currentUrl.startsWith('https://www.lanzn.com/')) { // 替换域名 var newUrl = currentUrl.replace(window.location.hostname, 'www.lanzn.com'); Toast("重定向中...."); // 重新访问新链接 window.location.href = newUrl; } const divnone = document.documentElement.innerHTML; // const divnoneButton = document.getElementById('divnone'); if (divnone.includes("非会员不在支持手机分享此文件,请先开通会员") && !currentUrl.includes("/tp/")) { Toast("重定向中...."); const modifiedUrl = currentUrl.replace("com/", "com/tp/"); window.location.href = modifiedUrl; } /* * 蓝奏云网盘增强 */ // 滚动条事件 function windowScroll(fn1) { var beforeScrollTop = document.documentElement.scrollTop, fn = fn1 || function() {}; setTimeout(function() { window.addEventListener('scroll', function(e) { var afterScrollTop = document.documentElement.scrollTop, delta = afterScrollTop - beforeScrollTop; if (delta == 0) return false; fn(delta > 0 ? 'down' : 'up', e); beforeScrollTop = afterScrollTop; }, false); }, 1000) } // 自动显示更多文件 function fileMoreS() { windowScroll(function(direction, e) { if (direction === 'down') { let scrollTop = document.documentElement.scrollTop || window.pageYOffset || document.body.scrollTop; let scrollDelta = 500; if (document.documentElement.scrollHeight <= document.documentElement.clientHeight + scrollTop + scrollDelta) { let filemore = document.getElementById('filemore'); if (filemore && filemore.style.display != 'none') { if (filemore.textContent.indexOf('更多') > -1) { filemore.click(); } } } } }); } setTimeout(function() { if (document.getElementById('infos')) { fileMoreS(); } }, 500); /* * * */ // 使用GM_registerMenuCommand添加管理密码的菜单命令 GM_registerMenuCommand('查看密码', function() { // 获取所有存储的键 const allKeys = GM_listValues(); if (allKeys.length === 0 || (allKeys.length === 1 && !allKeys[0])) { Swal.fire({ position: "top", icon: "question", title: "没有存储的密码", showConfirmButton: false, timer: 1000, }); return; } // 存储所有存储的数据 const allStoredData = {}; // 遍历所有键,并获取对应的值 allKeys.forEach(key => { const value = GM_getValue(key); allStoredData[key] = value; }); // 构建展示消息 let message = ''; Object.entries(allStoredData).forEach(([key, value]) => { if (value.title !== undefined) message += `${value.title} (${key}):${value.password}\n┈┈┈┈┈┈┈┈┈┈┈┈\n`; }); // 显示消息 alert(message); }); // 使用GM_registerMenuCommand添加管理密码的菜单命令 GM_registerMenuCommand('🔒管理密码', function() { // 获取所有存储的键值对 const allKeys = GM_listValues(); if (allKeys.length === 0 || (allKeys.length === 1 && !allKeys[0])) { Swal.fire({ position: "top", icon: "question", title: "没有存储的密码", showConfirmButton: false, timer: 1000, }); return; } const allStoredData = {}; allKeys.forEach(key => { const value = GM_getValue(key); allStoredData[key] = value; }); // 构建展示消息 let message = ''; Object.entries(allStoredData).forEach(([key, value]) => { if (value.title !== undefined) message += `${value.title} (${key}):${value.password}\n`; }); // 提示用户编辑密码列表 Swal.fire({ title: '使用\'换行 \\n \'分割', input: 'textarea', inputValue: message, // 设置input属性 inputAttributes: { autocapitalize: 'off', style: 'font-size: 12px;' }, showCancelButton: true, cancelButtonText: '取消', confirmButtonText: '保存', showLoaderOnConfirm: true, // 当为loading的时候取消confirm按钮并显示加载组件 preConfirm: (editedList) => { if (editedList === '') { Swal.fire({ title: "确定清空密码?", icon: "warning", showCancelButton: true, confirmButtonColor: "#3085d6", cancelButtonColor: "#d33", cancelButtonText: '取消', confirmButtonText: "确定" }).then((result) => { if (result.isConfirmed) { const allKeys = GM_listValues(); allKeys.forEach(key => { GM_deleteValue(key); }); Swal.fire({ position: "top", icon: "success", title: "已清空", showConfirmButton: false, timer: 1000, }); } }); } else if (editedList !== null) { // 清空所有存储的密码 const allKeys = GM_listValues(); allKeys.forEach(key => { GM_deleteValue(key); }); // 将编辑后的列表转换为标准格式并存储 let editedLines = editedList.split('\n'); const linePattern = /\((.*?)\)/; editedLines.forEach(line => { const urlMatch = line.match(linePattern); if (urlMatch) { const title = line.substring(0, urlMatch.index).trim(); const url = urlMatch[1].trim(); const password = line.substring(line.indexOf(':') + 1).trim(); GM_setValue(url, { title, password }); } }); Swal.fire({ position: "top", icon: "success", title: "密码列表已更新!", showConfirmButton: false, timer: 1000, }); } }, // 如果设置为false则不允许点击对话框以外的背景来关闭对话框 allowOutsideClick: () => Swal.isLoading(), }).then((result) => { if (!result.isConfirmed) { Swal.fire({ position: "top", icon: "error", title: "已取消", showConfirmButton: false, timer: 1000, }); } }); }); // 获取文本框元素 const inputElement = document.getElementById('pwd'); // 获取按钮元素 const subButton = document.getElementById('sub'); const passwddivButton = document.querySelector('.passwddiv-btn'); // 获取存储的值 const storedCredentials = GM_getValue(currentUrl); // 检查是否存在存储的值 if (storedCredentials) { // 如果有存储的数据,将其填充到文本框中 inputElement.value = storedCredentials.password; // 检查是否存在.passwddiv-btn元素 if (passwddivButton) { // 如果存在,点击.passwddiv-btn passwddivButton.click(); } else { // 否则点击sub subButton.click(); } } const submitButton = document.getElementById('submit'); if (submitButton && inputElement) { submitButton.click(); if (storedCredentials) { inputElement.value = storedCredentials.password; } if (passwddivButton) { passwddivButton.click(); } else { subButton.click(); } } inputElement.addEventListener('input', function() { let pageTitle = document.title; let forTitle = 0; // 如果当前标题是'文件',则循环获取新标题 const titleInterval = setInterval(function() { pageTitle = document.title; if (pageTitle !== '文件' || forTitle > 15) { clearInterval(titleInterval); const credentials = { title: pageTitle, password: inputElement.value }; // 将对象存储在GM存储中 GM_setValue(currentUrl, credentials); } forTitle++; }, 1000); });