整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

音乐网站-计算机毕业设计源码+LW文档

音乐网站-计算机毕业设计源码+LW文档

的要求 通过毕业设计来进一步巩固和加强对所学知识和基本技能的训练,促进学生学习能力、调查研究能力、综合分析能力、实践能力和创新能力的培养。本系统需为用户提供实现以下功能:

音乐网站网站包括前台和后台。

前台:

音乐网站为用户提供在线音乐推荐的服务,前台用户注册后,查看和收听需要的音乐。

会员未登录前,浏览系统上的所有音乐信息,查看最新的音乐。通过音乐分类,查看分类对应的音乐。

音乐信息一般包括音乐图片,音乐描述和音乐信息。

会员使用本系统前,进行注册,填写个人信息。

会员通过搜索查找到音乐后,也可以收藏音乐,收听后在线评论。

会员还可以查看音乐网站相关公告。

后台:

系统公告管理

注册会员管理

音乐类别管理

音乐管理

音乐评论管理

主要技术指标与技术参数:

前台使用Html、CSS、JavaScript开发,后台使用Java的SSM框架,数据库使用MySQL。开发工具使用Eclipse。

选题需要重点研究的关键问题及解决问题的思路 选题需要研究的关键问题包括以下几个方面

1. 系统的权限如何划分。

2. 系统的音乐如何上传。

3. 数据库如何连接。

具体解决思路如下:

1. 音乐网站分为前台会员和后台管理员。会员登录后,发布评论信息,而管理员登录后管理系统所有的信息。

2. 管理员登录后上传文件,在文件上传页面,创建一个Form表单,用于提交文件上传信息。编写一个后台上传程序,用于处理上传的文件,获取上传的文件流。将获取到的文件流保存到服务器中的指定路径或者数据库中。

3. 首先需要导入数据库的驱动,可以将数据库的驱动jar包放到项目的lib目录中,使用Spring的JDBC模板或连接池实例来管理数据库连接,可以通过配置文件来配置数据源,在Java中,通过SqlSession对象来执行SQL语句。

lt;marquee>...</marquee>普通卷动

<marquee behavior=slide>...</marquee>滑动

<marquee behavior=scroll>...</marquee>预设卷动

<marquee behavior=alternate>...</marquee>来回卷动

<marquee direction=down>...</marquee>向下卷动

<marquee direction=up>...</marquee>向上卷动

<marquee direction=right></marquee>向右卷动

<marquee direction=left></marquee>向左卷动

<marquee loop=2>...</marquee>卷动次数

<marquee width=180>...</marquee>设定宽度

<marquee height=30>...</marquee>设定高度

<marquee bgcolor=FF0000>...</marquee>设定背景颜色

<marquee scrollamount=30>...</marquee>设定卷动距离

<marquee scrolldelay=300>...</marquee>设定卷动时间

<!>字体效果

<h1>...</h1>标题字(最大)

<h6>...</h6>标题字(最小)

<b>...</b>粗体字

<strong>...</strong>粗体字(强调)

<i>...</i>斜体字

<em>...</em>斜体字(强调)

<dfn>...</dfn>斜体字(表示定义)

<u>...</u>底线

<ins>...</ins>底线(表示插入文字)

<strike>...</strike>横线

<s>...</s>删除线

<del>...</del>删除线(表示删除)

<kbd>...</kbd>键盘文字

<tt>...</tt> 打字体

<xmp>...</xmp>固定宽度字体(在文件中空白、换行、定位功能有效)

<plaintext>...</plaintext>固定宽度字体(不执行标记符号)

<listing>...</listing> 固定宽度小字体

<font color=00ff00>...</font>字体颜色

<font size=1>...</font>最小字体

<font style=font-size:100 px>...</font>无限增大

<!>区断标记

<hr>水平线

<hr size=9>水平线(设定大小)

<hr width=80%>水平线(设定宽度)

<hr color=ff0000>水平线(设定颜色)

<br>(换行)

<nobr>...</nobr>水域(不换行)

<p>...</p>水域(段落)

<center>...</center>置中

<!>连结格式

<base href=位址>(预设好连结路径)

<a href=位址></a>外部连结

<a href=位址 target=_blank></a>外部连结(另开新视窗)

<a href=位址 target=_top></a>外部连结(全视窗连结)

<a href=位址 target=页框名></a>外部连结(在指定页框连结)

<!>贴图/音乐

<img src=图片位址>贴图

<img src=图片位址 width=180>设定图片宽度

<img src=图片位址 height=30>设定图片高度

<img src=图片位址 alt=提示文字>设定图片提示文字

<img src=图片位址 border=1>设定图片边框

<bgsound src=MID音乐档位址>背景音乐设定

<!>表格语法

<table aling=left>...</table>表格位置,置左

<table aling=center>...</table>表格位置,置中

