Greasy Fork is available in English.
按下D下载ppt,pdf,上课视频
当前为
// ==UserScript==
// @name 超星学习通章节内ppt视频下载
// @namespace http://tampermonkey.net/
// @version 1.13
// @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 https://*/*/mycourse/teacherstudy*
// @match http://*/*/mycourse/teacherstudy*
// @match https://*/mycourse/teacherstudy*
// @match http://*/mycourse/teacherstudy*
// @match https://*/*/*/mycourse/teacherstudy*
// @match http://*/*/*/mycourse/teacherstudy*
// @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);
}
};
})();