springboot音乐推荐系统-计算机毕业设计源码74962

摘 要

随着信息技术的飞速发展和智能设备的广泛普及,人们越来越依赖于数字音乐平台来满足其音乐需求。然而,传统的音乐推荐系统通常基于用户的显式反馈或历史行为,这可能导致推荐结果与用户期望的音乐存在偏差。为了解决这个问题,我们提出了一种基于小程序的音乐推荐系统。该系统旨在通过分析用户的音乐偏好和行为数据,提供个性化的音乐推荐服务,从而增强用户的音乐体验。

Spring Boot是一个轻量级的Java框架,它简化了Spring应用的初始搭建以及开发过程。通过使用Spring Boot,我们可以快速地构建出稳定、可靠的音乐推荐系统后端服务。同时,微信小程序作为一种轻量级的应用程序,具有无需下载安装、即用即走的特点,非常适合作为音乐推荐系统的前端展示平台。

本系统将采用先进的推荐算法,如协同过滤、内容推荐等,结合用户的音乐播放记录、喜好标签、社交关系等信息,为用户提供精准的音乐推荐。

通过本次设计与实现,我们期望能够为音乐爱好者提供一个高效、个性化的音乐推荐平台,同时推动音乐产业的发展和音乐文化的交流。在接下来的工作中,我们将详细介绍系统的架构设计、功能实现以及性能优化等方面的内容。

关键词:音乐推荐系统;springboot;Java

A Music Recommendation System Based on Mini Programs

Abstract

With the rapid development of information technology and the widespread popularity of smart devices, people are increasingly relying on digital music platforms to meet their music needs. However, traditional music recommendation systems are usually based on explicit feedback or historical behavior from users, which may lead to deviations between the recommendation results and the music that users expect. To address this issue, we propose a music recommendation system based on mini programs. The system aims to provide personalized music recommendation services by analyzing user music preferences and behavioral data, thereby enhancing the user's music experience.

Spring Boot is a lightweight Java framework that simplifies the initial setup and development process of Spring applications. By using Spring Boot, we can quickly build a stable and reliable music recommendation system backend service. At the same time, WeChat mini programs, as a lightweight application, have the characteristics of no need to download and install, and can be used immediately, making them very suitable as a front-end display platform for music recommendation systems.

This system will adopt advanced recommendation algorithms such as collaborative filtering and content recommendation, combined with user music playback records, preference tags, social relationships, and other information, to provide users with accurate music recommendations.

Through this design and implementation, we hope to provide an efficient and personalized music recommendation platform for music enthusiasts, while promoting the development of the music industry and the exchange of music culture. In the following work, we will provide a detailed introduction to the system's architecture design, functional implementation, and performance optimization.

Keywords:Music recommendation system; Springboot; Java

目录

1绪论

1.1 研究背景和意义

1.2 国内外研究现状

1.3 论文组成结构

2开发工具及相关技术介绍

2.1小程序框架以及目录结构介绍

2.2 JAVA技术

2.3  Mysql数据库

2.4 Springboot框架

3系统分析

3.1 可行性分析

3.1.1 技术可行性

3.1.2 经济可行性

3.1.3 操作可行性

3.2 需求分析

3.3 系统操作流程

3.3.1信息添加流程

3.3.2信息删除流程

3.4本章小结

4系统设计

4.1 系统架构设计

4.2 系统功能结构

4.3 数据库设计

4.3.1 概念模型设计

4.4.2 逻辑结构设计

5系统实现

5.1 登录模块的实现

5.2 用户子系统模块的实现

5.2.1 用户首页模块

5.2.2 用户资料修改模块

5.2.3 资讯数据管理模块

5.2.4 在线音乐模块

5.3 管理员子系统模块的实现

5.3.1 管理员主页模块

5.3.2 用户管理模块

5.3.3 音乐类型管理模块

5.3.4 在线音乐管理模块

5.3.5 轮播图模块

6系统测试

6.1 测试目的

6.2 测试用例

6.2.1 登录测试 

6.2.2 音乐资讯管理测试 

6.2.3 音乐资讯测试 

6.3 测试结果

结论

参考文献

致谢

1绪论

1.1 研究背景和意义

在当今数字化时代,音乐已经成为人们日常生活中不可或缺的一部分。随着智能设备和移动互联网的普及,用户对音乐的需求也在不断增长,他们期望能够随时随地享受到符合自己喜好的音乐。因此,音乐推荐系统应运而生,旨在通过分析用户的音乐偏好和行为数据,为他们提供个性化的音乐推荐服务。

基于小程序的音乐推荐系统在这样的背景下应运而生,它结合了小程序轻便、快捷的特点和音乐推荐系统的个性化需求,为用户带来了全新的音乐体验。小程序作为一种新兴的应用程序形态,具有无需下载安装、即用即走的优势,使得用户能够更加便捷地访问和使用音乐推荐系统。而音乐推荐系统则通过智能算法分析用户的音乐偏好和行为数据,为他们推荐符合口味的音乐作品,从而满足用户对个性化音乐的需求。

研究基于小程序的音乐推荐系统不仅具有重要的现实意义,还具有一定的学术价值。从现实意义来看,该系统能够满足用户对个性化音乐的需求,提升他们的音乐体验,同时也有助于推动音乐产业的发展和音乐文化的交流。

综上所述,基于小程序的音乐推荐系统具有广阔的应用前景和重要的研究价值。它不仅能够满足用户对个性化音乐的需求,提升他们的音乐体验,还有助于推动音乐产业的发展和音乐文化的交流。

1.2 国内外研究现状

在国内,随着移动互联网的普及和智能设备的广泛应用,音乐推荐系统已成为各大音乐平台的核心功能之一。一些大型的音乐平台如网易云音乐、QQ音乐等已经拥有庞大的用户群体和丰富的音乐资源,它们提供了音乐播放、歌曲推荐、歌单分享等功能。这些平台通过运用先进的推荐算法,结合用户的音乐偏好和行为数据,为用户提供个性化的音乐推荐服务。同时,随着小程序的发展,一些音乐平台也开始将音乐推荐系统引入小程序,让用户能够更加方便地访问和使用。

