您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
将当前页面的网址发送到指定的服务器,服务器地址信息需要再代码中修改以适合自己使用!
- // ==UserScript==
- // @name Post Action
- // @namespace https://github.com/RANSAA
- // @version 0.0.6
- // @description 将当前页面的网址发送到指定的服务器,服务器地址信息需要再代码中修改以适合自己使用!
- // @author sayaDev
- // @license MIT License
- // @icon 
- // @match http://*/*
- // @match *://*/*
- // @require https://update.greasyfork.org/scripts/494214/1432041/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==
- /**
- * 目前支持的参数:
- * url: 当前页面网址
- * title:当前页面标题
- * four_color_av_m3u8:四色AV中的m3u8视频地址
- **/
- /**
- * 配置信息,可更具需求更改配置
- **/
- const SERVER_CONFIG = {
- host: "127.0.0.1", //服务器地址
- port: "80", //服务器端口,直接使用”“不指定端口
- method: "POST", //请求方式
- scheme: "http", //协议类型
- taskAdd: "task/add", //yt-dlp 任务添加API Query Path路劲地址
- };
- /**
- * 将参数组装成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)
- }
- (function() {
- 'use strict';
- TKBaseSDK.initToast();
- addSendServerButton();
- })();
- // -------------------------------Setup UI-------------------------------
- function addSendServerButton(){
- //添加style
- TKBaseSDK.addButtonStyle();
- //创建Send URL按钮
- let sendURL = TKBaseSDK.createListItemButton("Send URL");
- //定义的是事件被触发后要做的事情
- sendURL.addEventListener("click", function() {
- sendLocationURL();
- });
- //创建Copy URL按钮
- let copyURL = TKBaseSDK.createListItemButton("Copy URL");
- //定义的是事件被触发后要做的事情
- copyURL.addEventListener("click", function() {
- copyLocationURL();
- });
- //创建Copy M3u8按钮
- let copyM3u8 = TKBaseSDK.createListItemButton("Copy M3U8");
- //定义的是事件被触发后要做的事情
- copyM3u8.addEventListener("click", function() {
- copyM3u8Link();
- });
- //创建Copy yt-dlp-n按钮
- let copyYtDlpN = TKBaseSDK.createListItemButton("Copy yt-dlp-n");
- //定义的是事件被触发后要做的事情
- copyYtDlpN.addEventListener("click", function() {
- copyYtDlpM3u8Link();
- });
- //创建Copy yt-dlp按钮
- let copyYtDlp = TKBaseSDK.createListItemButton("Copy yt-dlp");
- //定义的是事件被触发后要做的事情
- copyYtDlp.addEventListener("click", function() {
- copyYtDlpLocationLink();
- });
- //创建Copy Magnet按钮
- let copyMagnet = TKBaseSDK.createListItemButton("Copy Magnet");
- copyMagnet.addEventListener("click", function() {
- copyMagnetLinks();
- });
- let list = document.createElement("TKButtonList");
- list.className = "TKButtonListStyle";
- list.appendChild(sendURL);
- //list.appendChild(copyURL);
- list.appendChild(copyM3u8);
- list.appendChild(copyYtDlpN);
- list.appendChild(copyYtDlp);
- list.appendChild(copyMagnet);
- document.body.appendChild(list);
- }
- // -------------------------------Setup UI-------------------------------
- // -------------------------------Action-------------------------------
- /**
- * 发送数据当前页面的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;
- TKBaseSDK.copyToClipBoard(url);
- TKBaseSDK.showToast("复制成功!",1);
- }
- /**
- * 获取并拷贝m3u8链接
- **/
- function copyM3u8Link(){
- let m3u8Url = getFourColorAVM3u8Url();
- if (m3u8Url === "") {
- TKBaseSDK.showToast("复制失败,没有找到M3U8链接!",0);
- TKBaseSDK.copyToClipBoard("");
- }else{
- TKBaseSDK.showToast("复制成功!",1);
- //拷贝到剪切板
- TKBaseSDK.copyToClipBoard(m3u8Url);
- }
- }
- /**
- * 获取四色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('四色AV站点:m3u8 URL:', m3u8Url);
- } else {
- console.warn('四色AV站点:m3u8 URL could not be found.');
- }
- return m3u8Url
- }
- /**
- * 获取四色AV中视频的标题
- **/
- function getFourColorAVTitle(){
- var title = ""
- // 获取包含 h1 元素的 div.main 元素
- const mainDiv = document.querySelector('.wrap > .main');
- // 确认 main 元素存在
- if (mainDiv) {
- // 在 mainDiv 内查找 h1 元素
- const h1Element = mainDiv.querySelector('h1');
- // 确认 h1 元素存在
- if (h1Element) {
- // 获取 h1 元素的文本内容
- const h1Content = h1Element.textContent.trim();
- console.log('四色AV站点:查找h1 内容为:', h1Content);
- title = h1Content
- } else {
- console.warn('四色AV站点:查找视频标题时未找到 h1 元素!');
- // title = "test---222"
- }
- } else {
- console.warn('四色AV站点:查找视频标题时未找到 .main 元素!');
- // title = "test-333"
- }
- return title
- }
- /**
- * 拷贝四色AV中的标题与m3u8链接,并且组装yt-dlp-n命令
- * 格式: yt-dlp-n "视频标题" "m3u8视频地址"
- **/
- function copyYtDlpM3u8Link(){
- // let m3u8Url = getFourColorAVM3u8Url();
- // let title = getFourColorAVTitle();
- let m3u8Url = filterVideoLink();
- let title = filterVideoTitle();
- if (m3u8Url === "" || title === "") {
- TKBaseSDK.showToast("yt-dlp-n下载命令复制失败,没有找到视频链接!",0);
- TKBaseSDK.copyToClipBoard("");
- }else{
- TKBaseSDK.showToast("yt-dlp-n下载命令复制成功!",1);
- //拷贝到剪切板
- let cmd = "yt-dlp-n " + "\"" + title + "\"" + " \"" + m3u8Url + "\"" + "\n\n";
- TKBaseSDK.copyToClipBoard(cmd);
- }
- }
- /**
- * 过滤获取当前视频指定的名称
- **/
- function filterVideoTitle(){
- //默认获取四色AV中视频的标题
- var title = getFourColorAVTitle();
- //获取当前站点的域名
- let hostname = document.location.hostname
- //当前网站路径
- let pathname = document.location.pathname
- //所有直接以网页标题作为title的域名集合
- const titleSet = new Set([
- "beeg.com",
- ]);
- if (pathname != "/") { //不是网站的主页才可以获取视频的标题
- if ( titleSet.has(hostname) ) {
- title = document.title;
- }
- }
- // 处理文件名中的特殊字符
- title = sanitizeFileName(title);
- return title
- }
- /**
- * 过滤获取视频的指定链接
- **/
- function filterVideoLink(){
- //默认获取四色AV中视频的m3u8链接
- var videoURL = getFourColorAVM3u8Url();
- if (videoURL === "") {
- TKBaseSDK.showToast("没有找到M3U8链接,直接使用当前网页地址作为视频链接!",0);
- videoURL = document.location.href;
- }
- return videoURL
- }
- /**
- * 拷贝当前网页链接, 并组装yt-dlp命令
- * 格式:yt-dlp "网页地址"
- **/
- function copyYtDlpLocationLink(){
- let url = window.location.href;
- TKBaseSDK.showToast("yt-dlp下载命令复制成功!",1);
- //拷贝到剪切板
- let cmd = "yt-dlp " + "\"" + url + "\"" + "\n\n";
- TKBaseSDK.copyToClipBoard(cmd);
- }
- /**
- * 功能:拷贝当前页面的所有magnet磁力链接
- **/
- function copyMagnetLinks(){
- const magnetLinks = getMagnetLinks();
- // 转换成换行分隔的字符串
- const magnetLinksString = magnetLinks.join('\n');
- if (magnetLinksString === "" ) {
- TKBaseSDK.showToast("Copy Mangnet失败,没有找到磁力链接!",0);
- TKBaseSDK.copyToClipBoard("");
- }else{
- TKBaseSDK.showToast("Copy Mangnet成功!",1);
- //拷贝到剪切板
- TKBaseSDK.copyToClipBoard(magnetLinksString);
- }
- }
- /**
- * 获取页面中的所有magnet磁力链接
- **/
- function getMagnetLinks(){
- // 从整个 HTML 文档中提取磁力链接
- const htmlContent = document.documentElement.innerHTML;
- const magnetRegex = /magnet:\?xt=urn:[a-zA-Z0-9:]+/g;
- const magnetLinks = Array.from(new Set(htmlContent.match(magnetRegex) || []));
- console.log(magnetLinks);
- return magnetLinks;
- }
- /**
- * 功能:将字符串中不能作为文件名的字符替换成"_",并且如果存在英文的双引号"替换成英文的单引号'
- * replace(/"/g, '“'); //正则表达式
- * replaceAll('"', '“'); //直接替换函数
- **/
- function sanitizeFileName(filename) {
- //使用正则表达式将"替换成'
- var name = filename;
- name = name.replace(/"/g, "'"); //注意:这儿使用的正则表达式无法将"替换成',然后再调用这个函数的外部直接对字符串操作又可以,不知道是什么原因。所以直接使用replaceAll方法进行替换。
- name = name.replaceAll('"', "'");
- name = name.replaceAll(':', ":");
- name = name.replaceAll('”', "'");
- //将不能作为文件名的字符替换为:_
- name = name.replace(/[:]+/g, '_'); // -osx
- // name = name.replace(/[\/\\:*?"<>|]+/g, '_'); // win
- return name
- }
- /**
- * 功能:将字符串中不能作为路径的字符替换成”_“
- **/
- function sanitizePath(path) {
- return path.replace(/[\/\\:*?"<>|]+/g, '_'); // 替换为单个下划线
- }
- // -------------------------------Action-------------------------------