Greasy Fork is available in English.

个人视频解析

支持B站、腾讯视频、爱奇艺、优酷、土豆、芒果TV,支持多个解析接口切换,界面简洁,脚本仅限学习,请大家支持正版。

// ==UserScript==
// @name              个人视频解析
// @version           2.13-2023.12.4
// @description       支持B站、腾讯视频、爱奇艺、优酷、土豆、芒果TV,支持多个解析接口切换,界面简洁,脚本仅限学习,请大家支持正版。
// @author            skyseek
// @author       skyseek
// @require           https://cdn.bootcss.com/jquery/3.5.1/jquery.min.js
// @match             *://v.qq.com/x/cover/*
// @match             *://v.qq.com/x/page/*
// @match             *://m.qq.com/*
// @match             *://www.iqiyi.com/v*
// @match             *://m.iqiyi.com/*
// @match             *://v.youku.com/v_show/*
// @match             *://m.youku.com/*
// @match             *://www.mgtv.com/b/*

// @icon         
// @license           GPL License
// @grant             unsafeWindow
// @grant             GM.openInTab
// @grant             GM_getValue
// @grant             GM_setValue
// @grant             GM_xmlhttpRequest
// @grant             GM_registerMenuCommand
// @connect           iqiyi.com
// @connect           mgtv.com
// @namespace https://greasyfork.org/zh-CN/scripts/424086
// ==/UserScript==

;(function () {
  ;('use strict')
  var $ = $ || window.$
  var host = location.host
  var parseInterfaceList = []
  var originalInterfaceList = [
    { name: '线路一', type: '1', url: 'https://jx.playerjy.com/?url=' },
    {
      name: '线路二',
      type: '1',
      url: 'https://www.yemu.xyz/?url='
    },
    {
      name: '线路三',
      type: '1',
      url: 'https://svip.bljiex.cc/?v='
    },
    {
      name: '线路四',
      type: '1',
      url: 'https://jx.xmflv.com/?url='
    },
     {
      name: '线路五',
      type: '1',
      url: 'https://www.yemu.xyz/?url='
    }
  ]
  function innerParse(url) {
    $('#iframe-player').attr('src', url)
  }
  function GMopenInTab(url, open_in_background) {
    if (typeof GM_openInTab === 'function') {
      GM_openInTab(url, open_in_background)
    } else {
      GM.openInTab(url, open_in_background)
    }
  }
  function GMgetValue(name, value) {
    if (typeof GM_getValue === 'function') {
      return GM_getValue(name, value)
    } else {
      return GM.getValue(name, value)
    }
  }
  function GMsetValue(name, value) {
    if (typeof GM_setValue === 'function') {
      GM_setValue(name, value)
    } else {
      GM.setValue(name, value)
    }
  }
  function GMxmlhttpRequest(obj) {
    if (typeof GM_xmlhttpRequest === 'function') {
      GM_xmlhttpRequest(obj)
    } else {
      GM.xmlhttpRequest(obj)
    }
  }
  function css(css) {
    var myStyle = document.createElement('style')
    myStyle.textContent = css
    var doc = document.head || document.documentElement
    doc.appendChild(myStyle)
  }

  var node = ''
  var player_nodes = [
    { url: 'v.qq.com', node: '#player-container' },
    { url: 'www.iqiyi.com', node: '#flashbox' },
    { url: 'v.youku.com', node: '#ykPlayer' },
    { url: 'www.mgtv.com', node: '#mgtv-player-wrap container' }
  ]
  for (var i in player_nodes) {
    if (player_nodes[i].url == host) {
      node = player_nodes[i].node
    }
  }
  var videoPlayer = `<div id='iframe-div' style='width:100%;height:100%;z-index:1000;'><iframe id='iframe-player' frameborder='0' allowfullscreen='true' width='100%' height='100%'></iframe></div>`
  var innerList = []
  var innerlis = ''
  originalInterfaceList.forEach((item, index) => {
    if (item.type == '1') {
      innerList.push(item)
      innerlis += '<li>' + item.name + '</li>'
    }
  })
  parseInterfaceList = innerList

  var left = 0
  var top = 100
  var Position = GMgetValue('Position_' + host)
  if (!!Position) {
    left = Position.left
    top = Position.top
  }
  // add css to the html
  css(`
  .mainc {
      cursor: pointer;
      position: fixed;
      top: ${top}px;
      left: ${left}px;
      z-index: 2147483647;
      font-size: 12px;
      text-align: left;
    }
    .mainc .logo {
       position: absolute;
       right: 0;
       width: 1.5em;
       padding: 5px 2px;
       text-align: center;
       color: #fff;
       cursor: auto;
       user-select: none;
       border-radius: 0 4px 4px 0;
       transform: translate3d(100%, 5%, 0);
       background: rgba(255, 255, 255, .15);
     }
     .mainc:hover{
       .box{
       display:block;
       }
     }
     .box {
      display:none;
       background-color: rgba(0, 0, 0, 0.4);
       position: absolute;
       top: 0;
       left: 17px;
       width: 70px;
     }
     .box .container {
       display: flex;
       flex-direction: column;
     }
     .box .container ul {
       list-style: none;
     }
     .container li {
       font-size: 12px;
       color: #fff;
       text-align: center;
       line-height: 21px;
       width: 60px;
       border-radius: 6px 6px 6px 6px;
       padding: 0 4px;
       margin: 12px 2px;
     }
     .container li:hover {
       /* 背景突出,鼠标变为点击状态 */
       background: rgba(255, 255, 255, 0.2);
       user-select: none;
       cursor: pointer;
     }`)
  $(function () {
    $('ul').on('click', 'li', function () {
      $('ul li').removeClass('add')
      $(this).addClass('add')
    })
  })
  //crearte a new element
  var html = `     <div class="mainc">
      <div class="logo"><a id="m">解析</a></div>
      <div class="box">
        <div class="container">
          <ul>
            ${innerlis}
          </ul>
        </div>
      </div>
    </div>`
  //append the new element to the body
  //add event listener
  $('body').append(html)
  $('.container li').each((index, item) => {
    item.addEventListener('click', () => {
      if ((parseInterfaceList[index].type == '1', '2')) {
        if (document.getElementById('iframe-player') == null) {
          var player = $(node)
          player.empty()
          player.append(videoPlayer)
        }
        innerParse(parseInterfaceList[index].url + location.href)
      } else {
        GMopenInTab(parseInterfaceList[index].url + location.href, false)
      }
    })
  })
})()