Greasy Fork is available in English.

超星学习通章节内ppt视频下载

按下D下载ppt,pdf,上课视频

// ==UserScript==
// @name         超星学习通章节内ppt视频下载
// @namespace    http://tampermonkey.net/
// @version      1.12
// @description  按下D下载ppt,pdf,上课视频
// @author       西电网信院的废物rytter & 西电网信院的废物B4a
// @match        https://*/*/mycourse/studentstudy*
// @match        http://*/*/mycourse/studentstudy*
// @match        https://*/mycourse/studentstudy*
// @match        http://*/mycourse/studentstudy*
// @match        https://*/*/*/mycourse/studentstudy*
// @match        http://*/*/*/mycourse/studentstudy*
// @match        http://*/nodedetailcontroller/*
// @match        https://*/nodedetailcontroller/*
// @icon         
// @grant        none
// @updateURL
// @installURL
// @downloadURL
// @license      MIT
// ==/UserScript==

function get_xueyinonline_objectid() {
    var ans_classes = document.getElementsByClassName("ans-attach-ct");
    // support old version used by learning.xidian.edu.cn
    if (ans_classes.length === 0) {
        ans_classes = document.getElementsByClassName("ans-cc")
    }
    console.log("任务数量: ", ans_classes.length);
    var objectids = new Array();
    for (var j = 0; j < ans_classes.length; j++) {
        console.log(ans_classes[j]);
        if (
            ans_classes[j]
                .getElementsByTagName("iframe")[0]
                .getAttribute("objectid") != undefined
        ) {
            objectids = objectids.concat(
                ans_classes[j]
                    .getElementsByTagName("iframe")[0]
                    .getAttribute("objectid")
            );
        }
    }
    console.log("任务对象:", objectids);
    return objectids;
}

function get_chaoxing_objectid() {
    var ans_classes = document
        .getElementsByTagName("iframe")[0]
        .contentDocument.body.getElementsByClassName("ans-attach-ct");
    console.log(ans_classes.length);
    var objectids = new Array();
    for (var j = 0; j < ans_classes.length; j++) {
        console.log(ans_classes[j]);
        if (
            ans_classes[j]
                .getElementsByTagName("iframe")[0]
                .getAttribute("objectid") != undefined
        ) {
            objectids = objectids.concat(
                ans_classes[j]
                    .getElementsByTagName("iframe")[0]
                    .getAttribute("objectid")
            );
        }
    }
    console.log(objectids);
    return objectids;
}