在国外,音乐推荐系统的研究也取得了丰硕的成果。许多知名的音乐平台,如Spotify、Apple Music等,都拥有强大的音乐推荐系统。这些系统通过分析用户的音乐偏好、播放历史、社交关系等数据,为用户提供精准的音乐推荐。此外,一些学术机构和研究人员也在积极探索音乐推荐系统的技术和算法,推动该领域的发展。

综上所述,基于小程序的音乐推荐系统在国内外都受到了广泛的关注和研究。随着技术的不断进步和应用场景的不断拓展,相信未来该领域的研究将取得更加丰硕的成果。

1.3 论文组成结构

第一章是绪论,本文章的开头部分,对本题目的研究背景意义和研究现状等一些做文字性的描述。

第二章研究了音乐推荐系统的所采用的开发技术和开发工具。

第三章是系统分析部分,包括系统总体需求描述、功能性角度分析系统需求、非功能性等各个方面分析系统是否可以实现。

第四章是系统设计部分,本文章的重要部分,提供了系统架构的详细设计和一些主要功能模块的设计说明。

第五章是系统的具体实现,介绍系统的各个模块的具体实现。

第六章在前几章的基础上对系统进行测试和运行。

最后对系统进行了认真的总结,以此对未来有一个新的展望。

2开发工具及相关技术介绍

2.1小程序框架以及目录结构介绍

整个小程序框架系统分为两部分:逻辑层视图层。小程序开发框架的目标是通过尽可能简单、高效的方式让开发者可以在微信中开发具有原生 小程序 体验的服务。小程序在视图层与逻辑层间提供了数据传输和事件系统,提供了自己的视图层以及逻辑层框架,让开发者能够专注于数据与逻辑。框架的核心是一个响应的数据绑定系统,可以让数据与视图非常简单地保持同步。在逻辑层做数据修改,在视图层就会做相应的更新。框架提供了一套基础的组件,这些组件自带微信风格的样式以及特殊的逻辑,开发者可以通过组合基础组件,创建出强大的微信小程序 。

2.2 JAVA技术

Java主要采用CORBA技术和安全模型,可以在互联网应用的数据保护。它还提供了对EJB(Enterprise JavaBeans)的全面支持,java servlet API,SSM(java server pages),和XML技术。

JAVA语言功能:

面向对象:面向对象是Java编程语言的标志之一,是一种软件开发方法。最重要的是将所有东西变成对象,然后以某种方式编程。编程时,代码和数据写在每个对象上。 面向对象编程方法的出现使得人们在编程过程中的设计思考和操作变得非常简单,同时也提高了程序的安全性。

跨平台:Java流行的一个关键特性是它的跨平台特性,这使得用Java编程变得容易。您可以用Java编写程序并在其他地方运行它,而无需在编译后更改它。

垃圾回收机制:用来将那些在程序不操作时无用的对象所占用的内存空间释放掉,C ++最被人厌恶的就是因为其不能将在编程的过程中所占用的内存空间进行及时的释放,导致随着编程时间的变长所占用的内存空间越来越多。对于一些编程高手而言,他们会在刚开始编程的时候配置一块内存地址放在堆栈上,然后在不需要的时候会对其进行释放,而一些新手和菜鸟在很多的时候会忘记删除这个内存地址,从而导致程序在运行的过程中会变得十分的不稳定,最终有可能会导致程序崩溃。所以很多C ++的高手在编写程序时往往都会将删除后的指针的值设置为NULL,然后在删除之前确定一个指针的值是否为NULL。

2.3  Mysql数据库

数据库是系统开发过程中不可或缺的一部分。 在WEB应用方面,MySQL AB开发了一个具有很大优势的MySQL关系数据库管理系统。 MySQL可以将数据存储在不同的表中,这非常灵活,并且还可以提高系统在实际应用中的速度。 数据库访问最常用于标准SQL语言,MySQL用于SQL语言,因此它具有高度兼容性。数据库的操作是必不可少的,包括对数据库表的增加、删除、修改、查询等功能。现如今,数据库可以分为关系型数据库和非关系型数据库,Mysql属于关系性数据库,Mysql数据库是一款小型的关系型数据库,它以其自身特点:体积小、速度快、成本低等,Mysql数据库是目前最受欢迎的开源数据库。

在WEB应用技术中, Mysql数据库支持不同的操作系统平台,虽然在不同平台下的安装和配置都不相同,但是差别也不是很大,Mysql在Windows平台下两种安装方式,二进制版和免安装版。安装完Mysql数据库之后,需要启动服务进程,相应的客户端就可以连接数据库,客户端可通过命令行或者图形界面工具登录数据库。

2.4 Springboot框架

