您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
解析下载链接
// ==UserScript== // @name 网易云音乐信息快速获取 // @namespace http://tampermonkey.net/ // @version 0.1.8 // @description 解析下载链接 // @author 水煮木头 // @match *://music.163.com/* // @icon  // @grant none // @license MIT // @noframes // ==/UserScript== (function() { 'use strict'; function copy(text) { let txa = document.createElement('textarea'); txa.value = text; document.body.appendChild(txa) txa.select() let res = document.execCommand('copy') document.body.removeChild(txa) console.log('复制成功!'); //alert("复制成功!确认通知后自动暂停音乐"); } function load() { var download_url = ""; var img = ""; var title = ""; var subtitle = ""; var artists = ""; var album = ""; let flag_info = 0; function local_copy(){ copy(download_url + "\n" + img[0].currentSrc + "\n" + title[0].innerText + "\n" + subtitle + "\n" + artists + "\n" + album[0].innerText + "\n"); if (JSON.stringify(subtitle) === '{}') { local_notice(download_url, img[0].currentSrc, artists + " - " + title[0].innerText, album[0].innerText); } else { local_notice(download_url, img[0].currentSrc, artists + " - " + title[0].innerText + "(" + subtitle + ")", album[0].innerText); } } // UI结果显示 function local_notice(music_link, cover_link, filename_no_ext, album) { if (flag_info != 0) { document.getElementById("local_result").remove(); } flag_info++; let dom = document.createElement('p'); dom.id = "local_result"; dom.innerHTML = "累计请求次数:" + flag_info; // dom.style = "max-width: 30%;"; document.getElementById("sp-ac-container").appendChild(dom); dom.appendChild(document.createElement('br')); function copy_name() { copy(filename_no_ext); } let dom2 = document.createElement('a'); dom2.id = "local_result_music"; dom2.href = music_link; dom2.innerText = "音乐链接"; if (music_link == '') { dom2.innerText = "音乐链接:<空>"; } dom2.onclick = copy_name; dom.appendChild(dom2); dom.appendChild(document.createElement('br')); let dom3 = document.createElement('a'); dom3.id = "local_result_cover"; dom3.href = cover_link; dom3.innerText = "封面链接"; dom3.onclick = copy_name; dom.appendChild(dom3); dom.appendChild(document.createElement('br')); let dom4 = document.createElement('p'); dom4.innerText = "专辑:" + album; dom.appendChild(dom4); dom.appendChild(document.createElement('br')); let dom5 = document.createElement('a'); dom5.id = "local_button_recopy"; // dom5.href = cover_link; dom5.innerText = "点这重新复制信息"; dom5.onclick = local_copy; dom.appendChild(dom5); dom.appendChild(document.createElement('br')); let dom6 = document.createElement('a'); dom6.id = "local_button_recopy"; // dom6.href = cover_link; dom6.innerText = "点这复制音乐名"; dom6.onclick = copy_name; dom.appendChild(dom6); } function local_func (){ var temp = document.getElementById("g_iframe").contentWindow; // 进入新的窗口 img = temp.document.getElementsByClassName("j-img"); // 封面 title = temp.document.getElementsByClassName("f-ff2"); // 歌曲名 subtitle = temp.document.getElementsByClassName("subtit"); // 副标题 if (JSON.stringify(subtitle) === '{}') { subtitle = ""; } else { subtitle = subtitle[0].innerText; } var temp2 = temp.document.getElementsByClassName("s-fc4"); // 歌手 + 专辑 var artist = temp2[0].getElementsByClassName("s-fc7"); // 歌手 album = temp2[1].getElementsByClassName("s-fc7"); // 专辑 var play = temp.document.getElementsByClassName("u-btn2"); const event = new MouseEvent('click', { view: window, bubbles: true, cancelable: true }); play[0].dispatchEvent(event); setTimeout(function (){ var tmp=performance.getEntriesByType("resource"); download_url = ""; if (JSON.stringify(tmp) === '{}') { console.log("警告!您未有任何请求资源!"); download_url = ""; } for (var i = tmp.length - 1; i >= 0; i--) { if (tmp[i].initiatorType == "audio") { console.log("下载链接:\n" + tmp[i].name); download_url = tmp[i].name; break; } } if (download_url == "") { console.log("警告!未能成功获取下载链接!请在播放您想要下载的资源后重试!"); } console.log("封面链接:\n" + img[0].currentSrc); console.log("曲名:\n" + title[0].innerText); if (subtitle != "") { console.log("副标题:\n" + subtitle); } artists=artist[0].innerText; for(var i2 = 1, len = artist.length; i2 < len; i2++) { artists = artists + "," + artist[i2].innerText; } console.log("歌手:\n" + artists); console.log("专辑:\n" + album[0].innerText); local_copy(); document.getElementsByClassName("ply")[0].click(); }, 2000); /* ^ | | (n000为n秒,默认为2秒) `------ 修改这里的数值以更改延迟 */ } let Container = document.createElement('div'); Container.id = "sp-ac-container"; Container.style.position="fixed"; Container.style.left="0px"; Container.style.top="20%"; Container.style['z-index']="999999"; let dom = document.createElement('button'); dom.id = "myCustomize"; dom.style = "position:relative;left:0px;top:0px;background-color: darkgray;padding: 5px;margin: 0px 0px 15px 0px;font-size: 13px;border: 1px;box-shadow: 0 0 5px;width: 2em;"; dom.innerHTML = "点击查询"; dom.onclick = local_func; Container.appendChild(dom); document.body.appendChild(Container); } window.onload = load; })();