您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
将当前页面的网址发送到指定的服务器,服务器地址信息需要再代码中修改以适合自己使用!
当前为
此脚本不应直接安装。它是供其他脚本使用的外部库,要使用该库请加入元指令 // @require https://update.greasyfork.icu/scripts/494214/1371699/TKBaseSDK%20Test.js
// ==UserScript== // @name TKBaseSDK Test // @namespace https://github.com/RANSAA // @version 0.0.1 // @description 将当前页面的网址发送到指定的服务器,服务器地址信息需要再代码中修改以适合自己使用! // @author sayaDev // @license MIT License // @icon  // @match http://*/* // @match *://*/* // @require https://update.greasyfork.org/scripts/494214/1371698/TKBaseSDK.js // @grant unsafeWindow // @grant GM_openInTab // @grant GM_xmlhttpRequest // @connect self //添加需要跨域不弹出用户选择页面的标注 // @connect localhost // @connect 127.0.0.1 // @connect * // @compatible chrome // @compatible edge // @compatible firefox // @compatible opera // @compatible safari // @noframes // ==/UserScript== /** * 配置信息,可更具需求更改配置 **/ const SERVER_CONFIG = { host: "127.0.0.1", //服务器地址 port: "80", //服务器端口,直接使用”“不指定端口 method: "POST", //请求方式 scheme: "http", //协议类型 taskAdd: "task/add", //yt-dlp 任务添加API Query Path路劲地址 }; (function() { 'use strict'; TKBaseSDK.initToast(); addSendServerButton(); })(); // -------------------------------Setup UI------------------------------- function addSendServerButton(){ //添加style TKBaseSDK.addButtonStyle(); //每隔button的高为44px //创建Send URL按钮 let sendURL = TKBaseSDK.createItemButton("Send URL","100px"); //定义的是事件被触发后要做的事情 sendURL.addEventListener("click", function() { sendLocationURL(); }); //创建Copy URL按钮 let copyURL = TKBaseSDK.createItemButton("Copy URL","144px"); //定义的是事件被触发后要做的事情 copyURL.addEventListener("click", function() { copyLocationURL(); }); //创建Copy M3u8按钮 let copyM3u8 = TKBaseSDK.createItemButton("Copy M3U8","188px"); //定义的是事件被触发后要做的事情 copyM3u8.addEventListener("click", function() { copyM3u8Link(); }); let list = document.createElement("TKButtonList"); list.appendChild(sendURL); list.appendChild(copyURL); list.appendChild(copyM3u8); document.body.appendChild(list); } // -------------------------------Setup UI------------------------------- // -------------------------------Action------------------------------- /** * 将参数组装成JSON格式 * 获取当前需要的所有属性 * url:当前页面的url地址 * title:当前网页的标题 * four_color_av_m3u8:四色AV中播放页面中的m3u8链接--值为可选 **/ function loadParameterJSON(){ // //示例 // var json = { // jsonrpc:'2.0', // method:'aria2.addUri', // id:url, // params:[ // [url], // ] // } // return JSON.stringify(json) //当前网页地址 let url = window.location.href; //当前网页标题 let title = document.title; //四色AV中的m3u8链接 let four_color_av_m3u8 = getFourColorAVM3u8Url(); let json = { "url": url, "title": title, "four_color_av_m3u8":four_color_av_m3u8 }; return JSON.stringify(json) } /** * 发送数据当前页面的URL到指定服务器 */ function sendLocationURL() { console.log(`Send Server`); //服务器的地址 var serverUrl = SERVER_CONFIG.scheme + "://" + SERVER_CONFIG.host + ":" + SERVER_CONFIG.port + "/" + SERVER_CONFIG.taskAdd if (SERVER_CONFIG.port === "" ) { serverUrl = SERVER_CONFIG.scheme + "://" + SERVER_CONFIG.host + "/" + SERVER_CONFIG.taskAdd } //发送的参数数据 let data = loadParameterJSON(); console.log(`serverUrl: ${serverUrl}`); console.log(`parameter: ${data}`); //GM_xmlhttpRequest方式请求 GM_xmlhttpRequest({ method: SERVER_CONFIG.method, url: serverUrl, headers: { 'Content-Type': 'application/json; charset=utf-8', }, data: data, onload: function(response) { console.log(response); console.log(`readyState:${response.readyState}`); console.log(`status:${response.status}`); console.log(`statusText:${response.statusText}`); console.log(`responseHeaders:\n${response.responseHeaders}`); console.log(`responseText:${response.responseText}`); if (response.status === 200) { console.log(`Send URL Success: ${url}`); TKBaseSDK.showToast("当前URL地址发送成功!",1); } else { console.log(`Send URL Error: ${url} statusText: ${response.statusText}`); TKBaseSDK.showToast("当前URL地址发送失败!",0); } }, onerror: function(response) { // 请求发生错误时执行 console.error("Request failed:", response); let msg = `发送失败,Send Server服务地址:${response.finalUrl}`; console.log(msg); TKBaseSDK.showToastWtihTime(msg, 0, 4000); } }); } /** * 拷贝当前网页地址 **/ function copyLocationURL(){ //当前网页地址 let url = window.location.href; //将magnet复制到剪切板 let transfer = document.createElement('input'); document.body.appendChild(transfer); transfer.value = url; //transfer.focus(); transfer.select(); if (document.execCommand('copy')) { document.execCommand('copy'); } transfer.blur(); document.body.removeChild(transfer); console.log('复制成功'); TKBaseSDK.showToast("复制成功!",1); } /** * 获取并拷贝m3u8链接 **/ function copyM3u8Link(){ let m3u8Url = getFourColorAVM3u8Url(); //将magnet复制到剪切板 let transfer = document.createElement('input'); document.body.appendChild(transfer); transfer.value = m3u8Url; //transfer.focus(); transfer.select(); if (document.execCommand('copy')) { document.execCommand('copy'); } transfer.blur(); console.log('复制成功'); TKBaseSDK.showToast("复制成功",2); document.body.removeChild(transfer); if (m3u8Url === "") { TKBaseSDK.showToast("复制失败,没有找到M3U8链接!",0); }else{ TKBaseSDK.showToast("复制成功!",1); } } /** * 获取四色AV中的m3u8链接地址 **/ function getFourColorAVM3u8Url(){ // Define a regular expression to match the playUrl variable pattern const playUrlPattern = /var playUrl\s*=\s*"([^"]+)"/; // Get all script tags on the page const scripts = Array.from(document.getElementsByTagName('script')); // Look for the script containing the playUrl variable const matchedScript = scripts.find(script => playUrlPattern.test(script.textContent)); var m3u8Url = "" // If found, extract the URL if (matchedScript) { const match = matchedScript.textContent.match(playUrlPattern); m3u8Url = match && match[1]; console.log('m3u8 URL:', m3u8Url); } else { console.warn('m3u8 URL could not be found.'); } return m3u8Url } // -------------------------------Action-------------------------------