Spring框架是Java平台上的一种开源应用框架,提供具有控制反转特性的容器。尽管Spring框架自身对编程模型没有限制,但其在Java应用中的频繁使用让它备受青睐,以至于后来让它作为EJB(EnterpriseJavaBeans)模型的补充,甚至是替补。Spring框架为开发提供了一系列的解决方案,比如利用控制反转的核心特性,并通过依赖注入实现控制反转来实现管理对象生命周期容器化,利用面向切面编程进行声明式的事务管理,整合多种持久化技术管理数据访问,提供大量优秀的Web框架方便开发等等。Spring框架具有控制反转(IOC)特性,IOC旨在方便项目维护和测试,它提供了一种通过Java的反射机制对Java对象进行统一的配置和管理的方法。Spring框架利用容器管理对象的生命周期,容器可以通过扫描XML文件或类上特定Java注解来配置对象,开发者可以通过依赖查找或依赖注入来获得对象。Spring框架具有面向切面编程(AOP)框架,SpringAOP框架基于代理模式,同时运行时可配置;AOP框架主要针对模块之间的交叉关注点进行模块化。Spring框架的AOP框架仅提供基本的AOP特性,虽无法与AspectJ框架相比,但通过与AspectJ的集成,也可以满足基本需求。Spring框架下的事务管理、远程访问等功能均可以通过使用SpringAOP技术实现。Spring的事务管理框架为Java平台带来了一种抽象机制,使本地和全局事务以及嵌套事务能够与保存点一起工作,并且几乎可以在Java平台的任何环境中工作。Spring集成多种事务模板,系统可以通过事务模板、XML或Java注解进行事务配置,并且事务框架集成了消息传递和缓存等功能。Spring的数据访问框架解决了开发人员在应用程序中使用数据库时遇到的常见困难。它不仅对Java:JDBC、iBATS/MyBATIs、Hibernate、Java数据对象(JDO)、ApacheOJB和ApacheCayne等所有流行的数据访问框架中提供支持,同时还可以与Spring的事务管理一起使用,为数据访问提供了灵活的抽象。Spring框架最初是没有打算构建一个自己的WebMVC框架,其开发人员在开发过程中认为现有的StrutsWeb框架的呈现层和请求处理层之间以及请求处理层和模型之间的分离不够,于是创建了SpringMVC。

3系统分析

3.1 可行性分析

在软件开发的过程中,可行性分析是至关重要的,它旨在评估问题的可行性,以便尽可能快地解决,同时也要考虑到不同的解决方案的优势和劣势,以及实施这些方案所带来的经济效益。通过对音乐推荐系统的可行性分析,我们可以从技术、操作和经济三个方面来评估其可行性,从而为其提供有效的支持和保障。

3.1.1 技术可行性

Spring Boot框架以其强大的功能和灵活的扩展性,为构建音乐推荐系统提供了坚实的基础。结合小程序的技术优势,如轻量化、即用即走的特点,使得基于Spring Boot和小程序的音乐推荐系统在技术实现上具有很高的可行性。Spring Boot能够快速搭建稳定的后端服务,同时小程序能够提供流畅的前端体验,二者相结合能够确保音乐推荐系统的高效运行和良好用户体验。此外,Spring Boot丰富的生态系统和成熟的技术社区也为系统的开发和维护提供了有力的支持。因此,从技术角度来看,基于Spring Boot和小程序的音乐推荐系统是完全可行的。

3.1.2 经济可行性

基于Spring Boot和小程序的音乐推荐系统在经济可行性方面表现出显著优势。Spring Boot作为开源框架,具有免费且丰富的资源库,大大降低了开发成本。小程序作为轻量级应用,无需下载安装,减少了用户的使用门槛,从而提高了用户粘性和活跃度,为商家带来更多商业机会。此外,系统的灵活性和可扩展性使得其能够适应不同的商业需求,为企业带来长期的经济效益。综上所述,基于Spring Boot和小程序的音乐推荐系统在经济上具有很高的可行性,不仅能够为企业节省成本,还能创造更多的商业价值。

3.1.3 操作可行性

音乐推荐系统的前台页面简洁易懂,无论是系统管理员还是普通用户,只要电脑连接到网络,就可以轻松访问网站,而且不需要任何操作指导,只要输入正确的URL地址,就可以轻松完成所有的操作。由于无需任何复杂的环境配置,这个系统非常简单,易于操作,因此它是一个非常实用的工具。

3.2 需求分析

为了满足用户的需求,音乐推荐系统将系统划分为两个部分:管理员和普通用户,每个部分都有独特的功能,以便更加便捷地管理信息。此外,系统还具有简单易操作的特点,可以更加精确、全面地实现用户的需求。以下是关于该功能的详细描述:

普通用户模块:

注册登录:提供普通用户注册新账户并进行登录的功能,以便能够访问系统的各项功能和个人信息。

首页:展示推荐的音乐内容和功能入口,包括个性化推荐的音乐、热门歌单、最新音乐等,让用户快速找到自己喜爱的音乐。

音乐资讯:提供音乐相关的新闻和资讯内容,如音乐人访谈、音乐活动等,让用户了解音乐圈的最新动态。

在线音乐:用户可以在线播放音乐,包括搜索、收藏、播放列表等功能,提供优质的音乐体验。

网站公告:系统发布重要的公告信息,如系统更新、活动通知等,确保用户能够及时获取相关信息。

基本信息:用户可以查看和修改个人基本信息,如昵称、头像等。

收藏:用户可以收藏喜欢的音乐或歌单,方便后续查看和播放。

管理员模块:

注册登录:管理员需要通过用户名和密码进行登录,以获取管理后台的访问权限。

后台首页:提供管理员一个概览系统的主要信息和功能入口,包括系统概况、最新通知、待处理事项等内容,方便管理员了解系统的运行情况。

系统用户:管理员可以管理系统中的用户信息,包括普通用户和其他管理员,进行添加、编辑、删除用户等操作,以确保用户信息的完整性和准确性。

音乐类型管理:管理员可以管理系统中的音乐类型,包括添加、编辑、删除音乐类型,以维护音乐类型的准确性和完整性。

在线音乐管理:管理员可以管理系统中的在线音乐,包括添加、编辑、删除音乐,确保音乐信息的准确性和更新性。

轮播图管理:管理员可以管理系统首页的轮播图设置,包括添加、编辑、删除轮播图等操作,以提升系统的用户体验和视觉效果。

通知公告管理:管理员可以发布、编辑、删除系统的通知公告信息,确保信息及时传达给用户。

资源管理:管理员可以管理系统提供的资源信息,包括音乐资讯、分类列表等内容,确保信息的准确性和更新性。

普通用户用例图如下所示。

图3-1 用户用例图

管理员用例图如下所示。

图3-2 管理员用例图

