💡
原文中文,约3500字,阅读约需9分钟。
📝
内容提要
文章讨论了网易云音乐接口更换后,作者尝试使用QQ音乐的API获取歌曲链接。通过构建请求地址和解析返回的JSON数据,成功获取了歌曲的真实链接。由于跨域问题,作者使用JSONP进行客户端解析,并封装了相关接口。最后,分享了项目的开源代码,并反思了学习JavaScript的过程。
🎯
关键要点
- 网易云音乐接口更换导致旧接口返回403,作者决定使用QQ音乐的API。
- QQ音乐的请求地址和参数包括songmid、filename和guid,构建请求后可获取JSON格式的数据。
- 从返回的数据中提取vkey字段,可以解析出歌曲的真实链接。
- 由于接口请求地址只支持国内,作者尝试使用JavaScript在客户端解析,解决跨域问题。
- 使用JSONP进行跨域请求,封装了getJSONP()接口以配合getMusic()使用。
- 项目已开源,使用ES7的async和await特性,需注意浏览器兼容性。
- 学习JavaScript过程中,作者反思了实战学习的重要性,并分享了个人学习体验。
❓
延伸问答
为什么网易云音乐的接口无法使用?
因为网易云音乐更换了新的接口,旧接口返回403错误。
如何使用QQ音乐的API获取歌曲链接?
通过构建请求地址,使用songmid、filename和guid参数请求QQ音乐的API,解析返回的JSON数据中的vkey字段即可获取真实链接。
跨域请求的问题如何解决?
可以使用JSONP进行跨域请求,因为CORS需要服务器端设置,而JSONP不需要。
项目的开源代码在哪里可以找到?
项目的开源代码可以在作者提供的链接中找到,包含详细注释。
使用async和await特性有什么注意事项?
使用async和await时,调用getMusic()时必须加上await关键字,否则返回的是Promise对象。
作者在学习JavaScript过程中有什么反思?
作者认为实战学习的重要性,解决问题的目的学习比单纯学习更有效。
🏷️
标签
➡️