function download(i,isPPT) {
    // firstly, we need to get the objectid
    var tipsDiv = document.querySelector('.tips');

    if (!tipsDiv) {
        // If it doesn't exist, create it and set styles to make it float in the top right corner
        tipsDiv = document.createElement('div');
        tipsDiv.className = 'tips';
        document.body.appendChild(tipsDiv);

        // Apply styles directly or add a class
        tipsDiv.style.position = 'fixed';
        tipsDiv.style.top = '10px';
        tipsDiv.style.right = '10px';
        tipsDiv.style.backgroundColor = 'rgb(209 232 255 / 90%)';
        tipsDiv.style.padding = '10px';
        tipsDiv.style.zIndex = '1000'; // Ensure it's on top of other elements
        tipsDiv.style.textAlign = 'right'; // Align text to the right
    }

    // unhide
    if (tipsDiv.style.zIndex === '-1') {
        tipsDiv.style.zIndex = '1000';
    }

    tipsDiv.innerHTML = '<i></i>';

    var objectids = get_xueyinonline_objectid();
    if (objectids.length == 0) {
        objectids = get_chaoxing_objectid();
    }

    var objectid = objectids[i % objectids.length];
    console.log(objectid);

    var protocolStr = document.location.protocol;
    var url = protocolStr + "//mooc1." + (window.location.href.includes("xueyinonline") ? "xueyinonline" : "chaoxing") + ".com/ananas/status/" + objectid + "?flag=normal";
    console.log("资源URL:", url);

    // 使用fetch API获取文件信息
    fetch(url)
        .then(response => response.json())
        .then(json => {
            console.log(json);
            var fileUrl, fullFileName;
            if (json.pdf === undefined) {
                fileUrl = json.http;
                var fileExtension = json.filename ? json.filename.split('.').pop() : '';
                fullFileName = json.filename;
                if (json.pdf === undefined && fileExtension) {
                    var prevTitle = document.querySelector('.prev_title')?.textContent || 'download';
                    fullFileName = prevTitle + '.' + fileExtension;
                }
            } else if (json.filename.includes(".ppt") && isPPT) {
                fileUrl = json.download.replace('http','https');
                fullFileName = json.filename;
                window.open(fileUrl)
                console.log(fileUrl)
                return
            } else {
                // Assuming json.pdf or json.download is the URL to the file you want to download
                fileUrl = json.pdf || json.download;
                fullFileName = json.filename;
            }

            // Create elements for file name, file size, and percentage
            var fileNameSpan = document.createElement('span');
            fileNameSpan.textContent = '下载文件: ' + fullFileName;
            fileNameSpan.style.marginRight = '10px'; // Add margin to the right


            var percentageSpan = document.createElement('span');
            percentageSpan.textContent = '0%';
            percentageSpan.style.marginLeft = '10px'; // Add margin to the right
            percentageSpan.style.width = '60px';

            // Create a progress bar element and append it to the tips div
            var progressBar = document.createElement('progress');
            var fileSizeSpan = document.createElement('span');
            fileSizeSpan.textContent = '文件大小:计算中……';
            fileSizeSpan.style.marginRight = '10px'; // Add margin to the right

            progressBar.value = 0;
            progressBar.max = 100;
            tipsDiv.appendChild(fileNameSpan);
            tipsDiv.appendChild(fileSizeSpan);
            tipsDiv.appendChild(progressBar);
            tipsDiv.appendChild(percentageSpan);

            var xhr = new XMLHttpRequest();

            xhr.open('GET', fileUrl, true);
            xhr.responseType = 'blob';
            xhr.onprogress = function (event) {
                if (event.lengthComputable) {
                    var percentComplete = (event.loaded / event.total) * 100;
                    progressBar.value = percentComplete; // Update the progress bar value
                    percentageSpan.textContent = percentComplete.toFixed(2) + '%'; // Update the percentage text
                    fileSizeSpan.textContent = '文件大小:' + (event.total / 1024 / 1024).toFixed(2) + ' MB'; // Update the file size text
                }
            };

            xhr.onload = function (event) {
                if (this.status === 200) {
                    var blob = this.response;

                    if (blob.type === 'application/pdf') {
                        // Check if the blob type is application/pdf
                        // Modify the filename to have the .pdf extension
                        var extension = '.pdf';
                        if (!fullFileName.endsWith(extension)) {
                            // If the filename doesn't end with .pdf, modify it
                            fullFileName = fullFileName.replace(/\.[^.]+$/, '') + extension;
                        }
                    }
                    var downloadUrl = window.URL.createObjectURL(blob);
                    var a = document.createElement("a");
                    a.href = downloadUrl;
                    a.download = fullFileName || 'download'; // Set the download filename here
                    document.body.appendChild(a);
                    a.click();
                    a.remove(); // Remove the element after download starts
                    window.URL.revokeObjectURL(downloadUrl); // Clean up the URL object
                    tipsDiv.innerHTML = ''; // Optionally clear the progress bar after download
                }
                if (tipsDiv.style.position === 'fixed') {
                    tipsDiv.style.zIndex = '-1';
                }
            };

            xhr.onerror = function () {
                console.error("Error fetching the file for download.");
                tipsDiv.innerHTML = '下载失败!'; // Display error message in tips div
            };

            xhr.send();

        })
        .catch(error => {
            console.error("Error fetching the JSON data:", error);
        });
}


(function () {
    "use strict";
    var i1= 0;
    var i2 = 0;
    var i3 = 0;
    // 创建按钮容器
    var buttonContainer = document.createElement('div');
    buttonContainer.style.position = 'fixed';
    buttonContainer.style.left = '10px';
    buttonContainer.style.top = '50%';
    buttonContainer.style.transform = 'translateY(-50%)';
    buttonContainer.style.display = 'flex';
    buttonContainer.style.flexDirection = 'column';
    buttonContainer.style.zIndex='9999'

    // 创建下载 PPT 按钮
    var pptButton = document.createElement('button');
    pptButton.innerText = '下载 PPT';
    pptButton.style.margin = '10px 0';
    pptButton.style.padding = '10px 20px';
    pptButton.style.backgroundColor = '#4CAF50';
    pptButton.style.color = 'white';
    pptButton.style.border = 'none';
    pptButton.style.cursor = 'pointer';
    pptButton.style.fontSize = '16px';

    // 创建下载 PDF 按钮
    var pdfButton = document.createElement('button');
    pdfButton.innerText = '下载 PDF';
    pdfButton.style.margin = '10px 0';
    pdfButton.style.padding = '10px 20px';
    pdfButton.style.backgroundColor = '#4CAF50';
    pdfButton.style.color = 'white';
    pdfButton.style.border = 'none';
    pdfButton.style.cursor = 'pointer';
    pdfButton.style.fontSize = '16px';

    // PPT 按钮点击事件
    pptButton.addEventListener('click', function() {
        download(i1++,true); // 调用 download 函数
    });

    // PDF 按钮点击事件
    pdfButton.addEventListener('click', function() {
        download(i2++,false); // 调用 download 函数
    });

    // 将按钮添加到页面
    buttonContainer.appendChild(pptButton);
    buttonContainer.appendChild(pdfButton);
    document.body.appendChild(buttonContainer);
    document.onkeydown = function (e) {
        //对整个页面监听
        var keyNum = window.event ? e.keyCode : e.which; //获取被按下的键值
        if (keyNum == 68) {
            download(i3++,false);
        }
    };
})();