3.3 系统操作流程

3.3.1信息添加流程

音乐推荐系统可以实现快速、准确地收集和处理各种信息,而且在使用过程中,只有在按照指定的界面和指定的参考文献,才能够正确地获取和处理信息,而若信息未能满足预期,就会被退出第一步,并且在第二步中,还会继续检查信息的准确性,以确保最终的结果能够满足预期的目标。

图3-3 信息添加流程图

3.3.2信息删除流程

无论是何种用户角色,只要进入了不正常的系统操作界面,就可以使用不同的信息内容来进行操作。当用户尝试删除系统中的数据时,必须先ACK这些数据是否已经被删除,如果没有,就应该按照图3-4的指示进行操作,以免影响系统的正常运行。

图3-4信息删除流程图

3.4本章小结

本章主要通过对音乐推荐系统的可行性分析、功能需求分析、系统用例分析,确定整个音乐推荐系统要实现的功能。同时也为音乐推荐系统的代码实现和测试提供了标准。

4系统设计

4.1 系统架构设计

当前,B/S架构的数据访问模式已经大大改善:用户只需要打开网站,就能够获取系统的信息,而且,系统会根据用户的需要,自动响应并解决所有的问题。此外,用户还能够查阅服务器的处理结果,从而更好地了解数据的流转情况。音乐推荐系统采用三层结构,即视觉-模拟-决策层。其中,视觉层负责接收来自用户的信息并将其呈现给用户;而模拟层则负责完成与用户有关的任务,包括组织信息、进行流程优化、提升用户体验。决策层则负责协商决策,并确保两层结果的一致性。

系统架构图如下图所示。

图4-1 系统架构图

4.2 系统功能结构

一旦您访问了这款应用,您需要完成一项重大的任务:通过认证,获得相应的权限。一旦您完成了认证,您将可以访问到一些关于您的服务,包括:系统用户、音乐类型管理、在线音乐管理、系统管理、通知公告管理、资源管理等。这个界面非常清晰明了,通过指引您就能轻松地完成各种任务。

系统的功能结构图如下所示。

图4-2 系统功能结构图

4.3 数据库设计

一个优秀的系统必须具备完善的后台数据库,就像建筑物一样,它不是一蹴而就的,而是需要经过精心设计,以确保其稳固可靠。只有将数据库设计得完善,并且考虑到各个方面,才能保证系统的可靠性,避免出现任何问题。

4.3.1 概念模型设计

下面是整个系统中主要的数据库表总E-R实体关系图。

图4-3 系统E-R图

4.4.2 逻辑结构设计

在这一步中,我们将概念转换为实际的数据。由于数据库中包含了大量的信息,我们只展示了一些表格。

表access_token (登陆访问时长)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

token_id

int

10

0

N

Y

临时访问牌ID

2

token

varchar

64

0

Y

N

临时访问牌

3

info

text

65535

0

Y

N

4

maxage

int

10

0

N

N

2

最大寿命:默认2小时

5

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

6

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

7

user_id

int

10

0

N

N

0

用户编号:

表article (文章:用于内容管理系统的文章)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

article_id

mediumint

8

0

N

Y

文章id:[0,8388607]

2

title

varchar

125

0

N

Y

标题:[0,125]用于文章和html的title标签中

3

type

varchar

64

0

N

N

0

文章分类:[0,1000]用来搜索指定类型的文章

4

hits

int

10

0

N

N

0

点击数:[0,1000000000]访问这篇文章的人次

5

praise_len

int

10

0

N

N

0

点赞数

6

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

7

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

8

source

varchar

255

0

Y

N

来源:[0,255]文章的出处

9

url

varchar

255

0

Y

N

来源地址:[0,255]用于跳转到发布该文章的网站

10

tag

varchar

255

0

Y

N

标签:[0,255]用于标注文章所属相关内容,多个标签用空格隔开

11

content

longtext

2147483647

0

Y

N

正文:文章的主体内容

12

img

varchar

255

0

Y

N

封面图

13

description

text

65535

0

Y

N

文章描述

表article_type (文章分类)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

type_id

smallint

5

0

N

Y

分类ID:[0,10000]

2

display

smallint

5

0

N

N

100

显示顺序:[0,1000]决定分类显示的先后顺序

3

name

varchar

16

0

N

N

分类名称:[2,16]

4

father_id

smallint

5

0

N

N

0

上级分类ID:[0,32767]

5

description

varchar

255

0

Y

N

描述:[0,255]描述该分类的作用

6

icon

text

65535

0

Y

N

分类图标:

7

url

varchar

255

0

Y

N

外链地址:[0,255]如果该分类是跳转到其他网站的情况下,就在该URL上设置

8

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

9

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表auth (用户权限管理)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

auth_id

int

10

0

N

Y

授权ID:

2

user_group

varchar

64

0

Y

N

用户组:

3

mod_name

varchar

64

0

Y

N

模块名:

4

table_name

varchar

64

0

Y

N

表名:

5

page_title

varchar

255

0

Y

N

页面标题:

6

path

varchar

255

0

Y

N

路由路径:

7

position

varchar

32

0

Y

N

位置:

8

mode

varchar

32

0

N

N

_blank

跳转方式:

9

add

tinyint

3

0

N

N

1

是否可增加:

10

del

tinyint

3

0

N

N

1

是否可删除:

11

set

tinyint

3

0

N

N

1

是否可修改:

12

get

tinyint

3

0

N

N

1

是否可查看:

13

field_add

text

65535

0

Y

N

添加字段:

14

field_set

text

65535

0

Y

N

修改字段:

15

field_get

text

65535

0

Y

N

查询字段:

16

table_nav_name

varchar

500

0

Y

N

跨表导航名称:

17

table_nav

varchar

500

0

Y

N

跨表导航:

18

option

text

65535

0

Y

N

配置:

19

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

20

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表collect (收藏)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

collect_id

