// ==UserScript== // @name KeepVid New Helper // @namespace https://keepvid.app/ // @version 1.5 // @description This userscript assists KeepVid in fetching download links. Mainly used as an alternative to the Java option currently provided. // @copyright 2014+, KeepVid // @icon https://keepvid.app/icon128.png // @icon64 https://keepvid.app/icon64.png // @homepage https://keepvid.app/extensions // updateURL https://keepvid.app/keepvid.user.meta.js // downloadURL https://keepvid.app/keepvid.user.js // @updateURL https://keepvid.app/keepvid.user.meta.js // @downloadURL https://keepvid.app/keepvid.user.js // @require https://code.jquery.com/jquery-1.11.0.min.js // @include http://* // @include https://* // @run-at document-start // @connect dailymotion.com // @connect vimeo.com // @connect cloudy.ec // @connect novamov.com // @connect soundcloud.com // @connect youtube.com // @connect ytimg.com // @connect * // @grant GM_xmlhttpRequest // ==/UserScript== var AttachStyleEnum = { AttachOuterTopLeft: 0, AttachOuterTopRight: 1, AttachOuterBottomLeft: 2, AttachOuterBottomRight: 3, AttachInnerTopLeft: 4, AttachInnerTopRight: 5, AttachInnerBottomLeft: 6, AttachInnerBottomRight: 7 }; //请求,网页请求 var xhr = new XMLHttpRequest(); var facebookDom; var isRequesting; var requestHtml; var fbVideoId; //$(document).ready(function(){ // keepvid.CheckAllWebsiteLink(); //}); window.onload=function(event){ keepvid.requestHtml= null; keepvid.CheckAllWebsiteLink(); }; if("undefined" == typeof (keepvid)) { var keepvid = { buttonList: [], isInitialAdjustPos: false, mouseOutTimer: null, getBrowserIndent: function() { var ua = window.navigator.userAgent.toLowerCase(); if(ua.indexOf("chrome")>0) { return "chrome"; } else if(ua.indexOf("firefox")>0){ return "firefox"; } else if(ua.indexOf("safari")>0) { return "safari"; } else { return ""; } }, // Get Element Position getElementPos: function(el) { var ua = window.navigator.userAgent.toLowerCase(); var isOpera = (ua.indexOf('opera') != -1); var isIE = (ua.indexOf('msie') != -1 && !isOpera); // not opera spoof if (el.parentNode === null || (el.style != null && el.style.display == 'none')) { return false; } var parent = null; var pos = []; var box; if (el.getBoundingClientRect) { // IE box = el.getBoundingClientRect(); var scrollTop = Math.max(document.documentElement.scrollTop, document.body.scrollTop); var scrollLeft = Math.max(document.documentElement.scrollLeft, document.body.scrollLeft); return { x: box.left + scrollLeft, y: box.top + scrollTop }; } else if (document.getBoxObjectFor) { // gecko box = document.getBoxObjectFor(el); var borderLeft = (el.style.borderLeftWidth) ? parseInt(el.style.borderLeftWidth) : 0; var borderTop = (el.style.borderTopWidth) ? parseInt(el.style.borderTopWidth) : 0; pos = [box.x - borderLeft, box.y - borderTop]; } else { // safari & opera pos = [el.offsetLeft, el.offsetTop]; parent = el.offsetParent; if (parent != el) { while (parent) { pos[0] += parent.offsetLeft; pos[1] += parent.offsetTop; parent = parent.offsetParent; } } if (ua.indexOf('opera') != -1 || (ua.indexOf('safari') != -1 && (el.style != null && el.style.position == 'absolute'))) { pos[0] -= document.body.offsetLeft; pos[1] -= document.body.offsetTop; } } if (el.parentNode) { parent = el.parentNode; } else { parent = null; } while (parent && parent.tagName != 'BODY' && parent.tagName != 'HTML') { // account for any scrolled ancestors pos[0] -= parent.scrollLeft; pos[1] -= parent.scrollTop; if (parent.parentNode) { parent = parent.parentNode; } else { parent = null; } } return { x: pos[0], y: pos[1] }; }, calculateButtonPos: function(attachedElement, buttonDiv, attachStyle) { // alter the button's position var btnWidth = buttonDiv.offsetWidth; var btnHeight = buttonDiv.offsetHeight; var pos = this.getElementPos(attachedElement); var beforeChildLeft = pos.x; var beforeChildTop = pos.y; var divLeft = 0; var divTop = 0; switch (attachStyle) { case AttachStyleEnum.AttachOuterTopLeft: { divLeft = beforeChildLeft; divTop = beforeChildTop - btnHeight; break; } case AttachStyleEnum.AttachOuterTopRight: { divLeft = beforeChildLeft + attachedElement.offsetWidth - btnWidth; divTop = beforeChildTop - btnHeight; break; } case AttachStyleEnum.AttachOuterBottomLeft: { divLeft = beforeChildLeft; divTop = beforeChildTop + attachedElement.offsetHeight; break; } case AttachStyleEnum.AttachOuterBottomRight: { divLeft = beforeChildLeft + attachedElement.offsetWidth - btnWidth; divTop = beforeChildTop + attachedElement.offsetHeight; break; } case AttachStyleEnum.AttachInnerTopLeft: { divLeft = beforeChildLeft; divTop = beforeChildTop; break; } case AttachStyleEnum.AttachInnerTopRight: { divLeft = beforeChildLeft + attachedElement.offsetWidth - btnWidth; divTop = beforeChildTop; break; } case AttachStyleEnum.AttachInnerBottomLeft: { divLeft = beforeChildLeft; divTop = beforeChildTop + attachedElement.offsetHeight - btnHeight; break; } case AttachStyleEnum.AttachInnerBottomRight: { divLeft = beforeChildLeft + attachedElement.offsetWidth - btnWidth; divTop = beforeChildTop + attachedElement.offsetHeight - btnHeight; break; } } return { x: divLeft, y: divTop }; }, // Adjuest The Download Button Element adjustAttachButtonPos: function() { for (var i = 0; i < keepvid.buttonList.length; i++) { attachedElement = keepvid.buttonList[i].attachedElement; buttonDiv = keepvid.buttonList[i].buttonDiv; attachStyle = keepvid.buttonList[i].attachStyle; var divPos = keepvid.calculateButtonPos(attachedElement, buttonDiv, attachStyle); buttonDiv.style.left = divPos.x.toString() + 'px'; buttonDiv.style.top = divPos.y.toString() + 'px'; } }, // 附 加 按 钮 attachButtonDiv: function(attachedElement, attachStyle, buttonCaption, buttonLink, divId, buttonId,videoName) { // Create div element //alert(buttonLink); if (!attachedElement) return; for (var i = 0; i < this.buttonList.length; i++) { if (this.buttonList[i].attachedElement == attachedElement) { return this.buttonList[i].buttonDiv; } }; var downloadDiv = document.createElement("div"); // downloadDiv.setAttribute("id", "ws"); //[safari] downloadDiv.setAttribute("style", "z-index: 2147483647; background: transparent; position: absolute;"); downloadDiv.style.width = 106 + 'px'; downloadDiv.style.height = 31 + 'px'; downloadDiv.style.backgroundImage = "url()"; downloadDiv.style.cursor = "pointer"; if (divId) downloadDiv.setAttribute("id", divId); downloadDiv.style.visibility = 'visible'; if(location.href.indexOf("instagram.com")>0) downloadDiv.style.visibility = 'hidden'; // Create button element var btnDownload = document.createElement("a"); //btnDownload.setAttribute("class", "fantasybutton"); var realLink = "http://www.keepvid.app/gopage.php?url=" + buttonLink; if(videoName !== undefined){ realLink+="&videoName="+videoName; } realLink += "&from=plugin#downloader"; // if(this.getBrowserIndent() == "firefox") // btnDownload.setAttribute("href", realLink); // else if(this.getBrowserIndent() == "chrome") // downloadDiv.onclick = function () { // //btnDownload.onclick = function () { // downloadDiv.style.visibility = 'hidden'; // myWindow1 = window.open(realLink, '_blank', ''); // myWindow1.focus(); // }; // //downloadDiv.href = buttonLink; // else if(this.getBrowserIndent() == "safari") { // //btnDownload.setAttribute("href", "javascript:void(0);"); // btnDownload.setAttribute("href", realLink); // //btnDownload.addEventListener("click", function(){this.blur(); window.location.href = buttonLink; downloadDiv.style.visibility = 'hidden'; return false; }); // btnDownload.addEventListener("click", function(){this.blur(); downloadDiv.style.visibility = 'hidden'; return false; }); // } downloadDiv.onclick = function () { //btnDownload.onclick = function () { if(location.href.indexOf("facebook.com")< 0){ downloadDiv.style.visibility = 'hidden'; } myWindow1 = window.open(realLink, '_blank', ''); myWindow1.focus(); }; btnDownload.style.cursor = "pointer"; var btnText = document.createElement("span"); if (buttonCaption) btnText.innerHTML = buttonCaption; btnDownload.appendChild(btnText); downloadDiv.appendChild(btnDownload); var body = document.body; body.insertBefore(downloadDiv, body.lastChild); var divPos = this.calculateButtonPos(attachedElement, downloadDiv, attachStyle); downloadDiv.style.left = divPos.x.toString() + 'px'; downloadDiv.style.top = divPos.y.toString() + 'px'; // initial onresize event if (!this.isInitialAdjustPos) { window.addEventListener("resize", keepvid.adjustAttachButtonPos, false); //window.addEventListener("DOMNodeInserted", WSCore.adjustAttachButtonPos, false); this.isInitialAdjustPos = true; } // push attachButtonInfo into attachButtonList var attachButtonInfo = {attachedElement: attachedElement, buttonDiv: downloadDiv, attachStyle: attachStyle}; this.buttonList.push(attachButtonInfo); return downloadDiv; }, //返回按钮对象 getButtonElement: function(attachedElement) { for (var i = 0; i < keepvid.buttonList.length; i++) { if (attachedElement == keepvid.buttonList[i].attachedElement) return keepvid.buttonList[i].buttonDiv; } }, showElement: function(el) { // if (WSCore.timeoutHandle) clearTimeout(this.timeoutHandle); if (el) { if (keepvid.mouseOutTimer) clearTimeout(keepvid.mouseOutTimer); el.style.visibility = "visible"; } }, delayHideElement: function(el) { // if (WSCore.timeoutHandle) clearTimeout(this.timeoutHandle); if (el) { el.style.visibility = "hidden"; } }, handleVideoMouseoverEvent: function(event) { //console.log("绑定新的DIV"); for (i = 0; i < keepvid.buttonList.length; i++) { if (event.target == keepvid.buttonList[i].attachedElement) { if (keepvid.mouseOutTimer) {clearTimeout(keepvid.mouseOutTimer);} keepvid.adjustAttachButtonPos(); keepvid.buttonList[i].buttonDiv.style.visibility = "visible"; return; } } for (i = 0; i < keepvid.buttonList.length; i++) { if (event.target == keepvid.buttonList[i].buttonDiv) { if (keepvid.mouseOutTimer) { clearTimeout(keepvid.mouseOutTimer); } keepvid.buttonList[i].buttonDiv.style.visibility = "visible"; return; } } }, handleVideoMouseoutEvent: function(event) { for (i = 0; i < keepvid.buttonList.length; i++) { if (event.target == keepvid.buttonList[i].attachedElement) { el = keepvid.buttonList[i].buttonDiv; keepvid.mouseOutTimer = setTimeout(function () {el.style.visibility = "hidden";}, 500); return; } } for (i = 0; i < keepvid.buttonList.length; i++) { if (event.target == keepvid.buttonList[i].buttonDiv) { el = event.target; keepvid.mouseOutTimer = setTimeout(function () {el.style.visibility = "hidden";}, 500); return; } } }, currentUrl:null, handleDocumentMouseOverEvent: function(event) { event = event|| window.event; var desktopType = document.getElementsByTagName('body')[0].getAttribute('desktopType'); if(desktopType!=undefined && desktopType!=null && desktopType!=''){ return; } if(location.href.indexOf('.mp4')>=0) return; if(event.target.tagName=='IFRAME' && location.href.indexOf("facebook.com")>=0){ //keepvidHref var savedUrl = $($(event.target).parent().parent()[0]).attr('keepvidHref'); var downloadUrlId = $($(event.target).parent().parent()[0]).attr('downloadButtonId'); currentUrl = savedUrl; //如果下载按钮已经创建过的,直接显示 if(savedUrl !==null && savedUrl !== undefined && downloadUrlId!==null && downloadUrlId!==undefined){ //alert($(event.target).parent()[0].id); $('#'+downloadUrlId).css("visibility","visible"); $('#'+downloadUrlId).css("left",$($(event.target).parent().parent()[0]).attr('downloadButtonleft')); $('#'+downloadUrlId).css("top",$($(event.target).parent().parent()[0]).attr('downloadButtontop')); return; } } //facebook不需要这个,直接用最下面的方法去查询调用。 || (event.target.toString().indexOf("HTMLIFrameElement") != -1) event.target instanceof HTMLIFrameElement || if(location.href.indexOf("facebook.com")<0){ if (event.target instanceof HTMLEmbedElement || event.target instanceof HTMLObjectElement || event.target instanceof HTMLVideoElement || (event.target.toString().indexOf("HTMLEmbedElement") != -1) || (event.target.toString().indexOf("HTMLObjectElement") != -1)|| (event.target.toString().indexOf("HTMLVideoElement") != -1)) { var downloadDiv; if( (location.href.indexOf('123movies.is')>=0||location.href.indexOf('123movieshd.to')>=0 ||location.href.indexOf('gomovies.to')>=0) && event.target instanceof HTMLVideoElement ){ var srcHref = $(event.target).attr('src'); var title = $('.mvic-desc h3')==undefined?document.title:$('.mvic-desc h3')[0].innerText; downloadDiv = keepvid.attachButtonDiv(event.target, AttachStyleEnum.AttachOuterTopRight, "", encodeURIComponent(srcHref),undefined,undefined,title); } else{ downloadDiv = keepvid.attachButtonDiv(event.target, AttachStyleEnum.AttachOuterTopRight, "", location.href); } if (keepvid.mouseOutTimer) { clearTimeout(keepvid.mouseOutTimer); } downloadDiv.style.visibility = "visible"; keepvid.bindEvent(event.target, downloadDiv); } } if(location.href.indexOf("facebook.com")<0){ keepvid.instagram(); keepvid.vimeo(); keepvid.vevo(); keepvid.discovery(); keepvid.liveleak(); keepvid.nbcnews(); } //facebook只有在Video标签才去允许下载 if(event.target.tagName == "VIDEO" && location.href.indexOf("facebook.com")>=0){ //先看是不是已经拿过了,如果拿过了就不管了,直接用 var destUrl = $($(event.target).parent().parent()[0]).attr('keepvidHref'); var video_id = $($(event.target).parent().parent()[0]).attr('video_id'); if(destUrl!=null && destUrl!= undefined){ var downloadUrlId = 'FaceBookVideo_' + video_id; if(downloadUrlId!==null && downloadUrlId!==undefined){ $('#'+downloadUrlId).css("visibility","visible"); } else{ var downloadDiv = keepvid.attachButtonDiv(event.target, AttachStyleEnum.AttachOuterTopRight, "", encodeURIComponent(destUrl),undefined,undefined,'FaceBookVideo_' + video_id); keepvid.bindEvent(event.target, downloadDiv); } return; } else{ keepvid.facebook(event.target); } } if((event.target.tagName=="DIV" || event.target.tagName=="A") && location.href.indexOf("facebook.com")>=0){ keepvid.facebookOutLink(event.target); } //暂时不要tumblr的内链 //if(event.target.tagName=="DIV" && location.href.indexOf("tumblr.com")>=0){ // keepvid.tumblrInnerLink(event.target); //} }, bindEvent: function(element, buttonDiv) { element.addEventListener("mouseover", keepvid.handleVideoMouseoverEvent, false); element.addEventListener("mouseout", keepvid.handleVideoMouseoutEvent, false); buttonDiv.addEventListener("mouseover", keepvid.handleVideoMouseoverEvent, false); buttonDiv.addEventListener("mouseout", keepvid.handleVideoMouseoutEvent, false); buttonDiv.addEventListener("mousemove", keepvid.handleVideoMouseoverEvent, false); }, //暂时不要tumblr的内链 //tumblrInnerLink:function(targetDom){ // alert('asdasd'); // if (location.href.indexOf("tumblr.com") >= 0) { // var parentDivNode = targetDom.parentNode; // //如果是视频的话,应该可以从他下面获取到Video标签 // var videoElement = $(targetDom).find('video'); // var srcElement = $(videoElement).find('source'); // // var destURL= $(srcElement).attr('src'); // var sourceAddrType= $(srcElement).attr('type'); // // var videoId = $(videoElement).attr('id'); // //embed-5832961698132629339048_html5_api // if(sourceAddrType.indexOf('mp3')>=0|| sourceAddrType.indexOf('mp4')>=0){ // var downloadDiv = keepvid.attachButtonDiv(targetDom, AttachStyleEnum.AttachOuterTopRight, "", destURL,undefined,undefined,videoId); // keepvid.bindEvent(targetDom, downloadDiv); // } // } //}, vimeo: function() { if (location.href.indexOf("vimeo.com") >= 0) { var els = document.getElementsByTagName("video"); for (var i = 0; i < els.length; i++) { var el = els[i].parentNode.parentNode.parentNode.nextSibling; if (el && (el instanceof HTMLDivElement) && el.className == "target") { var downloadDiv = keepvid.attachButtonDiv(el, AttachStyleEnum.AttachOuterTopRight, "", location.href); keepvid.bindEvent(el, downloadDiv); } } } }, instagram: function() { if (location.href.indexOf("instagram.com") >= 0) { var els = document.getElementsByTagName("video"); for (var i = 0; i < els.length; i++) { var el = els[i].parentNode.parentNode.parentNode.parentNode.lastChild; var dlUrl = els[i].src; if(dlUrl.indexOf("?") >= 0) dlUrl = dlUrl.split('?')[0]; var strArr = dlUrl.split('_'); var point = strArr.length - 2; if(point>0) videoId = strArr[point]; else videoId = new Date().getTime(); var videoName = encodeURIComponent("InstagramVideo_" + videoId.toString()); var imgTar = els[i]; var img = ''; if(imgTar && imgTar.className == "_l6uaz"){ img = '&img=' + encodeURIComponent(imgTar.poster); } if (el && el.className == "_7thjo") { var downloadDiv = keepvid.attachButtonDiv(el, AttachStyleEnum.AttachOuterTopRight, "", encodeURIComponent(els[i].src) + '&videoName='+videoName+img); if(document.getElementsByClassName('_nljxa').length>0) downloadDiv.style.position = 'fixed'; keepvid.bindEvent(el, downloadDiv); } else{ var el = els[i].parentNode.parentNode.parentNode.lastChild; if (el && el.className == "_7thjo") { var downloadDiv = keepvid.attachButtonDiv(el, AttachStyleEnum.AttachOuterTopRight, "", encodeURIComponent(els[i].src) + '&videoName='+videoName+img); if(document.getElementsByClassName('_nljxa').length>0) downloadDiv.style.position = 'fixed'; keepvid.bindEvent(el, downloadDiv); } } } } }, facebook: function(targetDom){ if(isRequesting) return; var destURL; facebookDom = targetDom; //这里要获取地址 var parentsList = $(targetDom).parents(); var currentVideoDiv; for(var i=0;i=2){ fbVideoId = videoIdArr[1]; } } var checkCurrentResult = false; if(requestHtml!= undefined && requestHtml!= null){ checkCurrentResult = keepvid.facebookInnerLinkCheck(requestHtml,videoUrl); } if(checkCurrentResult== false){ keepvid.RequestFaceBookDownloadUrl(videoUrl); } //只接受facebook的网站的东西 //if(location.href.indexOf("facebook.com")>=0){ // //这里要区分两类,第一类是直接从页面上能找到的,找不到的时候再去保存链接里面找,再找不到就没办法了 // //1找到当前Video标签的父节点中包含有data-testid="fbfeed_story"属性的div // var hyperfeedId; // var divList = $(targetDom).parents(); // for(var i=0;i=0){ // marksScriptIndex = i; // break; // } // } // var sourceUrlScript= document.scripts[marksScriptIndex + 1].innerHTML; // if(sourceUrlScript.indexOf('"'+$(targetDom).attr('id')+'"')<0){ // return; // } // var pattern = new RegExp('sd_src_no_ratelimit:".*?",','gi'); //匹配单个script标签内容的写法 // var matchArr = pattern.exec(sourceUrlScript); // if(matchArr!=null && matchArr.length>0){ // destURL= matchArr[0].replace('sd_src_no_ratelimit:"','').replace('",',''); // } // if(destURL==null ||destURL == undefined){ // pattern = new RegExp('hd_src_no_ratelimit:".*?",','gi'); // var matchArr = pattern.exec(sourceUrlScript); // if(matchArr!=null && matchArr.length>0){ // destURL = matchArr[0].replace('hd_src_no_ratelimit:"','').replace('",',''); // } // } // if(destURL==null ||destURL == undefined){ // pattern = new RegExp('hd_src:".*?",','gi'); // var matchArr = pattern.exec(sourceUrlScript); // if(matchArr!=null && matchArr.length>0){ // destURL = matchArr[0].replace('hd_src:"','').replace('",',''); // } // } // if(destURL==null ||destURL == undefined){ // pattern = new RegExp('sd_src:".*?",','gi'); // var matchArr = pattern.exec(sourceUrlScript); // if(matchArr!=null && matchArr.length>0){ // destURL = matchArr[0].replace('sd_src:"','').replace('",',''); // } // } // if(destURL==null ||destURL == undefined){ // destURL = location.href; // } // //alert("添加事件");出来的链接直接传递到按钮,跳转,Keepvid网站可能需要修改来检测下载资源。 // //客户端同步需要能够直接接受http://www.facebook.com/video/wanglihong.mp4?参数1=0&参数2=0这种地址 // var downloadDiv = keepvid.attachButtonDiv(targetDom, AttachStyleEnum.AttachOuterTopRight, "", destURL,undefined,undefined,'FaceBookVideo_' + $(targetDom).attr('id')); // keepvid.bindEvent(targetDom, downloadDiv); // } //} }, RequestFaceBookDownloadUrl: function(currentUrl){ if (xhr) { //xhr.overrideMimeType("text/html"); xhr.open('GET', currentUrl, true); xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded"); xhr.setRequestHeader("Accept","*/*"); xhr.setRequestHeader("Accept-Language","zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3"); xhr.onreadystatechange = keepvid.handler; xhr.send(); isRequesting = true; } else { //如果不行,就要找别的办法了。 //document.getElementById("content").innerHTML = "can not create XMLHttpRequest"; } }, handler: function(evtXHR){ if (xhr.readyState == 4) { if (xhr.status == 200) { var response = xhr.responseText; requestHtml = xhr.responseText; if(xhr.responseURL.indexOf('facebook.com')>=0){ keepvid.facebookInnerLinkCheck(requestHtml,xhr.responseURL); } } else { console.log('can not cross domain'); //document.getElementById("content").innerHTML = "can not cross domain"; } isRequesting = false; } else { console.log(xhr.readyState); //document.getElementById("content").innerHTML += "
exceute status readyState" + xhr.readyState; } }, facebookInnerLinkCheck:function(response,currentUrl){ //拿着返回值去解析,从里面找出progressive,这里面有各种信息(url,quality,id等) //AnalysisVimeoDownloadLink(response); //从response里面找video_id找出下载地址。 //var parten = new RegExp('/videos\/(\d+)?','gi'); try{ var video_id; var matcharr = currentUrl.match(/videos\/(\S*)/); if(!matcharr||matcharr.length<2){ if(fbVideoId!=undefined && fbVideoId!=null && fbVideoId!=''){ video_id = fbVideoId; } else{ return false; } } else{ video_id = matcharr[1].replace('/',''); } var downloadUrlParten = new RegExp('"videoData":\\[{"is_hds":(false|true),"video_id":"' + video_id + '",.*,"sd_src":.*?,"hd_tag":','gi');//,"sd_src_no_ratelimit":.*? var downloadJsonArr = response.match(downloadUrlParten); var downloadJson; if(downloadJsonArr==null || downloadJsonArr.length<0){ //他们返回有两种不同格式的Json downloadUrlParten= new RegExp('videoData:\\[{is_hds:(false|true),video_id:"' + video_id + '",.*,sd_src:.*?,hd_tag:','gi');//,sd_src_no_ratelimit:.*? downloadJsonArr = response.match(downloadUrlParten); downloadJson = downloadJsonArr[0]; downloadJson = downloadJson.replace(/:/g,'":'); downloadJson = downloadJson.replace(/https":/g,'https:'); downloadJson = downloadJson.replace(/,/g,',"'); downloadJson = '"' + downloadJson; downloadJson = downloadJson.replace('"videoData":[{',''); downloadJson = '{"' + downloadJson; downloadJson = downloadJson.replace(',"hd_tag":','}'); downloadJson = downloadJson.substr(0,downloadJson.indexOf('}')+1); } else{ downloadJson = downloadJsonArr[0]; //去头去尾 downloadJson = downloadJson.replace('"videoData":[',''); downloadJson = downloadJson.replace(',"hd_tag":','}'); downloadJson = downloadJson.substr(0,downloadJson.indexOf('}') + 1); //downloadJson = downloadJson.substr(0,downloadJson.indexOf('}"sve_hd"') + 1); } if(downloadJsonArr==null || downloadJsonArr.length<0){ keepvid.RequestFaceBookDownloadUrl(currentUrl); return false; } var json = JSON.parse(downloadJson); //获取下载地址 var destUrl = json.hd_src_no_ratelimit; if(destUrl==undefined || destUrl== null){ destUrl = json.sd_src_no_ratelimit; } if(destUrl==undefined || destUrl== null){ destUrl = json.hd_src; } if(destUrl==undefined || destUrl== null){ destUrl = json.sd_src; } if(destUrl==undefined || destUrl== null){ destUrl = location.href; } //保存到facebookDom的parent的parent节点 $($(facebookDom).parent().parent()[0]).attr('keepvidHref',destUrl); $($(facebookDom).parent().parent()[0]).attr('video_id',video_id); var downloadDiv = keepvid.attachButtonDiv(facebookDom, AttachStyleEnum.AttachOuterTopRight, "", encodeURIComponent(destUrl),undefined,undefined,'FaceBookVideo_' + video_id); keepvid.bindEvent(facebookDom, downloadDiv); } catch(err){ return false; } return true; }, facebookOutLink: function(targetDom){ var viemoLinkUrl; var videoImage = $(targetDom).find('img'); var createDivId; //alert($(targetDom).attr('id')); if(targetDom.tagName=="A") { //alert("isComming"); var youtubeAElement = $(targetDom).find('img'); var youtubeUrl = $(targetDom).attr('href'); var youtubeAjaxify = $(targetDom).attr('ajaxify'); console.log(youtubeUrl); console.log(youtubeAjaxify); if(youtubeAElement !== undefined && youtubeAElement.length > 0 && youtubeAjaxify !== undefined && youtubeAjaxify.indexOf('/ajax/flash/expand_inline.php')>=0){ var currentUrl = decodeURIComponent(youtubeUrl); //这是针对youtube的分析 if(currentUrl.indexOf("youtube.com")>=0){ currentUrl = currentUrl.substr(currentUrl.indexOf('u=/')+3); youtubeUrl= 'https://www.youtube.com/'+currentUrl; //alert($(targetDom).parent()[0].id); if($(targetDom).parent().parent()[0] !== null && $(targetDom).parent().parent()[0]!== undefined){ //将分析出来的url和我们创建的div的id保存,后面检查到iframe时直接根据id去展示按钮 $($(targetDom).parent().parent()[0]).attr('keepvidHref',youtubeUrl); createDivId = 'downloadUrl_'+ $(targetDom).parent()[0].id; $($(targetDom).parent().parent()[0]).attr('downloadButtonId',createDivId); } } //这是针对其他网站你的分析,url带有video的就认为是视频 else if(currentUrl.indexOf("/video") >= 0 || currentUrl.indexOf("vine.co")){ $($(targetDom).parent().parent()[0]).attr('keepvidHref',youtubeUrl); createDivId = 'downloadUrl_'+ $(targetDom).parent()[0].id; $($(targetDom).parent().parent()[0]).attr('downloadButtonId',createDivId); } else{ return; } //如果是CNN网站的 //else if(currentUrl.indexOf("www.cnn.com/video")>=0){ // if($(targetDom).parent().parent()[0] !== null && $(targetDom).parent().parent()[0]!== undefined){ // $($(targetDom).parent().parent()[0]).attr('keepvidHref',youtubeUrl); // createDivId = 'downloadUrl_'+ $(targetDom).parent()[0].id; // $($(targetDom).parent().parent()[0]).attr('downloadButtonId',createDivId); // } //} //alert("添加事件");出来的链接直接传递到按钮,跳转,Keepvid网站可能需要修改来检测下载资源。 //客户端同步需要能够直接接受http://www.facebook.com/video/wanglihong.mp4?参数1=0&参数2=0这种地址 var downloadDiv = keepvid.attachButtonDiv(targetDom, AttachStyleEnum.AttachOuterTopRight, "", decodeURIComponent(youtubeUrl),createDivId); //计算按钮显示位置,facebook分享的youtube有点不一样 var width = parseInt($($(targetDom).parent().parent().parent().parent().parent()[0]).css("width")); var left =$($(targetDom).parent().parent().parent().parent().parent()[0]).offset().left + width- parseInt($(downloadDiv).css('width')); $(downloadDiv).css('left',left+'px'); $($(targetDom).parent().parent()[0]).attr('downloadButtonleft',$(downloadDiv).css('left')); $($(targetDom).parent().parent()[0]).attr('downloadButtontop',$(downloadDiv).css('top')); keepvid.bindEvent(targetDom, downloadDiv); } } //这是其他网站的分析 else{ if(location.href.indexOf("facebook.com")>=0 && videoImage !== null && videoImage !== undefined && videoImage.length>0){ var aLink = $(targetDom).parent(); var href = $(aLink[0]).attr('href'); var ajaxify = $(aLink).attr('ajaxify'); if(ajaxify !== undefined && ajaxify.indexOf('/ajax/flash/expand_inline.php')>=0){ if(href.indexOf('dai.ly')>=0) href = 'http://www.dailymotion.com/video/' + href.substr(href.indexOf('dai.ly/')+7); viemoLinkUrl = href; //console.log($(targetDom).parent().parent()[0].id); if( $($(targetDom).parent().parent().parent()[0]) !== null && $($(targetDom).parent().parent().parent()[0]) !== undefined){ //将分析出来的url和我们创建的div的id保存,后面检查到iframe时直接根据id去展示按钮 $($(targetDom).parent().parent().parent()[0]).attr('keepvidHref',viemoLinkUrl); createDivId = 'downloadUrl_'+ $(targetDom).parent().parent()[0].id; $($(targetDom).parent().parent().parent()[0]).attr('downloadButtonId',createDivId); } //alert("添加事件");出来的链接直接传递到按钮,跳转,Keepvid网站可能需要修改来检测下载资源。 //客户端同步需要能够直接接受http://www.facebook.com/video/wanglihong.mp4?参数1=0&参数2=0这种地址 var otherLinkDownloadDiv = keepvid.attachButtonDiv(targetDom, AttachStyleEnum.AttachOuterTopRight, "", viemoLinkUrl,createDivId); $($(targetDom).parent().parent().parent()[0]).attr('downloadButtonleft',$(otherLinkDownloadDiv).css('left')); $($(targetDom).parent().parent().parent()[0]).attr('downloadButtontop',$(otherLinkDownloadDiv).css('top')); keepvid.bindEvent(targetDom, otherLinkDownloadDiv); } else if((ajaxify === undefined || ajaxify===null) && href !== undefined && (href.indexOf('soundcloud.com')>=0 || href.indexOf('mixcloud.com')>=0 || href.indexOf('/video')>0)){ var musicLinkDownloadDiv = keepvid.attachButtonDiv(targetDom, AttachStyleEnum.AttachOuterTopRight, "", href); keepvid.bindEvent(targetDom, musicLinkDownloadDiv); } } } }, vevo: function() { if (location.href.indexOf("vevo.com") >= 0) { var el = document.getElementById("control-bar"); if (el) { var downloadDiv = keepvid.attachButtonDiv(el, AttachStyleEnum.AttachOuterTopRight, "", location.href); keepvid.bindEvent(el, downloadDiv); } } }, discovery: function() { if (location.href.indexOf("discovery.com") >= 0) { var els = document.getElementsByClassName("overlay"); for (var i = 0; i < els.length; i++) { var downloadDiv = keepvid.attachButtonDiv(els[i], AttachStyleEnum.AttachOuterTopRight, "", location.href); keepvid.bindEvent(els[i], downloadDiv); } } }, liveleak: function() { if (location.href.indexOf("liveleak.com") >= 0) { var el = document.getElementById("wrapper"); if (el) el = el.firstChild; var id = el.id; el = document.getElementById(id + "_jwplayer_display"); if (el) { var downloadDiv = keepvid.attachButtonDiv(el, AttachStyleEnum.AttachOuterTopRight, "", location.href); keepvid.bindEvent(el, downloadDiv); } } }, nbcnews: function() { if (location.href.indexOf("nbcnews.com") >= 0) { var els = document.getElementsByClassName("tpVideoBlocker"); for (var i = 0; i < els.length; i++) { if (els[i].firstChild.tagName.toLowerCase() == "a") { var downloadDiv = keepvid.attachButtonDiv(els[i].firstChild, AttachStyleEnum.AttachOuterTopRight, "", location.href); keepvid.bindEvent(els[i].firstChild, downloadDiv); } }; } }, youtubeButton: function() { var desktopType = document.getElementsByTagName('body')[0].getAttribute('desktopType'); if(desktopType!=undefined && desktopType!=null && desktopType!=''){ return; } if (document.getElementById("KeepVid-Button")) return; var downloadDiv = document.createElement("div"); downloadDiv.id = "KeepVid-Button"; downloadDiv.setAttribute("float", "right"); downloadDiv.style.width = 107 + 'px'; downloadDiv.style.height = 37 + 'px'; downloadDiv.style.margin = 10 + 'px'; downloadDiv.style.backgroundImage = "url()"; downloadDiv.style.cursor = "pointer"; downloadDiv.style.float = "right"; downloadDiv.onclick = function () { var realLink = "http://www.keepvid.app/gopage.php?url=" + location.href + "&from=plugin#downloader"; myWindow1 = window.open(realLink, '_blank', ''); myWindow1.focus(); }; var insertDiv = document.getElementById("player-container-inner"); if(!insertDiv){ insertDiv = document.getElementById("player-container"); if(!insertDiv) return false; var existEl = insertDiv.firstChild; } else{ var existEl = insertDiv.lastChild; } insertDiv.insertBefore(downloadDiv, existEl); }, soundcloudButton: function() { var desktopType = document.getElementsByTagName('body')[0].getAttribute('desktopType'); if(desktopType!=undefined && desktopType!=null && desktopType!=''){ return; } if (document.getElementById("KeepVid-Button")) return; var downloadDiv = document.createElement("div"); downloadDiv.id = "KeepVid-Button"; downloadDiv.style.width = 74 + 'px'; downloadDiv.style.height = 26 + 'px'; downloadDiv.style.backgroundImage = "url()"; downloadDiv.style.cursor = "pointer"; downloadDiv.style.right = "190px"; downloadDiv.style.position = "absolute"; downloadDiv.onclick = function () { var realLink = "http://www.keepvid.app/gopage.php?url=" + location.href + "&from=plugin#downloader"; myWindow1 = window.open(realLink, '_blank', ''); myWindow1.focus(); }; var insertDivArr = document.getElementsByClassName("listenEngagement__footer sc-clearfix"); if(insertDivArr.length>0){ var existEl = insertDivArr[0].firstChild; insertDivArr[0].insertBefore(downloadDiv, existEl); } }, CheckAllWebsiteLink:function(){ var desktopType = document.getElementsByTagName('body')[0].getAttribute('desktopType'); if(desktopType!=undefined && desktopType!=null && desktopType!=''){ return; } //console.log('asdasdas'); var currentLinkUrl; var pattern = new RegExp('watch\?v=.*','gi'); //匹配单个script标签内容的写法 var aLinklist = document.getElementsByTagName('a'); var downloadButton; var currentLength = aLinklist.length; console.log(aLinklist.length); var needAddList = new Array(); var addLinkList = new Array(); var needAddIndex = 0; if(aLinklist== undefined || aLinklist == null || aLinklist.lengtj==0) return; for(var index = 0;index< currentLength; index++){ currentLinkUrl =''; console.log(index+' '+aLinklist.length+' '+currentLength); if(aLinklist[index] == null || aLinklist[index]== undefined) continue; currentLinkUrl = aLinklist[index].getAttribute('href'); //console.log('加载放出来的'+currentLinkUrl); if(currentLinkUrl==null ||currentLinkUrl==undefined) continue; if(currentLinkUrl.indexOf('savefrom.net')>=0){ aLinklist[index].parentNode.removeChild(aLinklist[index]); continue; } if(currentLinkUrl.indexOf('youtube.com')>= 0 && currentLinkUrl.indexOf('watch?v=')>= 0){ //console.log('加载放出来的'+currentLinkUrl); currentLinkUrl = currentLinkUrl.substr(currentLinkUrl.indexOf('watch?v=')); needAddList[needAddIndex] = aLinklist[index]; addLinkList[needAddIndex]= 'https://www.youtube.com/'+ currentLinkUrl; //downloadButton = keepvid.CreateLinkDownloadButton(currentLinkUrl); //aLinklist[index].parentNode.appendChild(downloadButton); } } var decodeUrlstr; var Id; for(var i =0 ;i< needAddList.length;i++){ decodeUrlstr = decodeURIComponent(addLinkList[i]); //console.log('解码:'+decodeUrlstr); if(decodeUrlstr.indexOf('url=')>=0){ decodeUrlstr = decodeUrlstr.substr(decodeUrlstr.indexOf('url=')+4); //console.log('裁剪'+decodeUrlstr); decodeUrlstr = "http://www.keepvid.app/gopage.php?url=" + decodeUrlstr; } else{ decodeUrlstr = "http://www.keepvid.app/gopage.php?url=" + decodeUrlstr; } //console.log('这是看看'+decodeUrlstr); downloadButton = keepvid.CreateLinkDownloadButton(decodeUrlstr); needAddList[i].parentNode.appendChild(downloadButton); } }, CreateLinkDownloadButton:function(currentLinkUrl){ var downloadspan = document.createElement("span"); downloadspan.setAttribute("style", "padding: 0; margin: 0; margin-left: 5px;"); downloadspan.style.cursor = "pointer"; var btnDownload = document.createElement("a"); btnDownload.setAttribute('href', currentLinkUrl); btnDownload.setAttribute('target', '_blank'); btnDownload.setAttribute('style','background-image: url(""); background-repeat: no-repeat; width: 16px; height: 16px; display: inline-block; border: none; text-decoration: none; padding: 0px; position: relative;'); downloadspan.appendChild(btnDownload); return downloadspan; }, kvh_ap: function(obj) { //Create the XMLHttpRequest, cross-browser //Build object for GM_xmlhttpRequest() var gm_xhr = new Object(); gm_xhr.url = obj.params.u; //Set method (obj.method!=undefined) ? gm_xhr.method=obj.method : gm_xhr.method="GET"; if(obj.params.locationonly=="yes") gm_xhr.method="HEAD"; //Set request headers gm_xhr.headers = new Object(); if(obj.params.ua!=undefined) gm_xhr.headers["User-Agent"]=obj.params.ua; if(obj.params.postdata!=undefined) gm_xhr.headers["Content-Type"]="application/x-www-form-urlencoded"; if(obj.params.referer!=undefined) gm_xhr.headers["Referer"]=obj.params.referer; //Set the Request body with postdata if it exists if(obj.params.postdata!=undefined){ gm_xhr.method="POST"; gm_xhr.data = obj.params.postdata; } //Set kvh_data textarea with the response when done if(obj.params.locationonly=="yes"){ gm_xhr.onload = function(response) { var loc=""; try{ loc = response.finalUrl; if(loc=="") loc=response.responseHeaders.match(/Location: ([^\r\n]+)/i)[1]; }catch(ex){ } document.getElementById("kvh_data").innerHTML=loc; } }else{ gm_xhr.onload = function(response) { document.getElementById("kvh_data").innerHTML=response.responseText; } } //Finally run GM_xmlhttpRequest() GM_xmlhttpRequest(gm_xhr); }, main: function() {//找到关注对象,注册mouseover和mouseout事件,写入buttondiv,默认不显示 if (location.href.indexOf("keepvid.") >= 0) { if(!document.location.href.match(/&mode=mp3/i)){ //Inject a variable telling the site that this Userscript is running var el = document.createElement('script'); el.innerHTML='var kvh_ext = true;'; var head = document.head || document.getElementsByTagName('head')[0]; head.insertBefore(el, head.lastChild); //Listen on the kvh_obj textarea for a new request to make setInterval(function(){ try{ if(document.getElementById("kvh_obj").innerHTML.toString()!="~kv"){ //Check if the textarea contains a new request made by js on the site //Define and clean up kvh_obj var kvh_obj = document.getElementById("kvh_obj").innerHTML; kvh_obj = kvh_obj.replace(/</g,"<").replace(/>/g,">").replace(/&/g,"&"); //Parse the JSON paramters (all relevent to the cross-domain request to be made) //Execute the request keepvid.kvh_ap(JSON.parse(kvh_obj)); //Empty the textarea to make it re-useable document.getElementById("kvh_obj").innerHTML="~kv"; } }catch(ex){ } },1); } } else if (location.href.indexOf("youtube") >= 0) { setInterval(keepvid.youtubeButton, 1000); } else if (location.href.indexOf("soundcloud") >= 0) { setInterval(keepvid.soundcloudButton, 1000); } else { //document.addEventListener('onload',keepvid.CheckAllWebsiteLink,false); document.addEventListener("mousemove", keepvid.handleDocumentMouseOverEvent, false); document.addEventListener("mouseover", keepvid.handleDocumentMouseOverEvent, false);//有些mousemove事件没响应,必须mouseover if(location.href.indexOf("facebook.com") >= 0){ return; } videoTags = document.getElementsByTagName("video"); for (var i = 0; i < videoTags.length; i++) { var downloadDiv = keepvid.attachButtonDiv(videoTags[i], AttachStyleEnum.AttachOuterTopRight, "", location.href); keepvid.bindEvent(videoTags[i], downloadDiv); } embedTags = document.getElementsByTagName("embed"); for (var i = 0; i < embedTags.length; i++) { var downloadDiv = keepvid.attachButtonDiv(embedTags[i], AttachStyleEnum.AttachOuterTopRight, "", location.href); keepvid.bindEvent(embedTags[i], downloadDiv); } objectTags = document.getElementsByTagName("object"); for (var i = 0; i < objectTags.length; i++) { var downloadDiv = keepvid.attachButtonDiv(objectTags[i], AttachStyleEnum.AttachOuterTopRight, "", location.href); keepvid.bindEvent(objectTags[i], downloadDiv); } //iFrameTags = document.getElementsByTagName("iframe"); //for (var i = 0; i < iFrameTags.length; i++) { // var downloadDiv = keepvid.attachButtonDiv(iFrameTags[i], AttachStyleEnum.AttachOuterTopRight, "", location.href); // keepvid.bindEvent(iFrameTags[i], downloadDiv); //} } } }; } keepvid.main();