您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Check if the URL has been accessed before and signaling to the user
当前为
// ==UserScript== // @name Chan SankakuComplex URL Verifier with IndexedDB // @namespace http://tampermonkey.net/ // @version 0.1 // @description Check if the URL has been accessed before and signaling to the user // @author mtpontes // @match *://chan.sankakucomplex.com/* // @match *://idol.sankakucomplex.com/* // @match *://legacy.sankakucomplex.com/* // @grant none // @icon  // @grant none // @license MI // ==/UserScript== (function() { console.log('Starting execution of the visited URLs persister...'); const dbName = 'VisitedDB'; function getDatabaseConnection() { return new Promise((resolve, reject) => { const request = indexedDB.open(dbName, 1); // If the database structure needs to be created or updated request.onupgradeneeded = (event) => { const db = event.target.result; if (!db.objectStoreNames.contains('visitedURLs')) { db.createObjectStore('visitedURLs', { keyPath: 'url' }); } }; request.onsuccess = (event) => resolve(event.target.result); // Returns the database as the result of the Promise request.onerror = (event) => reject('Error opening the database'); }); } function initiateDbReadTransaction(db) { const transaction = db.transaction(['visitedURLs'], 'readonly'); return transaction.objectStore('visitedURLs'); } function initiateDbWriteTransaction(db) { const transaction = db.transaction(['visitedURLs'], 'readwrite'); return transaction.objectStore('visitedURLs'); } async function checkVisitedPage(db, url) { const store = initiateDbReadTransaction(db); const getRequest = store.get(url); return new Promise((resolve, reject) => { getRequest.onsuccess = () => resolve(!!getRequest.result); // Operation succeeded getRequest.onerror = () => reject('Error accessing the database'); // Runs if the operation above fails }); } async function addCurrentPage(db, url) { const store = initiateDbWriteTransaction(db); return new Promise((resolve, reject) => { const request = store.add({ url }); request.onsuccess = () => resolve(); // If successful, resolve without any value request.onerror = () => reject('Error adding the URL to the database'); // Runs if the operation above fails }); } function addWarning() { const warningDiv = document.createElement('div'); warningDiv.style.position = 'fixed'; warningDiv.style.top = '10px'; warningDiv.style.left = '10px'; warningDiv.style.backgroundColor = 'rgba(255, 0, 0, 0.8)'; warningDiv.style.color = 'white'; warningDiv.style.padding = '10px'; warningDiv.style.zIndex = '9999'; warningDiv.innerText = 'You have already visited this page!'; document.body.appendChild(warningDiv); console.log('Visited URL warning was added'); } async function run() { try { const currentUrl = window.location.href; const db = await getDatabaseConnection(); const isVisited = await checkVisitedPage(db, currentUrl); if (isVisited) { console.log('URL already visited'); addWarning(); return; } await addCurrentPage(db, currentUrl); console.log('URL added to the database'); } catch (error) { console.error('Error:', error); } } run(); })();