<table background=图片路径>...</table>背景图片的URL=就是路径网址

<table border=边框大小>...</table>设定表格边框大小(使用数字)

<table bgcolor=颜色码>...</table>设定表格的背景颜色

<table borderclor=颜色码>...</table>设定表格边框的颜色

<table borderclor=颜色码>...</table>设定表格边框的颜色

<table borderclordark=颜色码>...</table>设定表格暗边框的颜色

<table borderclorlight=颜色码>...</table>设定表格亮边框的颜色

<table cellpadding=参数>...</table>指定内容与格线之间的间距(使用数字)

<table cellspacing=参数>...</table>指定格线与格线之间的距离(使用数字)

<table cols=参数>...</table>指定表格的栏数

<table frame=参数>...</table>设定表格外框线的显示方式

<table width=宽度>...</table>指定表格的宽度大小(使用数字)

<table height=高度>...</table>指定表格的高度大小(使用数字)

<td colspan=参数>...</td>指定储存格合并栏的栏数(使用数字)

<td rowspan=参数>...</td>指定储存格合并列的列数(使用数字)

<!>分割视窗

<frameset cols="20%,*">左右分割,将左边框架分割大小为20%右边框架的大小浏览器会自动调整

<frameset rows="20%,*">上下分割,将上面框架分割大小为20%下面框架的大小浏览器会自动调整

<frameset cols="20%,*">分割左右两个框架

<frameset cols="20%,*,20%">分割左中右三个框架

<分割上下两个框架

<frameset rows="20%,*,20%">分割上中下三个框架


<! - - ... - -> 注解

<a href target> 指定超连结的分割视窗

<a href=#锚的名称> 指定锚名称的超连结

<a href> 指定超连结

<a name=锚的名称> 被连结点的名称

<address>....</address> 用来显示电子邮箱地址

<b> 粗体字

<base target> 指定超连结的分割视窗

<basefont size> 更改预设字形大小

<bgsound src> 加入背景音乐

<big> 显示大字体

<blink> 闪烁的文字

<body text link vlink> 设定文字颜色

<body> 显示本文

<br> 换行

<caption align> 设定表格标题位置

<caption>...</caption> 为表格加上标题

<center> 向中对齐

<cite>...<cite> 用於引经据典的文字

<code>...</code> 用於列出一段程式码

<comment>...</comment> 加上注解

<dd> 设定定义列表的项目解说

<dfn>...</dfn> 显示"定义"文字

<dir>...</dir> 列表文字标签

<dl>...</dl> 设定定义列表的标签

<dt> 设定定义列表的项目

<em> 强调之用

<font face> 任意指定所用的字形

<font face> 任意指定所用的字形

<font size> 设定字体大小

<form action> 设定户动式表单的处理方式

<form method> 设定户动式表单之资料传送方式

<frame marginheight> 设定视窗的上下边界

<frame marginwidth> 设定视窗的左右边界

<frame name> 为分割视窗命名

<frame noresize> 锁住分割视窗的大小

<frame scrolling> 设定分割视窗的卷轴

<frame src> 将html档加入视窗

<frameset cols> 将视窗分割成左右的子视窗

<frameset rows> 将视窗分割成上下的子视窗

<frameset>...</frameset> 划分分割视窗

<h1>~<h6> 设定文字大小

<head> 标示文件资讯

<hr> 加上分格线

<html> 文件的开始与结束

<i> 斜体字

<img align> 调整图形影像的位置

<img alt> 为你的图形影像加注

<img dynsrc loop> 加入影片

<img height width> 插入图片并预设图形大小

<img hspace> 插入图片并预设图形的左右边界

<img lowsrc> 预载图片功能

<img src border> 设定图片边界

<img src> 插入图片

<img vspace> 插入图片并预设图形的上下边界

<input type name value> 在表单中加入输入栏位

<isindex> 定义查询用表单

<kbd>...</kbd> 表示使用者输入文字

<li type>...</li> 列表的项目 ( 可指定符号 )

<marquee> 跑马灯效果

<menu>...</menu> 条列文字标签

<meta name="refresh" content url> 自动更新文件内容

<multiple> 可同时选择多项的列表栏

<noframe> 定义不出现分割视窗的文字

<ol>...</ol> 有序号的列表

<option> 定义表单中列表栏的项目

<p align> 设定对齐方向

<p> 分段

<person>...</person> 显示人名

<pre> 使用原有排列

<samp>...</samp> 用於引用字

<select>...</select> 在表单中定义列表栏

<small> 显示小字体

<strike> 文字加横线

<strong> 用於加强语气

<sub> 下标字

<sup> 上标字

<table border=n> 调整表格的宽线高度

<table cellpadding> 调整资料栏位之边界

<table cellspacing> 调整表格线的宽度

<table height> 调整表格的高度

