吉他初学者学习网站搭建系列(6)——如何根据歌名查歌词

文章目录

背景

当你想要扒歌时,第一件事就是如何先拿到一首歌的歌词。当然,你可以去复制粘贴,但是如果可以在网站中直接搜到,那就太棒了。

实现

这里用到了国外的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的设置:

javascript 复制代码
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提供白名单服务,目前来看并没有。因此我只有本地才会启用这个功能模块,线上我直接隐藏了。

希望能帮助到你😉

相关推荐
知识分享小能手3 分钟前
SQL Server 2019入门学习教程,从入门到精通,SQL Server 2019 触发器 — 语法知识点及使用方法详解(17)
数据库·学习·sqlserver
Xin_z_8 分钟前
Vue3 + Element Plus el-tree 节点点击选中问题修复总结
前端·javascript·vue.js
蒸蒸yyyyzwd11 分钟前
后端知识学习笔记
笔记·学习
自然语12 分钟前
人工智能之数字生命-观察的实现
数据结构·人工智能·学习·算法
linux_cfan14 分钟前
从“线性观看”到“语义检索”:企业级视频知识库播放器选型指南 (2026版)
javascript·学习·音视频·html5
zh_xuan29 分钟前
React Native 原生和RN互相调用以及事件监听
android·javascript·react native
PieroPc31 分钟前
在飞牛 NAS(fnOS)上使用 Docker 部署 FastAPI 应用(这个是从错误学习教程 图是可以的)
学习·docker·fastapi·飞牛nas
yunhuibin35 分钟前
VGGNet网络学习
人工智能·python·深度学习·神经网络·学习
菩提小狗36 分钟前
小迪安全2023-2024|第14天:信息打点-JS架构&框架识别&泄漏提取&API接口枚举&FUZZ爬虫&笔记|web安全|渗透测试|
javascript·安全·架构
Never_Satisfied1 小时前
在JavaScript / HTML中,模板克隆并添加监听的注意事项
前端·javascript·html