NOTICE: By continued use of this site you understand and agree to the binding Terms of Service and Privacy Policy.
// ==UserScript== // @name 短视频去水印(支持抖音网页版) // @version 1.0.6 // @license MIT // @description 一款短视频去水印下载工具,支持抖音网页版视频无水印下载 // @icon  // @author 我爱工具箱 // @match *://*.douyin.com/* // @match *://*.iesdouyin.com/* // @require https://lib.baomitu.com/jquery/3.6.0/jquery.js // @require https://lib.baomitu.com/sweetalert/2.1.2/sweetalert.min.js // @require https://lib.baomitu.com/clipboard.js/2.0.6/clipboard.min.js // @grant GM_addStyle // @grant GM_getValue // @grant GM_setValue // @grant GM_deleteValue // @grant GM_listValues // @grant GM_openInTab // @grant GM_notification // @grant GM_xmlhttpRequest // @grant GM_download // @namespace https://greasyfork.org/users/894875 // ==/UserScript== (function() { let showTipErrorSwal = function(err) { showSwal(err, { icon: 'error' }); } const divTips = document.createElement('div'); divTips.id = "divTips"; let showSwal = function(content, option) { divTips.innerHTML = content; option.content = divTips; if (!option.hasOwnProperty('button')) { option.button = '我知道了' } swal(option); } let isDouyinPage = function() { let url = location.href; if (url.indexOf("https://www.douyin.com/") != -1) { return true; } else { return false; } }; let getVideoUrl = function() { let RENDER_DATA = document.getElementById("RENDER_DATA"); if (RENDER_DATA == null) { return ""; } let RENDER_DATA_STR = RENDER_DATA.textContent; renderData = decodeURIComponent(RENDER_DATA_STR); let jsonObject = JSON.parse(renderData); let data = null; for (let key in jsonObject) { if ("_location" == key || "app" == key || "11" == key) { continue; } data = key; } let dataJo = jsonObject[data]; let detail = dataJo["videoDetail"]; let video = detail["video"]; let playAddr = video["playAddr"]; let video1 = playAddr[0]; let src = video1["src"]; let videoUrl = "https:" + src; videoUrl = videoUrl.substring(0, videoUrl.length - 1); return videoUrl; } var videoDownloadNum = 0; let successCall = function(videoUrl, videoName) { if (videoUrl == null) { videoUrl = getVideoUrl(); } if (videoDownloadNum == 0) { GM_download({ url: videoUrl, name: videoName + '.mp4' }); videoDownloadNum++; } } let initButtonEvent = function() { if (isDouyinPage()) { videoDownloadNum = 0; let videoNode = document.getElementsByTagName("video"); let nameIndex = 0; let videoIndex = 0; if(videoNode[0].getAttribute("tabindex") != undefined) { nameIndex = videoNode.length == 1 ? 0 : videoNode.length - 2; videoIndex = nameIndex; }else{ nameIndex = 0; videoIndex = 2; } let index = videoNode.length == 1 ? 0 : videoNode.length - 2; let spanNode = document.getElementsByClassName("npIvCX5K")[nameIndex].childNodes[0]; let videoName = ""; for (let i = 0; i < spanNode.childNodes.length; i++) { let childNode = spanNode.children[i]; if (childNode != undefined) { videoName = videoName + childNode.textContent; } } if (videoName.trim().length == 0) { let accountNameSpanNode = document.getElementsByClassName("account-name")[index].childNodes[0]; for (let i = 0; i < accountNameSpanNode.childNodes.length; i++) { let childNode = accountNameSpanNode.children[i]; if (childNode != undefined) { videoName = videoName + childNode.textContent; } } } let sourceNodes = videoNode[videoIndex].getElementsByTagName("source"); for (let i = 0; i < sourceNodes.length; i++) { try { let videoUrl = decodeURI('https:' + sourceNodes[i].getAttribute("src")); GM_xmlhttpRequest(headRequest(videoUrl, videoName, successCall)); } catch (error) { console.error(error); } } } }; let headRequest = function(url, videoName, call) { return { method: 'HEAD', timeout: 300000, // 30秒超时 url: url, onload: function(res) { if (res.status === 200) { call(url, videoName); } else { console.error(res); } }, ontimeout: (res) => { console.error(res); }, onerror: (res) => { console.error(res); } } }; let start = function() { if (!isDouyinPage()) { //console.log('非正常页面,1秒后将重新查找!'); return; } let btn = document.createElement('a'); let btnShare = document.getElementsByClassName('OFZHdvpl') if (btnShare.length == 0) { btnShare = document.getElementsByClassName('Z1DFGRDj') if (btnShare.length == 0) { return; } btn.style.cssText = "padding-left: 10px;"; } let btnDownload = { id: 'btnClickDownload', title: '点击下载视频', html: function() { return `<img height="26" width="26" src=""/>`; } } let button = document.getElementById(btnDownload.id); if (button != null) { return; } btn.id = btnDownload.id; btn.title = btnDownload.title; btn.innerHTML = btnDownload.html(); btn.addEventListener('click', function(e) { initButtonEvent(); e.preventDefault(); }); btnShare[0].appendChild(btn); } setInterval(function() { start(); }, 1000) })();