QQ音乐API整理


由于在网上看过很多音乐API都是一半可以用不是很全,有的API有经过改动,造成无法访问,今天来个大家总结一下QQ音乐的API,可能还不是很全,仅供参考,但亲测可用,数据获取方式用的都是jquery的jsonp形式获取数据,歌词除外:

## 歌曲信息搜索:

var songName='青花瓷';//歌曲或者歌手名字

$.ajax({
          url:"http://s.music.qq.com/fcgi-bin/music_search_new_platform?t=0& n=5&aggr=1&cr=1&loginUin=0& inCharset=GB2312&outCharset=utf-8&notice=0& platform=jqminiframe.json&needNewCode=0&p=1&catZhida=0& remoteplace=sizer.newclient.next_song&w="+songName,
          type:"get",
          // async:false,
          dataType:'jsonp',
          jsonp: "jsonpCallback",
          success: function(data){
            var json=data.data.song;
            root.song=json.list;

          },
          error:function (e) {
            console.log('error');
          }
        });

## 跨域成功后会看到跨域接受到的数据其中有个f属性:

f:"410316|青花瓷 (;)|4558|周杰伦|33021|我很忙|1942555|239|8|1|0|9573872|3836490|320000|0|25541938|26237796|5414428|5617369|0|002qU5aY3Qu24y|0025NhlN2yWrP4|002eFUFm2XYZ7z|0|4009"

f属性中以“|”为分隔符索引为0位置为歌曲id用来获取歌曲和歌词,索引为4位置为albumId获取对应的专辑图片,例子如下:

## 歌曲mp3获取

var id = "410316";
var src = "http://ws.stream.qqmusic.qq.com/"+id+".m4a?fromtag=0";

## 可以直接听到音乐

<audio src="http://ws.stream.qqmusic.qq.com/410316.m4a?fromtag=0"  controls="controls" ></audio>

## 歌曲专辑图片获取,图片尺寸300*300,jpg格式

var albumId="33021";
        var src="http://imgcache.qq.com/music/photo/album_300/"+(albumId%100)+"/300_albumpic_"+albumId+"_0.jpg";

## 歌词获取,这部分比较不同由于获取的数据格式不是json而是xml格式,网上看到的方法是另写一个php进行获取,但我们是写纯前端可以用另一种方法,例子如下:

var id = "410316";
var txt="http://music.qq.com/miniportal/static/lyric/"+id%100+"/"+id+".xml";
var YqlUrl='http://query.yahooapis.com/v1/public/yql?q=select%20*%20from%20xml%20where%20url%3D"'+txt+'"&format=json&diagnostics=true&callback=?'
        $.getJSON(YqlUrl,function(data) {
            console.log(data);//获取的xml数据
        });

## 歌曲排行、新歌推荐信息获取url如下:

// 新歌推荐:http://music.qq.com/musicbox/shop/v3/data/hit/hit_newsong.js
// 歌曲排行:http://music.qq.com/musicbox/shop/v3/data/hit/hit_all.js

## 同样用jquery的jsonp可以很容易获取到,如果要进一步获取这些歌曲信息的歌曲mp3、歌词以及专辑图片方法和上面一样,获取的json数据中就带有id和albumId。

albumId:"139643"
albumLink:"/musicbox/shop/v3/album/43/album_139643.htm"
albumName:"身边的故事"
id:"1913719"
playtime:"268"
singerId:"12770"
singerName:"关喆"
songName:"想你的夜"
type:3
url:"http://stream3.qqmusic.qq.com:0/1913719.wma"
<think>好的,用户想查找与QQ音乐相关的资源或信息,特别是下载使用教程或相关API文档。我需要根据提供的引用内容来整理回答。 首先,引用1提到QQ音乐API的项目地址,使用koa2实现,可能用户需要API的源码或部署方法。引用2说明这是由Rain120开发的开源项目,用于访问QQ音乐资源,比如搜索、播放、下载,这应该能解答API的用途和快速启动方法。引用3提到了歌曲解析API的请求参数,包括api_key和链接,这对具体接口调用有帮助。引用4则是一个Java相关的项目,使用nodejs和koa2,部署到服务器,可能涉及Docker和持续集成,这对开发者来说可能有帮助。 用户的问题分为两部分:下载使用教程和相关API文档。需要将引用中的信息分门别类,整理出教程和API文档的资源。同时,注意引用中的项目地址和说明,可能需要直接给出链接,并说明每个资源的特点,比如开源项目、接口参数等。 另外,需要检查是否有遗漏的信息,比如是否有其他引用内容没被利用。目前四个引用都围绕QQ音乐API,可能没有直接提到官方教程,所以主要依赖这些开源项目的信息。需要指出这些是第三方资源,非官方,但提供了API的实现方法。 最后,生成相关问题时要围绕QQ音乐API的使用、部署、参数等,可能的问题包括如何部署API服务、如何获取API密钥、支持的搜索功能等。</think>### QQ音乐相关资源与API文档整理 #### 1. QQ音乐API开源项目 QQ音乐API是一个第三方开源工具,由开发者Rain120基于Node.js和Koa2框架实现,提供歌曲搜索、播放链接解析、歌词获取等功能[^2][^4]。 - **项目地址**:https://gitcode.com/gh_mirrors/qq/qq-music-api - **功能特点**: - 支持通过API_KEY鉴权调用[^3] - 解析QQ音乐歌曲链接,返回播放地址、歌词、专辑封面等信息 - 提供Docker部署和持续集成支持 #### 2. API快速启动教程 **环境准备**:需安装Node.js、Docker(可选) **接口调用示例**: ```python # 示例:解析歌曲链接 import requests api_key = "YOUR_API_KEY" link = "https://y.qq.com/n/ryqq/songDetail/004Z8Ihr0JIu5s" response = requests.get(f"https://api.example.com/song?api_key={api_key}&link={link}") print(response.json()) # 返回歌曲元数据 ``` #### 3. 下载与使用场景 - **歌曲下载**:通过API获取播放链接后,可结合流媒体下载工具实现(需注意版权限制) - **集成场景**:适用于音乐类App、歌词显示插件、歌单分析工具等[^2] #### 4. 注意事项 - 该项目为非官方接口,稳定性依赖第三方维护[^1] - 需遵守QQ音乐版权政策,禁止商用侵权
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hhzzcc_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值