<table width> 调整表格的宽度

<table>...</table> 产生表格的标签

<td align> 调整表格栏位之左右对齐

<td bgcolor> 设定表格栏位之背景颜色

<td colspan rowspan> 表格栏位的合并

<td nowrap> 设定表格栏位不换行

<td valign> 调整表格栏位之上下对齐

<td width> 调整表格栏位宽度

<td>...</td> 定义表格的资料栏位

<textarea name rows cols> 表单中加入多少列的文字输入栏

<textarea wrap> 决定文字输入栏是自动否换行

<th>...</th> 定义表格的标头栏位

<title> 文件标题

<tr>...</tr> 定义表格美一行

<tt> 打字机字体

<u> 文字加底线

<ul type>...</ul> 无序号的列表 ( 可指定符号 )

<var>...</var> 用於显示变数

近,我们在教学生使用JavaScript,今天就带大家开发一款简单的音乐播放器。首先,最终效果如图所示:

首先,我们来编写html界面index.html,代码如下:

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8" />

<title></title>

<link rel="stylesheet" type="text/css" href="css/style.css"/>

<script src="js/jquery-2.1.0.js" type="text/javascript" charset="utf-8"></script>

<script src="js/common.js" type="text/javascript" charset="utf-8"></script>

</head>

<body>

<!--播放器-->

<audio id="song" autoplay="autoplay"></audio>

<!--整体结构-->

<div id="boxDiv">

<!--歌词展示区域-->

<div id="contentDiv">

<!--歌词显示-->

<div id="lrcDiv"></div>

<!--上部阴影-->

<span id="bgTopSpan"></span>

<!--下部阴影-->

<span id="bgBottomSpan"></span>

</div>

<!--控制区域-->

<div id="controlDiv">

<!--进度条-->

<div id="progressDiv"></div>

<!--进度条圆点-->

<img id="pointerImg" src="img/audio/progress_pointer@2x.png"/>

<!--播放时间-->

<span id="playTimeSpan">00:00</span>

<!--歌曲标题-->

<span id="titleSpan"></span>

<!--总时间-->

<span id="totalTimeSpan">00:00</span>

<!--按钮区域-->

<div id="buttonDiv">

<!--上一首按钮-->

<img id="prevImg" src="img/audio/play_above_song@2x.png"/>

<!--播放暂停按钮-->

<img id="playOrPauseImg" src="img/audio/play@2x.png"/>

<!--下一首按钮-->

<img id="nextImg" src="img/audio/play_next_song@2x.png"/>

</div>

</div>

</div>

</body>

</html>

接下来,编写style.css,代码如下:

body{

margin: 0px;

background-color: #ccc;

}

#boxDiv{

width: 375px;

height: 568px;

margin: 10px auto;

position: relative;

}

#contentDiv{

width: 375px;

height: 460px;

background-image: url(../img/audio/play_bg@2x.png);

overflow: hidden;

}

#lrcDiv{

margin-top: 260px;

}

#lrcDiv span{

display: block;

line-height: 40px;

text-align: center;

color: white;

font-size: 20px;

}

#bgTopSpan{

position: absolute;

display: block;

width: 375px;

height: 30px;

top: 0px;

background-image: url(../img/audio/play_top_shadow@2x.png);

}

#bgBottomSpan{

top: 430px;

position: absolute;

background-image: url(../img/audio/play_bottom_shadow@2x.png);

display: block;

width: 375px;

height: 30px;

}

#controlDiv{

width: 375px;

height: 180px;

position: relative;

background-color: white;

}

#progressDiv{

background-color: red;

height: 1.5px;

width: 0px;

}

#pointerImg{

width: 18px;

height: 18px;

position: absolute;

top: -8.5px;

left: -3px;

}

#playTimeSpan{

display: block;

position: absolute;

font-size: 14px;

width: 35px;

top: 5px;

left: 5px;

}

#totalTimeSpan{

display: block;

position: absolute;

font-size: 14px;

width: 35px;

top: 5px;

left: 335px;

}

#titleSpan{

display: block;

position: absolute;

height: 30px;

width: 295px;

font-size: 20px;

text-align: center;

left: 40px;

top: 5px;

}

#buttonDiv{

margin-top: 40px;

position: relative;

}

#prevImg{

width: 40px;

height: 40px;

position: absolute;

top: 20px;

left: 60px;

}

#playOrPauseImg{

width: 70px;

height: 70px;

position: absolute;

top: 5px;

left: 152px;

}

#nextImg{

width: 40px;

height: 40px;

position: absolute;

top: 20px;

left: 275px;

}

最后,编写common.js,代码如下:

