您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
音视频下载器
当前为
// ==UserScript== // @name Vdownload // @name:zh-CN 下载器(个人使用) // @namespace http://tampermonkey.net/ // @version 0.35 // @description 音视频下载器 // @author 浣熊 // @match *://*/* // @icon  // @grant none // @run-at document-start // @require https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js // @license https://github.com/1024Vip/Vdownload/blob/main/LICENSE // ==/UserScript== (function () { window.autoDownload = 0; window.isComplete = 0; window.audio = []; window.video = []; window.downloadAll = 0; window.quickPlay = 1.0; var isDelTabPage = 0; //1关闭; var downloadName = document.title; var isVideo = 0;//1存在视频 var loadTrue = false; function styleInject(css, ref) { var insertAt, head, style; void 0 === ref && (ref = {}), insertAt = ref.insertAt, css && "undefined" != typeof document && (head = document.head || document.getElementsByTagName("head")[0], (style = document.createElement("style")).type = "text/css", "top" === insertAt && head.firstChild ? head.insertBefore(style, head.firstChild) : head.appendChild(style), style.styleSheet ? style.styleSheet.cssText = css : style.appendChild(document.createTextNode(css))); } function XF() { let parentID = 'VdownLoad-nav'; //鼠标移动 var scrollMove = function () { window.onscroll = window.onload = function () { var scrollsidebar = document.getElementById(parentID); var scrolltop = document.body.scrollTop || document.documentElement.scrollTop; startMove( parseInt( (document.documentElement.clientHeight - scrollsidebar.offsetHeight) / 2 + scrolltop ) ); }; }; //获取元素 var dv = document.getElementById(parentID); var x = 0; var y = 0; var l = 0; var t = 0; var isDown = false; //鼠标按下事件 dv.onmousedown = function (e) { //获取x坐标和y坐标 x = e.clientX; y = e.clientY; //获取左部和顶部的偏移量 l = dv.offsetLeft; t = dv.offsetTop; //开关打开 isDown = true; //设置样式 dv.style.cursor = 'move'; } //鼠标移动 dv.onmousemove = function (e) { if (isDown == false) { return; } //获取x和y var nx = e.clientX; var ny = e.clientY; //计算移动后的左偏移量和顶部的偏移量 var nl = nx - (x - l); var nt = ny - (y - t); dv.style.left = nl + 'px'; dv.style.top = nt + 'px'; } //鼠标抬起事件 dv.onmouseup = function () { //开关关闭 isDown = false; dv.style.cursor = 'default'; } }; const SetplaybackRate = (e) => { var pageX = e.pageX, pageY = e.pageY; let ID = 'div_play'; if ($('#' + ID).length > 0) { $('#' + ID).remove(); } let SD = 1; if (document.querySelector('video') !== null) SD = document.querySelector('video').playbackRate; $('body').prepend(` <div id="${ID}" class="div_play" style="display:none"> <input type="number" min="0" max="16" value="${SD}" id="numPlay"> <input type="button" value="取消" onclick="$('#${ID}').fadeOut(()=>$(this).parent().remove())"> <input type="button" value="确定" id="playSDSure""> </div> `) $(document).on('click', '#playSDSure', () => { playSDSure('numPlay') }) // onclick="playSDSure('numPlay') let py = document.getElementById(ID); $(py).fadeIn(); py.style.left = pageX + 'px'; py.style.top = pageY + 'px'; } const playSDSure = (id) => { let val = parseFloat($('#' + id).val()); val = val === 0 ? 1 : val; if (document.querySelector('video') !== null) document.querySelector('video').playbackRate = val; console.log(val); $('#' + id).parent().fadeOut(() => { $(this).remove() }); } const Vdown = (isDel) => { isDelTabPage = isDel; window.autoDownload = 1; } const XFrun = () => { if (loadTrue) { return; } if (isVideo !== 1) return; if (location.href.indexOf('51moot') > 0) { window.onblur = null; downloadName = $('.vedio-play-nav ul li').last().get(0).innerText document.querySelector('video').playbackRate = 16.0; // if (document.querySelector('video') !== null) { // } } $('body').prepend(` <div class="aside-nav bounceInUp animated no-filter" id="VdownLoad-nav"> <label for="" class="aside-menu" title="按住拖动">Videos</label> <a href="javascript:void(0)" title="本次关闭" id="XFclose" class="menu-item menu-line menu-first">本次<br>关闭</a> <a href="javascript:void(0)" id="vdown0" title="缓存进度条完成时,自动下载视频" class="menu-item menu-line menu-second">下载<br>视频</a> <a href="javascript:void(0)" id="vdown1" title="缓存进度条完成时,自动下载视频,并自动关闭当前页" class="menu-item menu-line menu-third">下载后<br>关闭</a> <a href="javascript:void(0)" title="设置播放速度" id="SetplaybackRate" class="menu-item menu-line menu-fourth">设置<br>速度</a> </div> `) $(document).on('click', '#XFclose', () => { let $nav =$('#VdownLoad-nav');$nav.fadeOut(()=>{loadTrue=false;$nav.remove()}) }) $(document).on('click', '#SetplaybackRate', () => { SetplaybackRate(event) }) $(document).on('click', '#vdown0', () => { Vdown(0) }) $(document).on('click', '#vdown1', () => { Vdown(1) }) var css_asd1 = ` .div_play { background-color: #f34444; opacity: .8; padding: 10px; border-radius: 10px; position: fixed; z-index: 999999; } html .aside-nav { -ms-text-size-adjust: 100%; -webkit-text-size-adjust: 100%; -webkit-font-smoothing: antialiased; font-size: 62.5% } body .aside-nav { font-family: "Helvetica Neue", Helvetica, "Microsoft YaHei", Arial, sans-serif; margin: 0; font-size: 1.6rem; color: #4e546b } .aside-nav { position: fixed; bottom: 0; left: -47px; width: 260px; height: 260px; -webkit-filter: url(#goo); filter: url(#goo); -ms-user-select: none; -moz-user-select: none; -webkit-user-select: none; user-select: none; opacity: .75; z-index: 99999 } .aside-nav.no-filter { -webkit-filter: none; filter: none } .aside-nav .aside-menu { position: absolute; width: 70px; height: 70px; -webkit-border-radius: 50%; border-radius: 50%; background: #f34444; left: -95px; top: 0; right: 0; bottom: 0; margin: auto; text-align: center; line-height: 70px; color: #fff; font-size: 20px; z-index: 1; cursor: move } .aside-nav .menu-item { position: absolute; width: 60px; height: 60px; background-color: #ff7676; left: -95px; top: 0; right: 0; bottom: 0; margin: auto; line-height: 60px; text-align: center; -webkit-border-radius: 50%; border-radius: 50%; text-decoration: none; color: #fff; -webkit-transition: background .5s, -webkit-transform .6s; transition: background .5s, -webkit-transform .6s; -moz-transition: transform .6s, background .5s, -moz-transform .6s; transition: transform .6s, background .5s; transition: transform .6s, background .5s, -webkit-transform .6s, -moz-transform .6s; font-size: 14px; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box } .aside-nav .menu-item:hover { background: #a9c734 } .aside-nav .menu-line { line-height: 20px; padding-top: 10px } .aside-nav:hover { opacity: 1 } .aside-nav:hover .aside-menu { -webkit-animation: jello 1s; -moz-animation: jello 1s; animation: jello 1s } .aside-nav:hover .menu-first { -webkit-transform: translate3d(0, -135%, 0); -moz-transform: translate3d(0, -135%, 0); transform: translate3d(0, -135%, 0) } .aside-nav:hover .menu-second { -webkit-transform: translate3d(120%, -70%, 0); -moz-transform: translate3d(120%, -70%, 0); transform: translate3d(120%, -70%, 0) } .aside-nav:hover .menu-third { -webkit-transform: translate3d(120%, 70%, 0); -moz-transform: translate3d(120%, 70%, 0); transform: translate3d(120%, 70%, 0) } .aside-nav:hover .menu-fourth { -webkit-transform: translate3d(0, 135%, 0); -moz-transform: translate3d(0, 135%, 0); transform: translate3d(0, 135%, 0) } @-webkit-keyframes jello { from, 11.1%, to { -webkit-transform: none; transform: none } 22.2% { -webkit-transform: skewX(-12.5deg) skewY(-12.5deg); transform: skewX(-12.5deg) skewY(-12.5deg) } 33.3% { -webkit-transform: skewX(6.25deg) skewY(6.25deg); transform: skewX(6.25deg) skewY(6.25deg) } 44.4% { -webkit-transform: skewX(-3.125deg) skewY(-3.125deg); transform: skewX(-3.125deg) skewY(-3.125deg) } 55.5% { -webkit-transform: skewX(1.5625deg) skewY(1.5625deg); transform: skewX(1.5625deg) skewY(1.5625deg) } 66.6% { -webkit-transform: skewX(-.78125deg) skewY(-.78125deg); transform: skewX(-.78125deg) skewY(-.78125deg) } 77.7% { -webkit-transform: skewX(0.390625deg) skewY(0.390625deg); transform: skewX(0.390625deg) skewY(0.390625deg) } 88.8% { -webkit-transform: skewX(-.1953125deg) skewY(-.1953125deg); transform: skewX(-.1953125deg) skewY(-.1953125deg) } } @-moz-keyframes jello { from, 11.1%, to { -moz-transform: none; transform: none } 22.2% { -moz-transform: skewX(-12.5deg) skewY(-12.5deg); transform: skewX(-12.5deg) skewY(-12.5deg) } 33.3% { -moz-transform: skewX(6.25deg) skewY(6.25deg); transform: skewX(6.25deg) skewY(6.25deg) } 44.4% { -moz-transform: skewX(-3.125deg) skewY(-3.125deg); transform: skewX(-3.125deg) skewY(-3.125deg) } 55.5% { -moz-transform: skewX(1.5625deg) skewY(1.5625deg); transform: skewX(1.5625deg) skewY(1.5625deg) } 66.6% { -moz-transform: skewX(-.78125deg) skewY(-.78125deg); transform: skewX(-.78125deg) skewY(-.78125deg) } 77.7% { -moz-transform: skewX(0.390625deg) skewY(0.390625deg); transform: skewX(0.390625deg) skewY(0.390625deg) } 88.8% { -moz-transform: skewX(-.1953125deg) skewY(-.1953125deg); transform: skewX(-.1953125deg) skewY(-.1953125deg) } } @keyframes jello { from, 11.1%, to { -webkit-transform: none; -moz-transform: none; transform: none } 22.2% { -webkit-transform: skewX(-12.5deg) skewY(-12.5deg); -moz-transform: skewX(-12.5deg) skewY(-12.5deg); transform: skewX(-12.5deg) skewY(-12.5deg) } 33.3% { -webkit-transform: skewX(6.25deg) skewY(6.25deg); -moz-transform: skewX(6.25deg) skewY(6.25deg); transform: skewX(6.25deg) skewY(6.25deg) } 44.4% { -webkit-transform: skewX(-3.125deg) skewY(-3.125deg); -moz-transform: skewX(-3.125deg) skewY(-3.125deg); transform: skewX(-3.125deg) skewY(-3.125deg) } 55.5% { -webkit-transform: skewX(1.5625deg) skewY(1.5625deg); -moz-transform: skewX(1.5625deg) skewY(1.5625deg); transform: skewX(1.5625deg) skewY(1.5625deg) } 66.6% { -webkit-transform: skewX(-.78125deg) skewY(-.78125deg); -moz-transform: skewX(-.78125deg) skewY(-.78125deg); transform: skewX(-.78125deg) skewY(-.78125deg) } 77.7% { -webkit-transform: skewX(0.390625deg) skewY(0.390625deg); -moz-transform: skewX(0.390625deg) skewY(0.390625deg); transform: skewX(0.390625deg) skewY(0.390625deg) } 88.8% { -webkit-transform: skewX(-.1953125deg) skewY(-.1953125deg); -moz-transform: skewX(-.1953125deg) skewY(-.1953125deg); transform: skewX(-.1953125deg) skewY(-.1953125deg) } } .animated { -webkit-animation-duration: 1s; -moz-animation-duration: 1s; animation-duration: 1s; -webkit-animation-fill-mode: both; -moz-animation-fill-mode: both; animation-fill-mode: both } @-webkit-keyframes bounceInUp { from, 60%, 75%, 90%, to { -webkit-animation-timing-function: cubic-bezier(0.215, .61, .355, 1); animation-timing-function: cubic-bezier(0.215, .61, .355, 1) } from { opacity: 0; -webkit-transform: translate3d(0, 800px, 0); transform: translate3d(0, 800px, 0) } 60% { opacity: 1; -webkit-transform: translate3d(0, -20px, 0); transform: translate3d(0, -20px, 0) } 75% { -webkit-transform: translate3d(0, 10px, 0); transform: translate3d(0, 10px, 0) } 90% { -webkit-transform: translate3d(0, -10px, 0); transform: translate3d(0, -10px, 0) } to { -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0) } } @-moz-keyframes bounceInUp { from, 60%, 75%, 90%, to { -moz-animation-timing-function: cubic-bezier(0.215, .61, .355, 1); animation-timing-function: cubic-bezier(0.215, .61, .355, 1) } from { opacity: 0; -moz-transform: translate3d(0, 800px, 0); transform: translate3d(0, 800px, 0) } 60% { opacity: 1; -moz-transform: translate3d(0, -20px, 0); transform: translate3d(0, -20px, 0) } 75% { -moz-transform: translate3d(0, 10px, 0); transform: translate3d(0, 10px, 0) } 90% { -moz-transform: translate3d(0, -5px, 0); transform: translate3d(0, -5px, 0) } to { -moz-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0) } } @keyframes bounceInUp { from, 60%, 75%, 90%, to { -webkit-animation-timing-function: cubic-bezier(0.215, .61, .355, 1); -moz-animation-timing-function: cubic-bezier(0.215, .61, .355, 1); animation-timing-function: cubic-bezier(0.215, .61, .355, 1) } from { opacity: 0; -webkit-transform: translate3d(0, 800px, 0); -moz-transform: translate3d(0, 800px, 0); transform: translate3d(0, 800px, 0) } 60% { opacity: 1; -webkit-transform: translate3d(0, -20px, 0); -moz-transform: translate3d(0, -20px, 0); transform: translate3d(0, -20px, 0) } 75% { -webkit-transform: translate3d(0, 10px, 0); -moz-transform: translate3d(0, 10px, 0); transform: translate3d(0, 10px, 0) } 90% { -webkit-transform: translate3d(0, -5px, 0); -moz-transform: translate3d(0, -5px, 0); transform: translate3d(0, -5px, 0) } to { -webkit-transform: translate3d(0, 0, 0); -moz-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0) } } .bounceInUp { -webkit-animation-name: bounceInUp; -moz-animation-name: bounceInUp; animation-name: bounceInUp; -webkit-animation-delay: 1s; -moz-animation-delay: 1s; animation-delay: 1s }`; styleInject(css_asd1); XF(); } //----------------------------分割线---------------------------------------------- const _endOfStream = window.MediaSource.prototype.endOfStream window.MediaSource.prototype.endOfStream = function () { window.isComplete = 1; return _endOfStream.apply(this, arguments) } window.MediaSource.prototype.endOfStream.toString = function () { // console.log('endOfStream hook is detecting!'); return _endOfStream.toString(); } const _addSourceBuffer = window.MediaSource.prototype.addSourceBuffer window.MediaSource.prototype.addSourceBuffer = function (mime) { // console.log("MediaSource.addSourceBuffer ", mime) if (mime.toString().indexOf('audio') !== -1) { window.audio = []; // console.log('audio array cleared.'); } else if (mime.toString().indexOf('video') !== -1) { window.video = []; // console.log('video array cleared.'); } let sourceBuffer = _addSourceBuffer.call(this, mime) const _append = sourceBuffer.appendBuffer sourceBuffer.appendBuffer = function (buffer) { // console.log(mime, buffer); if (mime.toString().indexOf('audio') !== -1) { window.audio.push(buffer); } else if (mime.toString().indexOf('video') !== -1) { window.video.push(buffer) } _append.call(this, buffer) } sourceBuffer.appendBuffer.toString = function () { // console.log('appendSourceBuffer hook is detecting!'); return _append.toString(); } isVideo = 1; XFrun(); loadTrue = true; console.log(Date.now()) return sourceBuffer } window.MediaSource.prototype.addSourceBuffer.toString = function () { // console.log('addSourceBuffer hook is detecting!'); return _addSourceBuffer.toString(); } function download() { let a = document.createElement('a'); a.href = window.URL.createObjectURL(new Blob(window.audio)); a.download = 'audio_' + downloadName + '.mp4'; a.click(); a.href = window.URL.createObjectURL(new Blob(window.video)); a.download = 'video_' + downloadName + '.mp4'; a.click(); window.downloadAll = 0; window.isComplete = 0; window.autoDownload = 0; if (isDelTabPage === 1) { closePage(); } } function closePage() { if (navigator.userAgent.indexOf("Firefox") != -1 || navigator.userAgent.indexOf("Chrome") != -1) { window.location.href = "about:blank"; window.close(); } else { window.opener = null; window.open("", "_self"); window.close(); } } setInterval(() => { if (window.downloadAll === 1) { download(); } }, 2000); // setInterval(() => { // if(window.quickPlay !==1.0){ // document.querySelector('video').playbackRate = window.quickPlay; // } // // }, 2000); // if (window.autoDownload === 1) { let autoDownInterval = setInterval(() => { if (window.isComplete === 1 && window.autoDownload === 1) { download(); } }, 2000); // } (function (that) { let removeSandboxInterval = setInterval(() => { if (that.document.querySelectorAll('iframe')[0] !== undefined) { that.document.querySelectorAll('iframe').forEach((v, i, a) => { let ifr = v; // ifr.sandbox.add('allow-popups'); ifr.removeAttribute('sandbox'); const parentElem = that.document.querySelectorAll('iframe')[i].parentElement; a[i].remove(); parentElem.appendChild(ifr); }); clearInterval(removeSandboxInterval); } }, 1000); })(window); })();