Greasy Fork

Greasy Fork is available in English.

网页版酷狗音乐下载

网页版酷狗音乐下载,目前仅支持普通音质,可下载vip音乐

当前为 2024-05-22 提交的版本,查看 最新版本

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Greasemonkey 油猴子Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Userscripts ,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         网页版酷狗音乐下载
// @namespace    http://tampermonkey.net/
// @version      1.3
// @description  网页版酷狗音乐下载,目前仅支持普通音质,可下载vip音乐
// @author       Xie
// @match        *://www.kugou.com/**
// @license      使用说明:请看下方描述
// @icon         
// @grant        none
// ==/UserScript==
(function() {
  'use strict';

  if (!('speechSynthesis' in window)) {
    throw alert("对不起,您的浏览器不支持")
  }
  setTimeout(function() {
    var audioElement = document.getElementById('myAudio');
    if (!audioElement) {
      console.log('没用找到音频元素,无法下载')
      return;
    }

// 检查是否存在 id 为 "downloadLink" 的元素,如果存在则删除
    var existingDownloadLink = document.getElementById('downloadLink');
    if (existingDownloadLink) {
      existingDownloadLink.parentNode.removeChild(existingDownloadLink);
    }


    // 创建一个新的div元素
    let floatingDiv = document.createElement("div");
    floatingDiv.innerHTML = `
<div class="xie-floating-div">
  <div id="downloadLink">

  </div>

<style>
  #downloadLink {
    position: fixed;
    bottom: 20px;
    right: 20px;
    padding: 10px 20px;
    color: #fff;
    text-decoration: none;
    border-radius: 5px;
    cursor: pointer;
    z-index: 99999;
    border: 1px solid #fff;
    background-color: #8d332c;
  }

  #downloadLink:hover {
    filter: brightness(1.5); /* 改变亮度以更改整个SVG的颜色 */
    transition: filter 0.3s; /* 添加过渡效果 */
  }
</style>

`;
    document.body.appendChild(floatingDiv);


    // 获得音频下载地址
    var audioSource = audioElement.src;

    // 获取音频文件名
    var nameEle = document.querySelector('#songName');
    if (!nameEle) {
      nameEle = document.querySelector('.audioName');
    }
    var songNameText = (nameEle ? nameEle.textContent : '未知') + '.mp3';

    const downloadLink = document.getElementById("downloadLink");
// 设置 <div> 标签的文本内容
    downloadLink.textContent = "点击下载:" + songNameText;
    console.log("下载地址:", audioSource)
    console.log("文件名称:", songNameText)

    downloadLink.addEventListener('click', function (event) {
      downFile(audioSource, songNameText)
    });

    function downFile(url, name) {
      // 创建一个 XMLHttpRequest 对象
      var xhr = new XMLHttpRequest();

      // 监听 XMLHttpRequest 的 readyState 属性的变化
      xhr.onreadystatechange = function () {
        // 当 readyState 变为 4 且状态码为 200 时表示请求成功
        if (xhr.readyState === 4 && xhr.status === 200) {
          // 获取服务器响应的数据
          var responseData = xhr.response;

          // 创建一个新的 <a> 标签用于下载
          var aEle = document.createElement('a');
          aEle.href = window.URL.createObjectURL(responseData);
          aEle.download = name; // 设置文件名
          document.body.appendChild(aEle);

          // 触发点击事件,开始下载文件
          aEle.click();

          // 下载完成后移除链接元素
          document.body.removeChild(aEle);
        }
      };

      // 发送 HTTP GET 请求
      xhr.open('GET', url, true);
      xhr.responseType = 'blob'; // 设置响应类型为 blob
      xhr.send();
    }

  }, 2000);
})();