🏠 返回首頁 

Greasy Fork is available in English.

阿里云盘多账号localStorage管理器

用于管理多个账号的localStorage信息


Installer dette script?
// ==UserScript==
// @name         阿里云盘多账号localStorage管理器
// @namespace    http://tampermonkey-multiple-accounts
// @version      1.0.3
// @description  用于管理多个账号的localStorage信息
// @match        https://www.aliyundrive.com/*
// @match        https://www.alipan.com/*
// @grant        GM_setValue
// @grant        GM_getValue
// ==/UserScript==
(function () {
'use strict';
// 定义变量
var accounts = GM_getValue('accounts', {});
var currentAccount = null;
var currentLocalStorage = null;
var currentHost = window.location.host;
var currentName = JSON.parse(localStorage.token).nick_name || ''
// 创建设置按钮
var settingsButton = document.createElement('div');
settingsButton.innerHTML = `
<div style="position: fixed; bottom: 20px; right: 20px; width: 40px; height: 40px;border-radius: 50%; cursor: pointer; display: flex; justify-content: center; align-items: center;">
<i class="fas fa-cog" style="color: white;"><svg t="1684308224035" class="icon" viewBox="0 0 #### ####" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2408" width="28" height="28"><path d="M682.666667 273.066667H580.266667V102.4h-477.866667v477.866667H273.066667V682.666667H0V0h682.666667v273.066667zM443.733333 443.733333v477.866667h477.866667v-477.866667h-477.866667zM341.333333 341.333333h682.666667v682.666667H341.333333V341.333333z" fill="#1296db" p-id="2409"></path></svg></i>
</div>
`;
document.body.appendChild(settingsButton);
// 显示管理面板
function showManagementPanel() {
// 移除之前的管理页面
var previousPanel = document.getElementById('multiple-accounts-panel');
if (previousPanel) {
previousPanel.parentNode.removeChild(previousPanel);
}
// 创建弹出元素
var panel = document.createElement('div');
panel.id = 'multiple-accounts-panel';
panel.style.position = 'fixed';
panel.style.top = '0';
panel.style.left = '0';
panel.style.width = '100%';
panel.style.height = '100%';
panel.style.backgroundColor = 'rgba(0, 0, 0, 0.5)';
panel.style.zIndex = '9999';
panel.innerHTML = `
<div style="position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); background-color: #fff; padding: 20px; border-radius: 10px; box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2); width: 600px;">
<h3 style="margin-top: 0; margin-bottom: 20px; font-size: 24px;">多账号localStorage管理器</h3>
<div style="display: flex; justify-content: space-between; margin-bottom: 10px; font-size: 18px;">
<div style="flex: 1; font-weight: bold;">账号名称</div>
<div style="flex: 1; display: flex; justify-content: flex-end; font-weight: bold;">操作</div>
</div>
<div style="overflow-y: auto; max-height: 400px;">
${Object.keys(accounts[currentHost] || {}).map(function (account) {
return `
<div style="display: flex; justify-content: space-between; margin-bottom: 10px;">
<div style="flex: 1;">${account}</div>
<div style="flex: 1; display: flex; justify-content: flex-end;">
<button class="login-button" data-account="${account}" style="margin-right: 10px; padding: 5px 10px; border: none; background-color: #007fff; color: #fff; border-radius: 4px; cursor: pointer;">登录</button>
<button class="update-button" data-account="${account}" style="margin-right: 10px; padding: 5px 10px; border: 1px solid #ccc; background-color: #fff; color: #007fff; border-radius: 4px; cursor: pointer;">更新</button>
<button class="delete-button" data-account="${account}" style="padding: 5px 10px; border: none; background-color: #ff4d4f; color: #fff; border-radius: 4px; cursor: pointer;">删除</button>
</div>
</div>
`;
}).join('')}
</div>
<hr style="margin-top: 20px; margin-bottom: 20px;">
<div style="display: flex; align-items: center; margin-top: 10px;">
<input type="text" value="${currentName}" id="account-name-input" style="flex: 1; padding: 5px 10px; border: 1px solid #ccc; border-radius: 4px; font-size: 16px;" placeholder="请输入账号名称">
<button id="save-current-button" style="margin-left: 10px; padding: 5px 10px; border: none; background-color: #007fff; color: #fff; border-radius: 4px; cursor: pointer;">保存当前账号</button>
</div>
</div>
`;
document.body.appendChild(panel);
// 绑定事件
panel.addEventListener('click', function (e) {
var accountName = e.target.getAttribute('data-account');
if (e.target.classList.contains('login-button')) {
localStorage.clear();
var data = accounts[currentHost][accountName];
for (var key in data) {
localStorage.setItem(key, data[key]);
}
location.reload();
} else if (e.target.classList.contains('update-button')) {
accounts[currentHost][accountName] = getLocalStorageData();
GM_setValue('accounts', accounts);
showManagementPanel();
} else if (e.target.classList.contains('delete-button')) {
delete accounts[currentHost][accountName];
GM_setValue('accounts', accounts);
showManagementPanel();
}
else if(e.target == panel){
panel.parentNode.removeChild(panel);
}
});
// 保存当前账号
document.getElementById('save-current-button').onclick = function () {
var accountName = document.getElementById('account-name-input').value.trim();
if (accountName === '') {
alert('请输入账号名称');
return;
}
if (!accounts[currentHost]) {
accounts[currentHost] = {};
}
accounts[currentHost][accountName] = getLocalStorageData();
GM_setValue('accounts', accounts);
showManagementPanel();
};
}
// 获取当前localStorage数据
function getLocalStorageData() {
var data = {};
for (var i = 0; i < localStorage.length; i++) {
var key = localStorage.key(i);
data[key] = localStorage.getItem(key);
}
return data;
}
// 设置按钮点击事件
settingsButton.onclick = function () {
showManagementPanel();
};
})();