文章目录
- 背景
- 实现
- track.search
- track.lyrics.get
- 效果
- 存在问题
背景
当你想要扒歌时,第一件事就是如何先拿到一首歌的歌词。当然,你可以去复制粘贴,但是如果可以在网站中直接搜到,那就太棒了。
实现
这里用到了国外的API https://developer.musixmatch.com/documentation。该网站提供了丰富的全球曲库,以及丰富的API,供用户查询。
分免费和付费两个版本,免费版本提供每日2000次的调用量(所有接口),但对于非商业场景已经够用。你首先需要注册一个账号,然后你会获得免费的apikey。
track.search
get请求:https://api.musixmatch.com/ws/1.1/track.search
参数:
apikey
apikey
q_track
歌名包含的字
q_artist
歌手包含的字
请求结果如下:
此时,你会拿到一个搜索结果列表track_list,然后你可以得到一个重要参数:track_id
track.lyrics.get
上一步拿到的track_id将作为这个API的参数,
get请求:https://api.musixmatch.com/ws/1.1/track.lyrics.get
参数:
apikey
apikey
track_id
track唯一标识
返回结果:
歌词是lyrics_body,展示时,你还需要将lyrics_copyright展示,以防止侵权。
效果
存在问题
由于这个api是有域名的,所以本地访问会有CORS限制,所以,你需要做一层代理,例如,假设你用的vite或者webpack,你可以在配置中,增加proxy的设置:
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
// https://vitejs.dev/config/
export default defineConfig({
plugins: [vue()],
server: {
proxy: {
"/api": {
target: "http://api.musixmatch.com",
changeOrigin: true,
rewrite: (path) => path.replace(/^\/api/, ""),
},
},
},
})
我这里将本地的访问都改为/api/ws/1.1/…,这样,就会命中这个代理。
如果是线上项目,你需要给线上配一个代理服务器才能解决这个问题,比如通过ngnix。如果是静态页面,就没有太好的方法了,除非musixmatch提供白名单服务,目前来看并没有。因此我只有本地才会启用这个功能模块,线上我直接隐藏了。
希望能帮助到你😉