int

10

0

N

Y

收藏ID:

2

user_id

int

10

0

N

N

0

收藏人ID:

3

source_table

varchar

255

0

Y

N

来源表:

4

source_field

varchar

255

0

Y

N

来源字段:

5

source_id

int

10

0

N

N

0

来源ID:

6

title

varchar

255

0

Y

N

标题:

7

img

varchar

255

0

Y

N

封面:

8

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

9

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表comment (评论)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

comment_id

int

10

0

N

Y

评论ID:

2

user_id

int

10

0

N

N

0

评论人ID:

3

reply_to_id

int

10

0

N

N

0

回复评论ID:空为0

4

content

longtext

2147483647

0

Y

N

内容:

5

nickname

varchar

255

0

Y

N

昵称:

6

avatar

varchar

255

0

Y

N

头像地址:[0,255]

7

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

9

source_table

varchar

255

0

Y

N

来源表:

10

source_field

varchar

255

0

Y

N

来源字段:

11

source_id

int

10

0

N

N

0

来源ID:

表hits (用户点击)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

hits_id

int

10

0

N

Y

点赞ID:

2

user_id

int

10

0

N

N

0

点赞人:

3

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

4

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

5

source_table

varchar

255

0

Y

N

来源表:

6

source_field

varchar

255

0

Y

N

来源字段:

7

source_id

int

10

0

N

N

0

来源ID:

表music_genre (音乐类型)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

music_genre_id

int

10

0

N

Y

音乐类型ID

2

music_genre

varchar

64

0

Y

N

音乐类型

3

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

4

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表notice (公告)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

notice_id

mediumint

8

0

N

Y

公告id:

2

title

varchar

125

0

N

N

标题:

3

content

longtext

2147483647

0

Y

N

正文:

4

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

5

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表online_music (在线音乐)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

online_music_id

int

10

0

N

Y

在线音乐ID

2

album_name

varchar

64

0

Y

N

专辑名称

3

music_tags

varchar

64

0

Y

N

音乐标签

4

music_genre

varchar

64

0

Y

N

音乐类型

5

music_name

varchar

64

0

Y

N

音乐名称

6

singer_name

varchar

64

0

Y

N

歌手姓名

7

music_images

varchar

255

0

Y

N

音乐图片

8

release_time

date

10

0

Y

N

发布时间

9

sound_quality_selection

varchar

64

0

Y

N

音质选择

10

music_audio

varchar

255

0

Y

N

音乐音频

11

music_lyrics

text

65535

0

Y

N

音乐歌词

12

hits

int

10

0

N

N

0

点击数

13

praise_len

int

10

0

N

N

0

点赞数

14

recommend

int

10

0

N

N

0

智能推荐

15

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

16

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表praise (点赞)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

praise_id

int

10

0

N

Y

点赞ID:

2

user_id

int

10

0

N

N

0

点赞人:

3

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

4

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

5

source_table

varchar

255

0

Y

N

来源表:

6

source_field

varchar

255

0

Y

N

来源字段:

7

source_id

int

10

0

N

N

0

来源ID:

8

status

bit

1

0

N

N

1

点赞状态:1为点赞,0已取消

表regular_users (普通用户)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

regular_users_id

int

10

0

N

Y

普通用户ID

2

user_name

varchar

64

0

Y

N

用户姓名

3

user_gender

varchar

64

0

Y

N

用户性别

4

contact_phone_number

varchar

16

0

Y

N

联系电话

5

examine_state

varchar

16

0

N

N

已通过

审核状态

6

user_id

int

10

0

N

N

0

用户ID

7

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表slides (轮播图)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

slides_id

int

10

0

N

Y

轮播图ID:

2

title

varchar

64

0

Y

N

标题:

3

content

varchar

255

0

Y

N

内容:

4

url

varchar

255

0

Y

N

链接:

5

img

varchar

255

0

Y

N

轮播图:

6

hits

int

10

0

N

N

0

点击量:

7

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表upload (文件上传)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

upload_id

int

10

0

N

Y

上传ID

2

name

varchar

64

0

Y

N

文件名

3

path

varchar

255

0

Y

N

访问路径

4

file

varchar

255

0

Y

N

文件路径

5

display

varchar

255

0

Y

N

显示顺序

6

father_id

int

10

0

Y

N

0

父级ID

7

dir

varchar

255

0

Y

N

文件夹

8

type

varchar

32

0

Y

N

文件类型

表user (用户账户:用于保存用户登录信息)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

user_id

mediumint

8

0

N

Y

用户ID:[0,8388607]用户获取其他与用户相关的数据

2

state

smallint

5

0

N

N

1

账户状态:[0,10](1可用|2异常|3已冻结|4已注销)

3

user_group

varchar

32

0

Y

N

所在用户组:[0,32767]决定用户身份和权限

4

login_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

上次登录时间:

5

phone

varchar

11

0

Y

N

手机号码:[0,11]用户的手机号码,用于找回密码时或登录时

6

phone_state

smallint

5

0

N

N

0

手机认证:[0,1](0未认证|1审核中|2已认证)

7

username

varchar

16

0

N

N

用户名:[0,16]用户登录时所用的账户名称

8

nickname

varchar

16

0

Y

N

昵称:[0,16]

9

password

varchar

64

0

N

N

密码:[0,32]用户登录所需的密码,由6-16位数字或英文组成

10

email

varchar

64

0

Y

N

邮箱:[0,64]用户的邮箱,用于找回密码时或登录时

11

email_state

smallint

5

0

N

N

0

邮箱认证:[0,1](0未认证|1审核中|2已认证)

12

avatar

varchar

255

0

Y

N

头像地址:[0,255]

13

open_id

varchar

255

0

Y

N

针对获取用户信息字段

14

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

15

vip_level

varchar

255

0

Y

N

会员等级

16

vip_discount

double

11

2

Y

N

0.00

