仓库 HTTPS 图片

把部分白名单域名内的图片更换为 https。

Dovrai installare un'estensione come Tampermonkey, Greasemonkey o Violentmonkey per installare questo script.

Dovrai installare un'estensione come Tampermonkey o Violentmonkey per installare questo script.

Dovrai installare un'estensione come Tampermonkey o Violentmonkey per installare questo script.

Dovrai installare un'estensione come Tampermonkey o Userscripts per installare questo script.

Dovrai installare un'estensione come ad esempio Tampermonkey per installare questo script.

Dovrai installare un gestore di script utente per installare questo script.

(Ho già un gestore di script utente, lasciamelo installare!)

Dovrai installare un'estensione come ad esempio Stylus per installare questo stile.

Dovrai installare un'estensione come ad esempio Stylus per installare questo stile.

Dovrai installare un'estensione come ad esempio Stylus per installare questo stile.

Dovrai installare un'estensione per la gestione degli stili utente per installare questo stile.

Dovrai installare un'estensione per la gestione degli stili utente per installare questo stile.

Dovrai installare un'estensione per la gestione degli stili utente per installare questo stile.

(Ho già un gestore di stile utente, lasciamelo installare!)

// ==UserScript==
// @name         仓库 HTTPS 图片
// @namespace    moe.jixun.galacg-https-image
// @version      0.1.3
// @description  把部分白名单域名内的图片更换为 https。
// @author       Jixun <https://jixun.moe/>
// @include      https://galacg.me/*
// @include      https://cangku.in/*
// @include      https://cangku.moe/*
// @grant        none
// @run-at       document-start
// ==/UserScript==

(function(_xhr_send) {
    function filter (src) {
        return src.replace(/(http)(:(\/\/|\\\/\\\/)(ww\d\.sinaimg\.cn|imgsrc\.baidu\.com|(?:\w+\.)?galacg\.me|\w+\.loli\.io|[\w\.]+.127.net|(?:\w+\.)?cangku\.(in|moe))[\\\/])/g, '$1s$2');
    }

    XMLHttpRequest.prototype.send = function () {
        var _onload = this.onload;
        var self = this;
        var ret = _xhr_send.apply(this, arguments);
        this.onload = function () {
            let resp = self.response;
            let respText = self.responseText;

            Object.defineProperty(self, 'response', { value: filter(resp) });
            Object.defineProperty(self, 'responseText', { value: filter(respText) });

            if (_onload)
                return _onload.apply(this, arguments);

            var event = new Event('xhrRequestEvent');
            window.dispatchEvent(event);
        };
        return ret;
    };
})(XMLHttpRequest.prototype.send);