91无限次观看脚本

解决91观看次数的问题

Versión del día 27/01/2018. Echa un vistazo a la versión más reciente.

// ==UserScript==
// @name         91无限次观看脚本
// @namespace    http://91porn.com/
// @version      0.79
// @description  解决91观看次数的问题
// @author       https://t.me/nrop19

// @include      http://91porn.com
// @include      http://91.91p*.space

// @match        http://*/index.php*
// @match        http://*/v.php*
// @match        http://*/video.php*
// @match        http://*/uvideos.php*
// @match        http://*/view_video.php*

// @grant        GM_xmlhttpRequest
// @grant        GM_addStyle
//
// ==/UserScript==
(function(){let videoListPageStyle=`.video-layer{display:none;color:#fff;font-size:16px;position:fixed;width:100%;height:100%;top:0;left:0;z-index:101}.video-bg{background:rgba(0,0,0,.7)}.video-show{display:flex!important;align-items:center;justify-content:center}.video-layer-close{cursor:pointer;position:absolute;right:5px;top:5px}.video-layer-close img{width:28px}.video-layer .video-content{position:relative;border:2px solid #fff}.video-layer .video-player{display:block;padding:10px 20px}.video-layer .video-player video{min-width:600px;max-height:600px}.video-layer .video-loading{display:none;padding:20px}.video-layer.video-loading .video-player{display:none}.video-layer.video-loading .video-loading{display:block;text-align:center}.video-logo{position:relative;cursor:pointer}.video-logo:hover:after{left:0;top:0;content:"";position:absolute;width:100%;height:100%;background-position:center;background-image:url();background-repeat:no-repeat}img.moduleFeaturedThumb{float:none!important}
`;const videoLayerHTML=`
<div class='video-content video-bg'>
<div class='video-layer-close' title='关闭'><img src=''></div>
<div class='video-player'>
</div>
<div class='video-loading'>
正在读取视频信息。。。
</div>
</div>`;const videoContentHTML=`
<h2>{title}</h2>
<div>
<video controls="controls" autoplay="autoplay">
<source src="{url}" type="video/mp4">
</video>
</div>
<div>视频文件地址: <a href='{url}' target='_blank'>视频文件</a></div>
`;const currentPage=window.location.href.match(/([^/]+)\.php/)[1];const getVideoFail='无法获取到这个视频地址';const videoNotExist='无法获取到这个视频地址\n建议5分钟后再次尝试观看这个视频';function getToken(callback){GM_xmlhttpRequest({method:"GET",url:"http://freeget.vip",onload:function(res){callback(res.response.match(/token" value="([^"]+)/))}})}
function getVideoPage(token,url,callback){console.log('getVideoPage',token,url);url=url.replace('view_video.php','view_video_hd.php');GM_xmlhttpRequest({method:"POST",url:"http://freeget.vip/info",headers:{"Content-Type":"application/x-www-form-urlencoded"},data:"token="+token+"&url="+url,onload:function(res){callback(res.response.match(/http:\/\/.+?ev.php.[^"]+/))}})}
function getVideoUrl(url,cb){console.log('getVideoUrl',url);GM_xmlhttpRequest({method:"GET",url:url,onload:function(res){cb(res.response.match(/http:\/\/.+?mp4[^"]+/))}})}
class VideoLayer{constructor(){if(currentPage==='view_video'){this.videoInfoPage()}else{this.videoListPage()}}
getMp4(url,callback,title){GM_xmlhttpRequest({method:"GET",url:"http://www.jiexiba.tech/api/pron?url="+url,onload:function(res){callback({title,mp4:res.response})}})}
videoInfoPage(){const $video=document.querySelector('#viewvideo-content');this.getMp4(window.location.href,res=>{$video.innerHTML=`<h3 style="text-align: center;">91无限次观看脚本已经生效</h3><video controls="controls" style="width: 100%;max-height: 400px;"><source src="${res.mp4}" type="video/mp4"></video>`})}
videoListPage(){const $videos=document.querySelectorAll('#tab-featured p, #videobox .imagechannelhd, #videobox .imagechannel, div#myvideo-content .videothumb');const callback=result=>{if(!!result.error){this.close();alert(result.error);return}
this.show(result.title,result.mp4)};$videos.forEach($video=>{const $a=$video.querySelector('a');const $img=$a.querySelector('img');let $target;let title;if(currentPage==='index'){videoListPageStyle+='.video-logo{float:left;}';$target=$a;title=$a.nextElementSibling.innerText}else if(currentPage==='uvideos'){$target=$video;title=$video.nextElementSibling.querySelector('a').innerText}else{$target=$video;title=$img.title}
const href=$a.href;$target.title='直接播放视频';$target.className+=' video-logo';$target.onclick=()=>{this.$videoLayer.className+=' video-loading';this.$videoLayer.className+=' video-show';this.getMp4(href,callback,title);return!1}});GM_addStyle(videoListPageStyle);this.$videoLayer=document.createElement('div');this.$videoLayer.className='video-layer';this.$videoLayer.innerHTML=videoLayerHTML;this.$videoTitle=this.$videoLayer.querySelector('h2');this.$videoContent=this.$videoLayer.querySelector('.video-player');this.$videoLayer.querySelector('.video-layer-close').onclick=this.close.bind(this);document.body.appendChild(this.$videoLayer)}
loadVideo(title,url,callback){getVideoPage('',url,url=>{if(!url||!url[0]){callback({error:videoNotExist});return}
getVideoUrl(url[0],mp4=>{if(!url||!url[0]){callback({error:getVideoFail});return}
callback({title:title,mp4:mp4[0]})})})}
close(){this.$videoContent.innerHTML='';this.$videoLayer.className=this.$videoLayer.className.replace(/\s*video-show/g,'')}
show(title,url){let html=videoContentHTML.replace(/\{title\}/g,title);html=html.replace(/\{url\}/g,url);this.$videoContent.innerHTML=html;this.$videoLayer.className=this.$videoLayer.className.replace(/\s*video-loading/g,'')}}
const video=new VideoLayer()})()