会员折扣

表user_group (用户组:用于用户前端身份和鉴权)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

group_id

mediumint

8

0

N

Y

用户组ID:[0,8388607]

2

display

smallint

5

0

N

N

100

显示顺序:[0,1000]

3

name

varchar

16

0

N

N

名称:[0,16]

4

description

varchar

255

0

Y

N

描述:[0,255]描述该用户组的特点或权限范围

5

source_table

varchar

255

0

Y

N

来源表:

6

source_field

varchar

255

0

Y

N

来源字段:

7

source_id

int

10

0

N

N

0

来源ID:

8

register

smallint

5

0

Y

N

0

注册位置:

9

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

10

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

5系统实现

5.1 登录模块的实现

在登录界面中输入用户名+密码,然后选择相应的角色,点击“登录”按钮,系统会在用户数据库表中匹配用户的帐户,如果用户名+密码正确,则会登录到系统中每个用户的主管理界面,否则会提示相应的信息,如果是忘记了密码,请返回登录界面。

用户登录流程图如下所示。

图5-1 用户登录流程

想要进入系统用户输入准确的姓名和密码,系统才会自动启动,并且会对用户的身份进行检查,若发现身份信息不符合要求,则会自动返回主界面,以便用户可以安全的登录使用。

系统登录界面如下图所示。

图5-2 系统登录界面

登录关键代码如下:

 def Login(self, ctx):

        print("===================登录=====================")

        ret = {

            "error": {

                "code": 70000,

                "message": "账户不存在",

            }

        }

        body = ctx.body

        password = md5hash(body["password"]) or ""

        obj = service_select("user").Get_obj(

            {"username": body["username"]}, {"like": False}

        )

        if obj:

            user_group = service_select("user_group").Get_obj({'name': obj['user_group']}, {"like": False})

            if user_group and user_group['source_table'] != '':

                user_obj = service_select(user_group['source_table']).Get_obj({"user_id": obj['user_id']},                                                                       {"like": False})

                if user_obj['examine_state'] == '未通过':

                    ret = {

                        "error": {

                            "code": 70000,

                            "message": "账户未通过审核",

                        }

                    }

                    return ret

                if user_obj['examine_state'] == '未审核':

                    ret = {

                        "error": {

                            "code": 70000,

                            "message": "账户未审核",

                        }

                    }

                    return ret

            if obj["state"] == 1:

                if obj["password"] == password:

                    timeout = timezone.now()

                    timestamp = int(time.mktime(timeout.timetuple())) * 1000

                    token = md5hash(str(obj["user_id"]) + "_" + str(timestamp))

                    ctx.request.session[token] = obj["user_id"]

                    service_select("access_token").Add(

                        {"token": token, "user_id": obj["user_id"]}

                    )

                    obj["token"] = token

                    ret = {

                        "result": {"obj": obj}

                    }

                else:

                    ret = {

                        "error": {

                            "code": 70000,

                            "message": "密码错误",

                        }

                    }

            else:

                ret = {

                    "error": {

                        "code": 70000,

                        "message": "用户账户不可用,请联系管理员",

                    }

                }

        return ctx.response(json.dumps(ret, ensure_ascii=False))

5.2 用户子系统模块的实现

5.2.1 用户首页模块

通过输入地址,用户可以轻松访问音乐推荐系统的首页,该首页由top、left、down和center四个部分组成,用户可以通过@ include来进一步了解该网站的内容。

首页载入流程图如下所示。

图5-3 首页载入流程

首页载入流程:系统首先连接数据库,调整显示界面参数,从中提取出数据表,使用html格式创建显示模板,根据添加时间顺序排列数据,并以模板指定的位置显示出来,然后重新调整显示界面,最后断开数据库的连接。

首页如下图所示。

图5-4 首页界面

5.2.2 用户资料修改模块

当您完成/注册操作,您就能够更新您的个人资料。您需要确保您的inputname值能够和您所属的实体类型的参数完全对应。当您更新您的个人资料时,您的账号密码应当保持完整,不能出现任何错误。您需要确保您的账号密码是唯一的,才能继续使用。

用户资料修改流程图如下所示。

图5-5 用户资料修改

密码修改如下图所示。

图5-6密码修改界面

5.2.3 资讯数据管理模块

管理员可以使用Springboot技术来查询资讯数据,这样他们就可以根据自己的需求,快速地更新和维护这些信息。在访问过程中,用户可以根据自己的偏好,自由地选择要修改或删除的信息,而且,如果用户选中的信息超出了预定的范围,系统将会弹出一个窗口,提醒用户只能选择一条数据,而如果用户没有选中,系统将会弹出一个窗口,要求用户重新选择一条新的信息。当用户选择进行更改时,系统会根据用户的id进行查询,并将结果返回到更新页面。用户可以在更新页面中更新刚刚选择的信息。用户点击确认后,from表单会将更新的数据提交到系统,并保存到数据库中。这意味着,如果提交的数据在数据库中,用户可以进行更新,否则将被保存。

音乐资讯添加流程图如下所示。

图5-7 音乐资讯添加流程图

音乐资讯展示界面如下图所示。

图5-8 音乐资讯界面

音乐资讯关键代码如下:

WSGI_APPLICATION = "app.wsgi.application"

DATABASES = {

    "default": {

        "ENGINE": "django.db.backends.mysql",

        "NAME": "project93355",

        "USER": "root",

        "PASSWORD": "root",

        "HOST": "127.0.0.1",

        "PORT": "3306",

    }

}

5.2.4 在线音乐模块

管理员管理在线音乐,用户点击想要观看的歌曲进入在线音乐界面,浏览器自动播放该歌曲,在线音乐通过调用Vue的<video>分类,将在线音乐文件路径参数传入,完成在线音乐,实现的歌曲播放。

在线音乐流程图如下图所示。

图5-9 在线音乐流程图

在线音乐界面如下图所示。

