.net几行代码音乐API各排行榜 热搜 入库

对比了几家大厂的音乐API的接口 这家相对规范些

现在开始从零开始 net6敏捷开发对接 入库吧

关键技术工具和思维

  1. 1 json 生成类
  2. 2 分析类 规划表设计
  3. 3 sqlsuger codefirst 生成表
  4. 4 封装get post 连接
  5. 5 类映射automapper
  6. 6 sqlsuger 插入数据

1 json 生成类

宇宙 第 一的编辑器生成 相应的类

cs 复制代码
using miniAPI.Model;

namespace miniAPI.Models
{
    public class QQtoplistDTO
    { 

        public class DataQQtoplistDTO
        {
            public List<Toplist> topList { get; set; }
        }

        public class Toplist
        {
            public DateTime CreateDate { get; set; } 
            public int id { get; set; }
            public int listenCount { get; set; }
            public string picUrl { get; set; }
            public List<TopSonglist> songList { get; set; }
            public string topTitle { get; set; }
            public int type { get; set; }
        }

        //public class Songlist
        //{
        //    public string singername { get; set; }
        //    public string songname { get; set; }
        //}

    }

    public class Outputpara<T>
    {
        private int _code = 500;
        public int code
        {
            get { return _code; }
            set { _code = value; }
        }
        public int subcode { get; set; }
        private string _msg = "";
        public string msg
        {
            get { return _msg; }
            set { _msg = value; }
        }
        public string message { get; set; }
        public int _default { get; set; }
        //public Data data { get; set; }
        public T data { get; set; }
    }

}

2 分析类 规划表设计

排行榜单 维度和songlist的明细

3 codefirst 生成表

sqlsuger 爽得不要不要的

4 封装get post 连接

使用 httpClientFactory

cs 复制代码
 {
 private IHttpClientFactory _httpClientFactory;
        private readonly Cachelper _cachelper;
        private readonly IMapper _mapper;
        public MusicApibyqqController(IMapper mapper, IHttpClientFactory httpClientFactory, Cachelper cachelper)
        {
            _mapper = mapper;
            _httpClientFactory = httpClientFactory;
            _cachelper = cachelper;
        } 

  [HttpGet]
        [Route("createmusicapibyqq")]
        public async Task<string> CreateMusicApibyqqIndex()
        {
 var client = _httpClientFactory.CreateClient();
            var param = new {   };
            string jsonData = System.Text.Json.JsonSerializer.Serialize(param);
            StringContent paramContent = new StringContent(jsonData);

 var logOutResponse = await client.GetAsync(url);
                string resultStr = await logOutResponse.Content.ReadAsStringAsync();
                Outputpara<DataQQtoplistDTO> response = System.Text.Json.JsonSerializer.Deserialize<Outputpara<DataQQtoplistDTO>>(resultStr);
       Console.WriteLine($"url:{url},  成功");
                }
                else
                {
                    Console.WriteLine($"url:{url}, 失败");
                }
            }; 
            return "同步完毕 toplist:" + listToplist.Count+ " TopSonglist:"+ listTopSonglist.Count;
}

5 类映射automapper

cs 复制代码
using AutoMapper;
using miniAPI.Model;
using static miniAPI.Models.QQtoplistDTO;

namespace miniAPI.Config
{
    /// <summary>
    /// Dto的映射配置
    /// </summary>
    public class AutoMapperConfigs : Profile
    {
        public AutoMapperConfigs()
        {
            //从 Toplist=》 TopMusiclist
            CreateMap<Toplist, TopMusiclist>(); 
        }
    }
}

注册

cs 复制代码
//Automapper映射
builder.Services.AddAutoMapper(typeof(AutoMapperConfigs));

映射 使用

_mapper.Map(temptoplist, tempTopMusiclist);

6 插入数据

cs 复制代码
 foreach (var temptoplist in response?.data?.topList)
                    { 
                        TopMusiclist tempTopMusiclist = new TopMusiclist(); 
                        _mapper.Map(temptoplist, tempTopMusiclist);
                        tempTopMusiclist.CreateDate = DateTime.Now;
                        tempTopMusiclist.codeid = temptoplist.id;
                        listToplist.Add(tempTopMusiclist);
                        foreach (var tempsongList in temptoplist.songList)
                        {
                            tempsongList.codeid=temptoplist.id; 
                            listTopSonglist.Add(tempsongList);
                        } 
                    } 
                    SqlSugarHelper.addtoplist(listToplist);
                    SqlSugarHelper.addtopSonglist(listTopSonglist); 
cs 复制代码
    Db.Insertable(listToplist).ExecuteCommand();

开始使用数据吧 据说API不能商用 QAQ 但放出来干啥QAQ

相关推荐
每日出拳老爷子3 小时前
[WinForms] 如何为 .NET Framework 4.8 窗体程序添加自定义图标
visualstudio·c#·.net
Yan90183 小时前
.net解析雷达拼图3.0组合反射率产品,并按经纬度裁剪绘制组合反射率图
.net
步、步、为营3 小时前
.net服务器Kestrel配置Nginx作为反向代理
服务器·nginx·.net
专注VB编程开发20年3 小时前
各版本操作系统对.NET支持情况(250707更新)
开发语言·前端·ide·vscode·.net
小Lu的开源日常4 小时前
AI模型太多太乱?用 OpenRouter,一个接口全搞定!
人工智能·llm·api
wtsolutions5 小时前
Excel to JSON API by WTSolution Documentation
json·excel·api·wtsolutions
界面开发小八哥6 小时前
界面组件DevExpress WPF中文教程:Grid - 如何检查节点?
ui·.net·wpf·界面控件·devexpress·ui开发
我是唐青枫11 小时前
C#.NET serilog 详解
开发语言·c#·.net
Dolphin_海豚1 天前
electron windows 无边框窗口最大化时的隐藏边框问题
前端·electron·api
深盾科技1 天前
.NET nupkg包的深度解析与安全防护指南
.net