$(function(){

// 歌曲列表

var playList=["红日", "狼的诱惑", "漂洋过海来看你"];

// 当前播放的歌曲序号

var currentIndex=0;

// 播放器的原生对象

var audio=$("#song")[0];

// 播放时间数组

var timeArr=[];

// 歌词数组

var lrcArr=[];

// 调用播放前设置

setup();

// 播放歌曲

playMusic();

// 播放歌曲

function playMusic(){

// 播放歌曲

audio.play();

// 设置为暂停的图片

$("#playOrPauseImg").attr("src", "img/audio/pause@2x.png");

}

// 歌曲播放前设置

function setup(){

// 设置播放哪一首歌曲

// img/audio/红日.mp3

audio.src="img/audio/" + playList[currentIndex] + ".mp3";

// 设置歌曲的名字

$("#titleSpan").text(playList[currentIndex]);

// 设置歌词

setLrc();

}

// 设置歌词

function setLrc(){

// 清空上一首的歌词

$("#lrcDiv span").remove();

// 清空数组

timeArr=[];

lrcArr=[];

// 加载歌词文件

$.get("img/audio/" + playList[currentIndex] + ".lrc", {}, function(data){

if(data){

// 按行切割字符串

var arr=data.split("\n");

// 分割歌词

for (var i=0; i < arr.length; i++) {

// 分割时间和歌词

var tempArr=arr[i].split("]");

if (tempArr.length > 1){

// 添加时间和歌词到数组

timeArr.push(tempArr[0]);

lrcArr.push(tempArr[1]);

}

}

// 显示歌词

for (var i=0; i < lrcArr.length; i++) {

$("#lrcDiv").append("<span>"+lrcArr[i]+"</span>");

}

}

});

}

// 播放暂停事件

$("#playOrPauseImg").click(function(){

// 如果播放器是暂停状态

if(audio.paused){

// 继续播放

playMusic();

}else{

// 暂停

audio.pause();

// 变成播放的图片

$("#playOrPauseImg").attr("src", "img/audio/play@2x.png");

}

});

// 上一首

$("#prevImg").click(function(){

// 如果是第一首,那么跳到最后一首

if(currentIndex==0){

currentIndex=playList.length - 1;

}else{

currentIndex--;

}

// 播放前设置

setup();

// 播放

playMusic();

});

// 下一首

$("#nextImg").click(function(){

// 如果是最后一首,就跳到第一首

if(currentIndex==playList.length - 1){

currentIndex=0;

}else{

currentIndex++;

}

// 播放前设置

setup();

// 播放

playMusic();

});

// 监听播放器播放时间改变事件

audio.addEventListener("timeupdate", function(){

// 当前播放时间

var currentTime=audio.currentTime;

// 总时间

var totalTime=audio.duration;

// 当是数字的时候

if(!isNaN(totalTime)){

// 得到播放时间与总时长的比值

var rate=currentTime / totalTime;

// 设置时间显示

// 播放时间

$("#playTimeSpan").text(getFormatterDate(currentTime));

// 总时长

$("#totalTimeSpan").text(getFormatterDate(totalTime));

// 设置进度条

$("#progressDiv").css("width", rate * 375 + "px");

// 设置进度圆点

$("#pointerImg").css("left", (375 - 15) * rate - 3 + "px");

// 设置歌词的颜色和内容的滚动

for (var i=0; i < timeArr.length - 1; i++) {

if(!isNaN(getTime(timeArr[i]))){

// 当前播放时间大于等于i行的时间,并且小于下一行的时间

if (currentTime >=getTime(timeArr[i]) && currentTime < getTime(timeArr[i+1])){

// 当前行歌词变红色

$("#lrcDiv span:eq("+i+")").css("color", "#FF0000");

// 其他行歌词变白色

$("#lrcDiv span:not(:eq("+i+"))").css("color", "#FFFFFF");

// 当前行歌词滚动

$("#lrcDiv").stop(false, true).animate({"margin-top": 260 - 40 * i + "px"}, 1000);

}

}

}

}

});

function getTime(timeStr){

// 去掉左边的[

var arr=timeStr.split("[");

if(arr.length > 1){

// 得到右边的时间

var str=arr[1];

// 分割分、秒

var tempArr=str.split(":");

// 分

var m=parseInt(tempArr[0]);

// 秒

var s=parseFloat(tempArr[1]);

return m * 60 + s;

}

return 0;

}

// 格式化时间(00:00)

function getFormatterDate(time){

// 分

var m=parseInt(time / 60);

// 秒

var s=parseInt(time % 60);

// 补零

m=m > 9 ? m : "0" + m;

s=s > 9 ? s : "0" + s;

return m + ":" + s;

}

});

图片和歌曲、歌词请自行下载,最后,可以运行试试了。是不是很有趣呢?想要学习更多的Java技术开发知识,关注“重庆千锋”获取更多的视频教程,千锋重庆IT培训机构还提供两周免费试听课程,欢迎各位小伙伴申请试听。