图5-10在线音乐界面

5.3 管理员子系统模块的实现

5.3.1 管理员主页模块

当您注册并使用该账号时,您将会进入一个新的网站。该网站的首部分为top、left、center三个部分,其中@ include部分提供了一个详细的概述。该部分将会提供您的个人资料,例如您的账号、当前时间、当前使用的浏览器版本、服务器的端口数、您的授权、您的ip地址、您的操作系统类型、您的编程语言、您的编程人员、您的编程老师以及您的编程时间。left区域被设计成一个完整的系统菜单,它由1级、2级两个层次组成,通过jquery将1级的功能扩充到2级。

管理员功能界面如下图所示。

图5-11管理员功能界面

5.3.2 用户管理模块

通过使用sql语句,用户可以访问yhzhgl中的用户信息,并且可以通过PageManager.getPages (url, 4, sql, request)获取一个ArrayList对象,以便更好地管理和分析用户表。通过for循环,我们可以从ArrayList中提取出所有数据,然后将其转换为键值对,从而在Python页面上进行解析。

用户管理流程图如下所示。

图5-12用户管理流程图

系统用户管理界面如下图所示。

图5-13 系统用户管理界面

系统用户管理关键代码如下:

def Add(self, ctx):

body = ctx.body

unique = self.config.get("unique")

obj = None

if unique:

qy = {}

for i in range(len(unique)):

key = unique[i]

qy[key] = body.get(key)

obj = self.service.Get_obj(qy)

if not obj:

error = self.Add_before(ctx)

if error["code"]:

return {"error": error}

error = self.Events("add_before", ctx, None)

if error["code"]:

return {"error": error}

result = self.service.Add(body, self.config)

if self.service.error:

return {"error": self.service.error}

res = self.Add_after(ctx, result)

if res:

result = res

res = self.Events("add_after", ctx, result)

if res:

result = res

return {"result": result}

else:

return {"error": {"code": 10000, "message": "已存在"}}

5.3.3 音乐类型管理模块

在添加、删除或修改音乐类型时,系统会根据音乐的状态来决定是否允许使用。如果允许,系统会提供相应的链接,以便用户访问。如果不允许,系统将会在后台查询音乐的状态,并决定是否允许使用。当您点击更改链接按钮时,您将会进入一个更改信息的页面。在完成数据填写之后,您将会将其提交到后台,并对数据库中的记录进行更新。

当添加音乐类型时,系统将会弹出一个页面,用户可以根据自己填写的音乐类型来查询编号是否已经存在。一旦填写完成,系统将会将其提交至后台,并调用相应的服务,将其插入到数据库中。

音乐类型添加流程图如下图所示。

图5-14音乐类型添加流程图

音乐类型的界面如所示。

图5-15音乐类型列表界面

图5-16音乐类型添加界面

5.3.4 在线音乐管理模块

对于在线音乐管理,可能涉及到多种方式,如添加、移除、更换和检索。举个例子,如果要添加一个新的在线音乐,可能会从视觉上向系统发出请求,然后系统会根据这些请求来进行处理。如果需要更多,可能会从系统的顶部进行处理,然后再从下一个系统中进行检索。

在线音乐管理的流程如所示。

图5-17在线音乐管理流程

在线音乐管理界面如所示。

图5-18在线音乐列表界面

图5-19在线音乐添加表界面

5.3.5 轮播图模块

在使用这个应用程序之前,您必须确保您的文章已经被录入了相应的管理功能。如果您想更新文章的内容,您只有在文章的状态被确认为允许更新的条件下,您才有权利更新文章。如果您想更新文章,您只有在您点击更新文章的链接之前,文章的状态将被检测并确认。当您点击更换链接的按钮,您将进入一个更换信息的页面,在完成更换之前,您需要将所有的数据都输入至系统,以便进行更加精确的统计和分析。

当您添加轮播图时,系统将会弹出一个页面,用户可以根据自己填写的轮播图标题来查询轮播图是否已经存在。一旦完成了数据填写,系统将会调用相应的服务,将其插入到数据库中。

轮播图流程图如下图所示。

图5-20轮播图流程图

轮播图的界面如所示。

图5-21轮播图界面

6系统测试

6.1 测试目的

在这款产品正式投入使用之前,试用是至关重要的一步。即使某些部分的开发没有出现任何问题,将多个模块组合在一起仍然可能会出现矛盾。就像每个人都有自己的特点,但如果混杂在一起,就会显得凌乱不堪,因此必须确保彼此之间能够达成默契的配合。在测试中,应该仔细检查其中的每一项内容,以确保它们符合预期的标准。如果发现有一些偏离,应该及时进行调整,以确保最终的结果能够达到预期的目标。

6.2 测试用例

6.2.1 登录测试 

登录测试用例如下表所示。

表6-1 登录测试用例

6.2.2 音乐资讯管理测试 

音乐资讯测试用例如下表所示。

表6-3 添加音乐资讯测试用例

6.2.3 音乐资讯测试 

音乐测试用例如下表所示。

表6-4 添加音乐测试用例

6.3 测试结果

经过测试,得到测试结果如下表所示。

表6-5 测试结果

结论

音乐推荐系统的设计,通过互联网来解决实现信息化的网站系统,通过我四年所学的所有专业知识整合一起,进行对音乐推荐系统进行开发设计,当然在真正着手来做的时候遇到了很多问题,一个是网站的技术问题,一个是自己之前没有单独开发过程序,动手实践比较少,面对问题的同时,自己的自信心也受到了一些打击,不过我也是快速的调整自己的状态,老师与同学讨论的方法解决了所有的困难。

毕业设计是我们所学知识应用的最佳体现,也是在考核我们四年中所学的所有的专业知识及技术应用情况,通过这样毕业设计可以更好的得到锻炼及对所学知识的复习及运用,也是一种训练和实践。音乐推荐系统的实现,不仅巩固了我以前的知识,还对学到的知识通过结合技术进行详细了解,还结合了对跨学科效果的深入理解。

