Update and rename douyinmusic.js to douyinMusic.js
This commit is contained in:
parent
30f99cd010
commit
c71e4267ff
@ -1,26 +1,24 @@
|
|||||||
/*
|
/*
|
||||||
* @Descripttion:
|
* @version: 1.0.0
|
||||||
* @version:
|
* @author: WangPeng
|
||||||
* @Author: WangPeng
|
* @date: 2023-07-11 16:41:48
|
||||||
* @Date: 2023-07-11 16:41:48
|
* @customEditors: imsyy
|
||||||
* @LastEditors: WangPeng
|
* @lastEditTime: 2023-07-11 16:03:12
|
||||||
* @LastEditTime: 2023-07-11 16:56:12
|
|
||||||
*/
|
|
||||||
/*
|
|
||||||
* @Descripttion:
|
|
||||||
* @version:
|
|
||||||
* @Author: WangPeng
|
|
||||||
* @Date: 2023-07-10 16:56:01
|
|
||||||
* @LastEditors: WangPeng
|
|
||||||
* @LastEditTime: 2023-07-11 16:33:56
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
const Router = require("koa-router");
|
const Router = require("koa-router");
|
||||||
const douyinRouter = new Router();
|
const douyinMusicRouter = new Router();
|
||||||
const axios = require("axios");
|
const axios = require("axios");
|
||||||
const { get, set, del } = require("../utils/cacheData");
|
const { get, set, del } = require("../utils/cacheData");
|
||||||
|
|
||||||
|
// 接口信息
|
||||||
|
const routerInfo = {
|
||||||
|
title: "抖音",
|
||||||
|
subtitle: "热歌榜",
|
||||||
|
};
|
||||||
|
|
||||||
// 缓存键名
|
// 缓存键名
|
||||||
const cacheKey = "douyinData";
|
const cacheKey = "douyinMusicData";
|
||||||
|
|
||||||
// 调用时间
|
// 调用时间
|
||||||
let updateTime = new Date().toISOString();
|
let updateTime = new Date().toISOString();
|
||||||
@ -28,35 +26,56 @@ let updateTime = new Date().toISOString();
|
|||||||
// 调用路径
|
// 调用路径
|
||||||
const url = "https://aweme.snssdk.com/aweme/v1/chart/music/list/";
|
const url = "https://aweme.snssdk.com/aweme/v1/chart/music/list/";
|
||||||
const HEADERS = {
|
const HEADERS = {
|
||||||
'user-agent': 'okhttp3'
|
"user-agent": "okhttp3",
|
||||||
}
|
};
|
||||||
const QUERIES = {
|
const QUERIES = {
|
||||||
'device_platform': 'android',
|
device_platform: "android",
|
||||||
'version_name': '13.2.0',
|
version_name: "13.2.0",
|
||||||
'version_code': '130200',
|
version_code: "130200",
|
||||||
'aid': '1128',
|
aid: "1128",
|
||||||
'chart_id': '6853972723954146568',
|
chart_id: "6853972723954146568",
|
||||||
'count': '100'
|
count: "100",
|
||||||
}
|
};
|
||||||
|
|
||||||
// 数据处理
|
// 数据处理
|
||||||
const getData = (data) => {
|
const getData = (data) => {
|
||||||
if (!data) return [];
|
if (!data) return [];
|
||||||
return data;
|
try {
|
||||||
|
return data.map((v) => {
|
||||||
|
const item = v.music_info;
|
||||||
|
return {
|
||||||
|
id: item.id,
|
||||||
|
title: item.title,
|
||||||
|
album: item.album,
|
||||||
|
artist: item.author,
|
||||||
|
pic: item?.cover_large.url_list[0],
|
||||||
|
lyric: item.lyric_url,
|
||||||
|
url: item.play_url.uri,
|
||||||
|
mobileUrl: item.play_url.uri,
|
||||||
|
// h5Url: item.matched_song?.h5_url,
|
||||||
|
};
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
console.error("数据处理出错" + error);
|
||||||
|
return [];
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// 抖音music热榜
|
// 抖音热歌榜
|
||||||
douyinRouter.get("/douyinmusic", async (ctx) => {
|
douyinMusicRouter.get("/douyinmusic", async (ctx) => {
|
||||||
console.log("获取抖音music热榜");
|
console.log("获取抖音热歌榜");
|
||||||
try {
|
try {
|
||||||
// 从缓存中获取数据
|
// 从缓存中获取数据
|
||||||
let data = await get(cacheKey);
|
let data = await get(cacheKey);
|
||||||
const from = data ? "cache" : "server";
|
const from = data ? "cache" : "server";
|
||||||
if (!data) {
|
if (!data) {
|
||||||
// 如果缓存中不存在数据
|
// 如果缓存中不存在数据
|
||||||
console.log("从服务端重新获取抖音music热榜");
|
console.log("从服务端重新获取抖音热歌榜");
|
||||||
// 从服务器拉取数据
|
// 从服务器拉取数据
|
||||||
const response = await axios.get(url, { headers: HEADERS, params: QUERIES });
|
const response = await axios.get(url, {
|
||||||
|
headers: HEADERS,
|
||||||
|
params: QUERIES,
|
||||||
|
});
|
||||||
console.log(response.data);
|
console.log(response.data);
|
||||||
data = getData(response.data.music_list);
|
data = getData(response.data.music_list);
|
||||||
updateTime = new Date().toISOString();
|
updateTime = new Date().toISOString();
|
||||||
@ -66,8 +85,7 @@ douyinRouter.get("/douyinmusic", async (ctx) => {
|
|||||||
ctx.body = {
|
ctx.body = {
|
||||||
code: 200,
|
code: 200,
|
||||||
message: "获取成功",
|
message: "获取成功",
|
||||||
title: "抖音music",
|
...routerInfo,
|
||||||
subtitle: "热榜",
|
|
||||||
from,
|
from,
|
||||||
total: data.length,
|
total: data.length,
|
||||||
updateTime,
|
updateTime,
|
||||||
@ -77,29 +95,30 @@ douyinRouter.get("/douyinmusic", async (ctx) => {
|
|||||||
console.error(error);
|
console.error(error);
|
||||||
ctx.body = {
|
ctx.body = {
|
||||||
code: 500,
|
code: 500,
|
||||||
title: "抖音music",
|
...routerInfo,
|
||||||
subtitle: "热榜",
|
|
||||||
message: "获取失败",
|
message: "获取失败",
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
// 抖音music热榜 - 获取最新数据
|
// 抖音热歌榜 - 获取最新数据
|
||||||
douyinRouter.get("/douyinmusic/new", async (ctx) => {
|
douyinMusicRouter.get("/douyinmusic/new", async (ctx) => {
|
||||||
console.log("获取抖音music热榜 - 最新数据");
|
console.log("获取抖音热歌榜 - 最新数据");
|
||||||
try {
|
try {
|
||||||
// 从服务器拉取最新数据
|
// 从服务器拉取最新数据
|
||||||
const response = await axios.get(url, { headers: HEADERS, params: QUERIES });
|
const response = await axios.get(url, {
|
||||||
|
headers: HEADERS,
|
||||||
|
params: QUERIES,
|
||||||
|
});
|
||||||
const newData = getData(response.data.word_list);
|
const newData = getData(response.data.word_list);
|
||||||
updateTime = new Date().toISOString();
|
updateTime = new Date().toISOString();
|
||||||
console.log("从服务端重新获取抖音music热榜");
|
console.log("从服务端重新获取抖音热歌榜");
|
||||||
|
|
||||||
// 返回最新数据
|
// 返回最新数据
|
||||||
ctx.body = {
|
ctx.body = {
|
||||||
code: 200,
|
code: 200,
|
||||||
message: "获取成功",
|
message: "获取成功",
|
||||||
title: "抖音music",
|
...routerInfo,
|
||||||
subtitle: "热榜",
|
|
||||||
total: newData.length,
|
total: newData.length,
|
||||||
updateTime,
|
updateTime,
|
||||||
data: newData,
|
data: newData,
|
||||||
@ -117,8 +136,7 @@ douyinRouter.get("/douyinmusic/new", async (ctx) => {
|
|||||||
ctx.body = {
|
ctx.body = {
|
||||||
code: 200,
|
code: 200,
|
||||||
message: "获取成功",
|
message: "获取成功",
|
||||||
title: "抖音music",
|
...routerInfo,
|
||||||
subtitle: "热榜",
|
|
||||||
total: cachedData.length,
|
total: cachedData.length,
|
||||||
updateTime,
|
updateTime,
|
||||||
data: cachedData,
|
data: cachedData,
|
||||||
@ -127,12 +145,12 @@ douyinRouter.get("/douyinmusic/new", async (ctx) => {
|
|||||||
// 如果缓存中也没有数据,则返回错误信息
|
// 如果缓存中也没有数据,则返回错误信息
|
||||||
ctx.body = {
|
ctx.body = {
|
||||||
code: 500,
|
code: 500,
|
||||||
title: "抖音music",
|
...routerInfo,
|
||||||
subtitle: "热榜",
|
|
||||||
message: "获取失败",
|
message: "获取失败",
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
module.exports = douyinRouter;
|
douyinMusicRouter.info = routerInfo;
|
||||||
|
module.exports = douyinMusicRouter;
|
Loading…
Reference in New Issue
Block a user