Reverse Whoxy Domain Status (OSINT)

Check if websites are online

您需要先安装一个扩展,例如 篡改猴Greasemonkey暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴Userscripts ,之后才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。

您需要先安装用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         Reverse Whoxy Domain Status (OSINT)
// @namespace    http://tampermonkey.net/
// @version      1.3
// @description  Check if websites are online
// @author       SH3LL
// @match        https://www.whoxy.com/*
// @grant        GM_xmlhttpRequest
// @connect      *
// ==/UserScript==

(async function() {
    'use strict';

    const table = document.querySelector('table.grid.first_col_center');
    if (!table) {
        console.log('No table found on the page.');
        return;
    }

    const defaultHosterKeywords = [
        'this domain is for sale',
        'domain registered',
        'domain reserved',
        'courtesy page',
        'coming soon',
        'welcome to your new website',
        'this domain has been registered',
        'placeholder page',
        'parked domain',
        'under construction',
        'domain parking',
        'domain reserved'
    ];

    const knownProviders = [
        'godaddy.com',
        'namecheap.com',
        'bluehost.com',
        'hostgator.com',
        'dreamhost.com',
        'squarespace.com',
        'wix.com',
        'siteground.com',
        'ionos.com',
        'dynadot.com'
    ];

    async function checkDomainStatus(url) {
        try {
            if (!url.startsWith('http://') && !url.startsWith('https://')) {
                url = 'http://' + url;
            }

            return new Promise((resolve) => {
                GM_xmlhttpRequest({
                    method: 'GET',
                    url: url,
                    timeout: 8000,
                    onload: function(response) {
                        const finalUrl = response.finalUrl || url;
                        const content = (response.responseText || '').toLowerCase();
                        const status = response.status;

                        // WAF / protected detection
                        if (
                            content.includes('cloudflare') ||
                            content.includes('ddos-guard') ||
                            content.includes('sucuri') ||
                            content.includes('access denied') ||
                            content.includes('request blocked') ||
                            status === 403 || status === 503
                        ) {
                            console.log(`🟠 WAF PROTECTED   | ${url} (HTTP ${status})`);
                            resolve('🟠');
                            return;
                        }

                        // Redirect to known provider
                        if (knownProviders.some(provider => finalUrl.includes(provider))) {
                            console.log(`🔴 REDIRECT        | ${url} (Redirected to ${finalUrl})`);
                            resolve('🔴');
                            return;
                        }

                        // Minimal or empty body
                        const parser = new DOMParser();
                        const doc = parser.parseFromString(response.responseText, 'text/html');
                        const bodyContent = doc.body ? doc.body.textContent.trim() : '';
                        if (!bodyContent || bodyContent.length < 50) {
                            console.log(`🔴 EMPTY PAGE      | ${url}`);
                            resolve('🔴');
                            return;
                        }

                        // Default hoster keywords
                        const matchingKeyword = defaultHosterKeywords.find(keyword => content.includes(keyword.toLowerCase()));
                        if (matchingKeyword) {
                            console.log(`🔴 HOSTER KEYWORD  | ${url} (${matchingKeyword})`);
                            resolve('🔴');
                            return;
                        }

                        // Online
                        console.log(`🟢 ONLINE          | ${url} (HTTP ${status})`);
                        resolve('🟢');
                    },
                    onerror: function() {
                        console.log(`🟠 BLOCKED         | ${url} (Network error or blocked by server)`);
                        resolve('🟠');
                    },
                    ontimeout: function() {
                        console.log(`🔴 TIMEOUT         | ${url} (Request timed out)`);
                        resolve('🔴');
                    }
                });
            });
        } catch (error) {
            console.log(`🔴 ERROR           | ${url} (${error.message})`);
            return '🔴';
        }
    }

    const rows = table.querySelectorAll('tbody tr');
    for (const row of rows) {
        const domainCell = row.querySelector('td:nth-child(2) a');
        if (domainCell) {
            const domain = domainCell.textContent.trim();
            const statusLink = document.createElement('a');
            statusLink.style.marginLeft = '5px';
            statusLink.textContent = '🔄'; // Loading
            statusLink.href = `http://${domain}`;
            statusLink.target = '_blank';
            domainCell.parentElement.appendChild(statusLink);

            const status = await checkDomainStatus(domain);
            statusLink.textContent = status;
        }
    }
})();