仓库 HTTPS 图片

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

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey, Greasemonkey или Violentmonkey.

Для установки этого скрипта вам необходимо установить расширение, такое как Tampermonkey.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey или Violentmonkey.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey или Userscripts.

Чтобы установить этот скрипт, сначала вы должны установить расширение браузера, например Tampermonkey.

Чтобы установить этот скрипт, вы должны установить расширение — менеджер скриптов.

(у меня уже есть менеджер скриптов, дайте мне установить скрипт!)

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

(у меня уже есть менеджер стилей, дайте мне установить скрипт!)

// ==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);