JD Thief_Zip

适用于京东JD.com图片抓取与下载打包。在商品详情页输入Ctrl+Q,即可触发爬取下载。

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

You will need to install an extension such as Tampermonkey to install this script.

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

// ==UserScript==
// @name         JD Thief_Zip
// @namespace    http://tampermonkey.net/
// @version      3.1
// @description  适用于京东JD.com图片抓取与下载打包。在商品详情页输入Ctrl+Q,即可触发爬取下载。
// @author       Soul_Yin
// @match       *://item.jd.com/*
// @require      https://cdn.bootcdn.net/ajax/libs/jszip/3.10.0/jszip.min.js
// @require      https://cdn.bootcdn.net/ajax/libs/FileSaver.js/2.0.5/FileSaver.min.js
// @require      https://cdnjs.cloudflare.com/ajax/libs/jquery/1.8.3/jquery.min.js
// @icon         
// @grant        none
// @license      MIT
// ==/UserScript==


(function () {
    'use strict';

    // Your code here...
    // jszip打包下载图片
    function saveImgZip(imgUrlArrs) {
        var imgUrlArr = []; // 图片列表
        imgUrlArr = imgUrlArrs
        var imgBase64 = {};//存放转成base64的图片,采用键值对形式就行存储,不采用数组。因为数组在异步中会导致存取数据的无序,数据混乱
        var imgNameArr = [];  // 图片名称
        var imageSuffix = []; // 图片后缀
        for (var i = 0; i < imgUrlArrs.length; i++) {
            // 图片后缀
            var suffix = imgUrlArrs[i].substring(imgUrlArrs[i].lastIndexOf("."));
            imageSuffix.push(suffix);
            //获取文件的名称
            var startIndex = imgUrlArrs[i].lastIndexOf("/");
            var endIndex = imgUrlArrs[i].lastIndexOf(".");
            var fileName = imgUrlArrs[i].substring(startIndex + 1, endIndex);
            imgNameArr.push(fileName);
        }
        // 创建JSZip对象
        var zip = new JSZip();
        // 创建文件夹
        var img = zip.folder("images");
        // 读取图片返回base64
        for (var i = 0; i < imgUrlArr.length; i++) {
            getBase64(imgUrlArr[i], i).then(function (base64, index) {
                //imgBase64.push(base64.substring(22));  // 去掉base64的图片格式前缀
                imgBase64[index] = base64.substring(22);
            }, function (err) {
                console.log(err);
            });
        }
        function downloadZip() {
            setTimeout(function () {
                if (imgUrlArr.length == Object.keys(imgBase64).length) {
                    for (var i = 0; i < imgUrlArr.length; i++) {
                        img.file(imgNameArr[i] + imageSuffix[i], imgBase64[i], { base64: true });
                    }
                    zip.generateAsync({ type: "blob" }).then(function (content) {
                        saveAs(content, "JD_Thief打包下载.zip"); // zip包命名
                    });
                } else {
                    downloadZip();
                }
            }, 100);
        }

        downloadZip();
    }


    //图片转base64; 传入图片路径,返回base64
    function getBase64(img, index) {
        function getBase64Image(img, width, height) {
            var canvas = document.createElement("canvas");
            canvas.width = width ? width : img.width;
            canvas.height = height ? height : img.height;
            var ctx = canvas.getContext("2d");
            ctx.drawImage(img, 0, 0, canvas.width, canvas.height);
            var dataURL = canvas.toDataURL();
            return dataURL;
        }

        var image = new Image();
        image.crossOrigin = 'Anonymous';
        image.src = img;
        /*
        * deferred对象是一个延迟对象,意思是函数延迟到某个点才开始执行,改变执行状态的方法有两个(成功:resolve和失败:reject),
        * 分别对应两种执行回调(成功回调函数:done和失败回调函数fail)
        * */
        var deferred = $.Deferred();
        if (img) {
            image.onload = function () {
                // 执行成功回调
                deferred.resolve(getBase64Image(image), index);
            }
            return deferred.promise();
        }
    }



    $(document).keyup(function (event) {

        if (event.ctrlKey && event.keyCode === 81) {    //KeyCode Q=81
            let ul = document.getElementsByClassName("lh")[0];
            let li = ul.getElementsByTagName("li");
            let li_list = new Array();
            //获取所有主图链接
            for (var x of li) {
                li_list.push(x.getElementsByTagName("img")[0].currentSrc);
            };
            
            //获取所有详情图
            let main_div_list = document.getElementsByClassName("detail-content clearfix")[0].getElementsByClassName("ssd-module-wrap")[0].getElementsByTagName("div");
            for (var i of main_div_list) {
                let raw = window.getComputedStyle(i).backgroundImage
                raw = raw.slice(5)
                raw = raw.substring(0, raw.length - 2)
                if (raw == '') {
                    continue
                }
                li_list.push(raw)
            }
            //获取所有详情图(京东页面数据获取有的时候会改变,写两个保证获取)
            let raw=document.getElementsByClassName("ssd-module-wrap")
            raw=raw[raw.length-1].getElementsByTagName("div")
            for (var m of raw) {
                let raw = window.getComputedStyle(m).backgroundImage
                raw = raw.slice(5)
                raw = raw.substring(0, raw.length - 2)
                if (raw == '') {
                    continue
                }
                li_list.push(raw)
            }




            //处理所有链接
            let final_list = new Array()
            for (let [name, url] of li_list.entries()) {

                let urll = url;
                if (urll.includes("avif")) {
                    urll = url.substring(0, url.length - 5)
                }
                if (urll.includes("/n5/s54x54_jfs/")) {
                    urll = urll.replace("/n5/s54x54_jfs/", "/n1/s450x450_jfs/")
                }
                if (urll.includes("/n5/jfs/")) {
                    urll = urll.replace("/n5/jfs/", "/n1/jfs/")
                }
                final_list.push(urll)
            }
            console.log(final_list)
            alert("下载请求已拉取,请耐心等待")
            //图片打包下载
            saveImgZip(final_list)

        }
    })

})();