在以后我的工作中,我仍然继续努力我的计算机方面的技术,让我在后期的平台开发中可以更好更快的实现需求功能。我相信自己可以胜任更多的好工作并在工作领域做出更大的贡献。

回顾毕业设计的整个过程,既付出了努力与汗水也收获了很多难以忘怀的美好经历。虽然在系统开发过程中经历了各种各样的困难,自己也在不断研究探索,可是系统的实现仍有许多不足之处。但是经过系统编程工作让我有了更多的信心,我相信在未来的路上,我会走的更好。

参考文献

[1]李津.基于知识图谱的个性化音乐推荐系统设计与实现[J].科学技术创新,2024,(02):127-130.

[2]S.R. R ,A.H. W ,S.M.T. M , et al.Quantifying aquifer interaction using numerical groundwater flow model evaluated by environmental water tracer data: Application to the data-scarce area of the Bandung groundwater basin, West Java, Indonesia[J].Journal of Hydrology: Regional Studies,2023,50

[3]Migallón V ,Penadés J .A Java Application for Teaching Graphs in Undergraduate Courses[J].Applied Sciences,2023,13(23):

[4]A D W ,R S ,V M .Landslide Prone Areas Analysis in Bandungan District, Semarang Regency, Central Java, Indonesia[J].IOP Conference Series: Earth and Environmental Science,2023,1268(1):

[5]Nurhadi B ,Arief M F ,Shofiyatul Q .Analysis of Vegetation Carbon Stock Using Remote Sensing In Penggaron Forest, Central Java Province[J].IOP Conference Series: Earth and Environmental Science,2023,1268(1):

[6]张碧玉.基于知识图增强图神经网络和情感分析的音乐推荐系统[D].南京邮电大学,2023.DOI:10.27251/d.cnki.gnjdc.2023.001401.

[7]郭静菡.面向用户偏好的个性化音乐智能推荐系统[J].自动化技术与应用,2023,42(10):108-112.DOI:10.20033/j.1003-7241.(2023)10-0108-05.

[8]李林,谭澜兰,覃岭.基于语义分析的音乐智能推荐系统的设计与实现[J].电脑知识与技术,2023,19(27):36-39.DOI:10.14004/j.cnki.ckt.2023.1423.

[9]杨帆.基于项目邻域协同过滤的音乐推荐系统实现[J].电声技术,2023,47(09):91-93.DOI:10.16311/j.audioe.2023.09.027.

[10]刘昊.基于深度学习和协同过滤的音乐推荐系统研究[D].吉林建筑大学,2023.DOI:10.27714/d.cnki.gjljs.2023.000421.

[11]马志远.基于改进硬负样本和神经网络的音乐推荐系统[D].阜阳师范大学,2023.DOI:10.27846/d.cnki.gfysf.2023.000203.

[12]毛庆航.基于情感分析的个性化音乐推荐系统的设计与实现[D].曲阜师范大学,2023.DOI:10.27267/d.cnki.gqfsu.2023.000685.

[13]姚勇林.基于深度学习的个性化音乐推荐系统[D].电子科技大学,2023.DOI:10.27005/d.cnki.gdzku.2023.000587.

[14]周峰.基于Spark的混合策略音乐推荐系统的研究与实现[D].南京邮电大学,2022.DOI:10.27251/d.cnki.gnjdc.2022.001529.

[15]潘子月.基于Hadoop和Storm的音乐推荐系统设计[D].南京邮电大学,2021.DOI:10.27251/d.cnki.gnjdc.2021.001670.

[16]王正青.基于图像情感分类的音乐推荐系统的设计与实现[D].东南大学,2022.DOI:10.27014/d.cnki.gdnau.2022.003346.

[17]张利鸽.基于用户兴趣偏好度的音乐智能推荐系统设计分析[J].电子设计工程,2022,30(11):189-193.DOI:10.14022/j.issn1674-6236.2022.11.040.

[18]钱贝贝.基于协同过滤的音乐推荐系统的设计与实现[D].阜阳师范大学,2022.DOI:10.27846/d.cnki.gfysf.2022.000071.

[19]王蕴森.基于情感分析的音乐推荐系统研究[D].中北大学,2022.DOI:10.27470/d.cnki.ghbgc.2022.000097.

[20]郭武承.融合知识图谱和深度学习的音乐推荐系统设计与实现[D].北京邮电大学,2022.DOI:10.26969/d.cnki.gbydu.2022.001307.

致谢

眨眼之间,大学生活就要结束了。在本文的最后,我要感谢我和蔼可亲的导师、团结有爱的同学的帮助和鼓励。此刻,我找不到感谢之词可以用来表达我最深切的感激之情。尤其感谢我的指导老师,在选题的过程中与我进行了深入的交流,在毕业设计期间给我提供了一些指导。四年的学习生活让我受益良多,老师们的丰富的学术知识、认真负责的学习态度让我受益匪浅。在此,我深深地感谢那些曾经给予我帮助和指导的老师!

我们的论文得益于许多学者的贡献,他们的研究成果为我们提供了宝贵的指导,使我们能够更好地完成这篇文章。感谢我的同学和朋友在我的写作以及排版过程中给予热情的帮助,才使得我比较顺利的完成了这篇论文。

感谢大学里遇见的朋友,你们在我这四年里留下无数的温暖和快乐,让我对这个校园多了一份留念。最后,感谢我的父母、辅导员张老师、班长白海鹏,以及室友们对我大学生活上的关心和理解,让我能保持乐观和追求我所热爱的。尽管我的能力有限,但我仍然尽力去完善这篇论文,并且诚挚地希望各位老师和学友能够给予宝贵的指导与意见!

免费领取项目源码,请关注❥点赞收藏并私信博主,谢谢~

  • 18
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值