python 建站需求_玩转Django2.0---Django笔记建站基础十一(一)(音乐网站开发)

第十一章  音乐网站开发

本章以音乐网站项目为例,介绍Django在实际项目开发中的应用,该网站共分为6个功能模块分别是:网站首页、歌曲排行榜、歌曲播放、歌曲点评、歌曲搜索和用户管理。

11.1  网站需求与设计

当我们接到一个项目的时候,首先需要了解项目的具体需求,根据需求类型划分网站功能,并了解每个需求的业务流程。本节以音乐网站为例进行介绍,整个网站的功能分为:网站首页、歌曲排行榜、歌曲播放、歌曲搜索、歌曲点评和用户管理,各个功能说明如下:

1、网站首页是整个网站的主界面,主要显示网站最新的动态信息以及网站的功能导航。网站动态信息以歌曲的动态为主,如热门下载、热门搜索和新歌推荐等;网站的功能导航时将其他页面的链接展示在首页上,方便用户访问浏览。

2、歌曲排行榜是按照歌曲的播放量进行排序,用户还可以根据歌曲类型进行自定义筛选。

3、歌曲播放是为用户提供在线试听功能,此外还提供歌曲下载、歌曲点评和相关歌曲推荐。

4、歌曲点评是通过歌曲播放页面进入的,每条点评信息包含用户名、点评内容和点评时间。

5、歌曲搜索是根据用户提供的关键字进行歌曲或歌手匹配查询的,搜索结果以数据列表显示在网页上。

6、用户管理分为用户注册、登录和用户中心。用户中心包含用户信息、登录注销和歌曲播放记录。

我们根据需求对网站的开发进行设计,首先由UI设计师根据网站需求实现网页设计图,然后由前端工程师根据网页设计图实现HTML静态页面,最后由后端工程师根据HTML静态页面实现数据库构建和网站后台开发。根据上述网站需求,一个哦你设计了6个网站页面,其中网站页面,气宗网站首页如图所示:

网站首页

从网站首页的设计图可以看到,按照网站功能可以分为7个功能区,说明如下:

1、歌曲搜索:位于网页顶端,由文本输入框和搜索按钮组成,文本输入框下面是热门搜索的歌曲。

2、轮播图:以歌曲的封面进行轮播,单击图片可进入歌曲播放。

3、音乐分类:位于轮播图的左边,按照歌曲的类型进行分类。

4、热门歌曲:位于轮播图的右边,按照歌曲的播放量进行排序。

5、新歌推荐:按照歌曲的发行时间进行排序。

6、热门搜索:按照歌曲的搜索量进行排序。

7、热门下载:按照歌曲的下载量进行排序。

歌曲排行榜页面如下图:

歌曲排行榜

从歌曲排行榜的设计图可以看到,整个页面分为两部分:歌曲分类和歌曲列表,说明如下:

1、歌曲分类:根据歌曲类型进行歌曲筛选,筛选后的歌曲显示在歌曲列表中。

2、歌曲列表:歌曲信息以播放次数进行降序显示,若对歌曲进行类型筛选,则对同一类型的歌曲以播放次数进行降序显示。

歌曲播放页面如下图:

歌曲播放

从歌曲播放的设计图可以看到,整个页面共有4大功能:各个功能说明如下:

1、歌曲信息:包括歌名、歌手、所属专辑、语种、流派、发行时间、歌词、歌曲封面和歌曲文件等。

2、下载与歌曲点评:实现歌曲下载,每下载一次都会对歌曲的下载次数累加一次。单击"歌曲点评"可进入歌曲点评页面。

3、播放列表:记录当前用户的试听记录,每播放一次都会对歌曲的播放次数累加一次。

4、相关歌曲:根据当前歌曲的类型筛选出同一类型的其他歌曲信息。

如下图:

歌曲点评

歌曲点评主要分为两部分:歌曲点评和点评信息列表,两者说明如下:

1、歌曲点评:由文本输入框和发表按钮组成的表单,以POST的请求形式实现内容提交。

2、点评信息列表:列出当前歌曲的点评信息,并对点评信息设置分页功能。

歌曲搜索页面如下图:

歌曲搜索

歌曲搜索主要根据文本框的内容对歌名或歌手进行匹配查询,然后将搜索结果返回到搜索页面上,其说明如下:

1、若文本框的内容为空,则默认返回前50首最新发行的歌曲。

2、若文本框的内容不为空,则从歌曲的歌名或歌手进行匹配查询,查询结果以歌曲的发现时间进行排序。

3、每次搜索时,若文本框的内容与歌名完全相符,则相符的歌曲将其搜索次数累加一次。

用户中心页面如下图:

用户中心

用户中心需要用户登录后才能访问,该页面主要分为用户基本信息和歌曲播放记录,说明如下:

1、用户基本信息:显示当前用户的用户头像和用户名,并设有用户退出登录链接。

2、歌曲播放记录:播放记录来自于歌曲播放页面的播放列表,并对播放记录进行分页显示。

用户注册和登录页面如下图:

用户的注册和登录是由同一个页面实现两个不同的功能,注册和登录都是通过JavaScript脚本来控制显示的,其说明如下:

1、用户注册:填写用户名、手机号和用户密码,其中用户名和手机号码具有唯一性,而且不能为空。

2、用户登录:根据用户注册时所填写的手机号码或用户名实现用户登录。

11.2  数据库设计

从网站的需求与网站设计可以得知,歌曲信息是整个网站最为核心的数据。因此,设置网站的数据结构时,应以歌曲信息为核心数据,逐步向外扩展相关联的数据信息。

我们将歌曲信息的数据表名为song,歌曲信息不song的数据结构如表所示:

表字段

字段类型

含义

song_id

Int类型,长度为11

主键

song_name

Varchar类型,长度为50

歌曲名称

song_singer

Varchar类型,长度为50

歌曲的演唱歌手

song_time

Varchar类型,长度为10

歌曲的播放时长

song_album

Varchar类型,长度为50

歌曲所属专辑

song_languages

Varchar类型,长度为20

歌曲的语种

song_type

Varchar类型,长度为20

歌曲的风格类型

song_release

Varchar类型,长度为20

歌曲的发行时间

song_img

Varchar类型,长度为20

歌曲封面图片路径

song_lyrics

Varchar类型,长度为50

歌曲的歌词文件路径

song_file

Varchar类型,长度为50

歌曲的文件路径

label_id

Int类型,长度为11

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值