音乐类别管理功能模块设计.doc

上传人:精*** 文档编号:841641 上传时间:2023-09-08 格式:DOC 页数:41 大小:1.38MB
下载 相关 举报
音乐类别管理功能模块设计.doc_第1页
第1页 / 共41页
音乐类别管理功能模块设计.doc_第2页
第2页 / 共41页
音乐类别管理功能模块设计.doc_第3页
第3页 / 共41页
音乐类别管理功能模块设计.doc_第4页
第4页 / 共41页
音乐类别管理功能模块设计.doc_第5页
第5页 / 共41页
点击查看更多>>
资源描述

1、摘 要随着互联网的发展,越来越多的音乐网受到人们的喜爱。人们可以通过各种音乐网实现在线试听歌曲,下载歌曲,根据需要搜索喜爱的歌曲。还可以把自己喜欢的歌曲收藏起来。目前大多数的音乐网站,都提供在线试听,音乐下载,在线交流,音乐收藏等功能。经过对音乐网的分析,本次毕业设计设计了一个能够满足音乐爱好者基本需求的ASP.NET音乐网。该设计是采用ASP.NET技术和SQL SERVER 数据库设计实现。该网站的主要功能是实现了前台音乐的浏览、下载、收藏、用户注册、登录,音乐试听、留言等功能。网站后台实现了音乐管理、用户管理、留言管理、音乐类别管理等功能。关键词:音乐网、ASP.NET、SQL Serv

2、er 2005ABSTRACTWith the development of Internet, more and more music popular. People through various music online audition song, song downloads, according to the need to search for my favorite songs. Also their love song collection. Most of the music site, offers online audition, music downloads, on

3、line communication, music collections and other functions. After the music network analysis, the graduation design to design a meet the basic needs of music lovers ASP.NET music network. This design is the use of ASP.NET technology and SQL SERVER database design and implementation. The site of the m

4、ain function is to achieve the foreground music browsing, download, collection, user registration, login, music, messages and other functions. The background of the website realizes the music management, user management, message management, music category management and other functions.Keywords: The

5、 music、ASP.NET、SQL Server 2005目 录第一章 绪 论4第二章 系统环境分析52.1 ASP.NET相关知识简介52.2 ASP.NET与ASP72.2.1 ASP.NET的优势82.2.2 ASP.NET的改进82.2.3 ASP.NET支持各种浏览器82.2.4 ASP.NET的更新9第三章 需求分析及整体设计103.1 功能需求103.2 系统使用者权限103.2.1 系统管理员103.3 网站功能模块图10第四章 数据库设计12第五章 详细设计及功能实现155.1 前台功能模块介绍155.2 登录注册界面设计155.3 前台主界面设计195.4 留言功能模块设

6、计265.6 后台功能模块介绍305.7 用户管理功能设计315.8 音乐类别管理功能模块设计355.9 留言管理功能模块设计38结 论40参考文献41致 谢42第一章 绪 论随着互联网的发展,越来越多的音乐网受到人们的喜爱。人们可以通过各种音乐网实现在线试听歌曲,下载歌曲,根据需要搜索喜爱的歌曲。还可以把自己喜欢的歌曲收藏起来。目前大多数的音乐网站,都提供在线试听,音乐下载,在线交流,音乐收藏等功能。经过对音乐网的分析,本次毕业设计设计了一个能够满足音乐爱好者基本需求的ASP.NET音乐网。该设计是采用ASP.NET技术和SQL SERVER 数据库设计实现。该网站的主要功能是实现了前台音乐

7、的浏览、下载、收藏、用户注册、登录,音乐试听、留言等功能。网站后台实现了音乐管理、用户管理、留言管理、音乐类别管理等功能。虽然该网站的功能还不够强大,还需要进一步的完善。但是音乐网的基本功能都以实现,能够满足一般用户的需要。第二章 系统环境分析2.1 ASP.NET相关知识简介ASP.NET是一个已编译的、基于.NET的环境,可以用任何与.NET兼容的语言(包括Visual Basic、.NET、C#和JScript.NET)创作应用程序。另外,任何ASP.NET应用程序都可以使用整个.NET框架,首先为了对.NET开发框架有一个整体的认识,请参阅图2.1所示:图2.1 Visual Stud

8、io.NET开发框架示意图ASP.NET可以协调地 WYSIWYG HTML编辑器和其他编程工具(包括 Microsoft Visual Studio.NET)一起工作。这不仅使得Web开发更加方便,而且还能提供这些工具必须提供的所有优点,包括开发人员可以将服务器控件拖到Web页用来GUI和完全集成的调试支持。.NET框架包含两个用于访问企业数据库的数据提供程序:OLE DB .NET数据提供程序和SQL Server.NET数据提供程序。本系统是使用SQL Server.NET数据提供程序来访问SQL Server。具体访问过程大致为:l 用SqlConnection类创建一个数据库连接;l

9、 使用SqlDataAdapter类从数据库中选择一组记录;l 使用SqlDataAdapter类填充新的DataSet;如果您正在从数据库中选择仅用于非交互显示的数据,为了获得最佳性能,建议使用只读、只进的SqlDataReader(或对于非SQL数据库使用OleDbDataReader)。当使用SqlDataReader时,请使用SqlCommand查询选择记录,并创建一个从SqlCommand对象的ExecuteReader方法返回的SqlDataReader,在某些情况下(例如当需要对一组数据进行排序或筛选时),也可能需要基于DataSet为所需表创建一个新的DataView。将服务器

10、控件(如DataGrid)绑定到DataSet、SqlDataReader或DataView。.NET框架包含三个便于显示大量数据的控件:Repeater控件、DataList控件和DataGrid控件。这三个控件都使用相似的数据绑定过程。ASP.NET提供一种简单的模型,该模型使Web开发人员能够编写在应用程序级运行的逻辑。开发人员可以在Global.asax文本文件或在作为程序集部署的已编译的类中编写这种代码。这种逻辑可以包括应用程序级事件,但开发人员可以轻松地扩展这种模型,以适应Web应用程序的需要。Global.asax文件是一个可选的包含响应应用程序级事件的文件,运行时Global.

11、asax文件被ASP.NET自动地解析并动态编译成为自Http Application派生的动态.NET框架类,当位于application名字空间内的任意资源或URL被首次访问时它被创建。Global.asax被自动配置为禁止直接通过URL访问,这样外部使用者就不可能下载或查看到Global.asax文件的代码;并且Global.asax文件是可选的,如果没有定义Global.asax文件,ASP.NET将不打算处理任何Application或Session事件。当改变一个正在运行的ASP.NET Web应用的Global.asax文件时ASP.NET将检测到这种改变,并向任何收听者发送 A

12、pplication_OnEnd事件,然后重新启动Web应用程序,关闭并清空所有的浏览器Session。当下一个对Web应用程序的请求到来时,Global.asax将重新解释和编译,并且触发Application_OnStart事件。ASP.NET提供易用的应用程序和会话状态功能,它们对于ASP开发人员来说是熟悉的,且容易与所有其他.NET框架API兼容。关于Application和Session对象的详细介绍如下:可以通过Application状态,在不同的Web窗体中共享一些全局的应用程序信息,并且支持对用户同时访问。应用Application状态时,以下几点对应用Application状

13、态很重要。使用Application状态后,内存将被存储的变量一直占用,直到这个变量被清除后或重新赋值,不像单独的Web页面,在单独的Web页面中,所有的资源在客户的请求结束后就自动被清除了。所以记住,不要在Application状态中储存超过10M的数据,尽管可以这么做,但这并不是合理使用资源的方法。储存在Application状态中的信息可以被多个线程同时访问,为了避免发生问题,要时刻注意多线程问题,避免发生死锁。当一个全局的公用Application状态可以被客户修改时,注意使用Lock和Unlock方法保护数据。Application状态信息不能在Web农场(位于不同Server上的不

14、同Web应用程序)或Web花园(位于相同Server上的不同Web应用程序)范围内共享。只有在一个Web应用程序中的不同Web窗体里才能被共享和访问。HTTP协议是无状态协议这意味着无法判断一系列的客户请求是否来自相同的客户。ASP.NET的Session状态提供这样一种能力,自动地判别来自相同客户端的请求,并将客户端看成是逻辑上位于Server的对象。在客户端浏览器经过一定的时间没有再来访问Web应用程序时,自动清除Session对象,释放此Session状态所有保存信息所占用的资源。2.2 ASP.NET与ASPASP.NET不是ASP(Active Serve Pages)的简单升级,而

15、是微软公司的新的体系(.NET)的一部分,其中全新的技术架构会让每个人的编程生活变得更简单。ASP.NET是在抓住ASP的最大优点并全力使其扩大化的基础上开发出来的,并且同时也修复了许多ASP运行时会发生的错误。那么ASP.NET对于ASP来说有什么突破呢?首先,运行机制不同。ASP属于一种解释型的编程框架,它的核心是VBScript和JScript,受这两种脚本语言的限制,决定了ASP先天不足,它无法进行像传统编程语言那样的底层操作,所以如果需要进行一些如socket、文件等的操作时不得不借助其他传统编程语言如C+、VB、Java等编写的组件,并且由于它是解释执行的,所以在运行效率上大打折扣

16、。而ASP.NET是一种编译型的编程框架,它的核心是NGWS runtime,可以用VB和C#来编写,这就决定了它功能的强大,可以进行很多底层操作而不必借助于其他编程语言。另外由于它是编译后执行的,所以执行效率要比ASP高得多。以下几点可使大家对ASP.NET和ASP有一个更全面的了解。2.2.1 ASP.NET的优势ASP.NET使代码更加干净。现有的ASP应用程序结构总是充满了长长短短的代码。而ASP.NET的代码不仅更容易编写,而且更加干净整洁,比ASP更易于阅读。同时,ASP.NET代码的结构方式提高了其再利用性和共享性。ASP能使用非结构语言编写,如VBScript和JScript(

17、如果用其他语言还需要单独的解释器)。而且当ASP在第一次执行时,它解释并在cache中存储这些代码,这样的局限性就是不允许其他结构性语言(如VB和C+)的使用,从而限制了它们的优越性。而ASP.NET真正提供了中层语言执行结构,允许各种语言的使用。虽然使用HTML文本,对象混合的ASP很容易建立一个大型的页面,但是很难重复利用这些代码,除非把一些代码放在一个include文件中,这也不是最好的解决方法。但是ASP.NET真正允许了单独的代码与内容共存。另外,在ASP中必须为几乎每件事情编写代码。如今在ASP.NET中引用了一种真正的组件模式,通过这种服务器端的控件以及事件触发,感觉就好像是在操

18、作VB中的FORM。这种ASP.NET中的新组件控制是宣告性质的,因此实际上只需写很少的代码,甚至完全不用写任何的代码。2.2.2 ASP.NET的改进对于简单的ASP应用程序,配置其实并不算什么问题,但是如果要移植到一个利用组件的N层结中时往往会遇到问题。而当对这些应用程序进行配置和维护时,DDL陷阱问题(组件注册、版本、锁定的DDL)就会出现。ASP.NET中则取消了组件注册以及DDL锁定,全面使用了XML配置文件,从而解决了这个问题。这样只需要执行简单的复制文件的工作就能配置一个Web应用程序。2.2.3 ASP.NET支持各种浏览器对于ASP开发人员来说,浏览器兼容问题本来就是一个永恒

19、的问题,对于Web程序员来说最大的挑战就是不断变化的浏览器的兼容性以及它们不断升级的复杂性。在保证能在所有浏览器下工作的同时,又得尽量地使用每个浏览器最新属性来建立更加具有交互式的页面,这对于ASP来说,要实现这个目的很难。ASP.NET引入了一个新的服务控制的概念,它封装了一些普通的任务,提供了一种清晰的编程模块,从而完成了帮助管理处理不同的用户类型的任务,动态地对不同的用户生成不同的输出,解决了浏览器兼容性问题。2.2.4 ASP.NET的更新目前的Web应用程序通常都是同一种模式:一套线性应用程序,然后将逻辑植入其中之一。ASP.NET允许开发人员打破这种单一模式,创造出更加动态而且伸缩

20、性更强的应用程序,这种应用程序能够更好地满足公司的商业需求,并提供一个更加丰富的开发环境。总之用ASP.NET进行开发要简单的多。它提供稳定的性能、优秀的升级性、更快速更简便的开发和管理方式、全新的语言及网络服务。在开发Web应用中更加易于写出结构清晰的代码,而且代码易于重用和共享,还可编译类语言编写等,极大满足了计算向Web转移的战略方向的需要,为程序员提供了更多新的开发机会。作为微软公司开创新局面的战略产品,在使用ASP.NET时,只需将精力集中在如何完善项目的方案上,而不用将精力再放在建立基础结构上了。因为ASP.NET已经做好了充分的基础架构,大部分不重要的工作也将由系统帮助完成,当然

21、也可以自己处理或者不按系统的默认方式来处理。第三章 需求分析及整体设计3.1 功能需求本网站主要是通过运用ASP.NET和SQL Server技术实现ASP.MET音乐网的整体设计,本网站的主要实现以下功能:1. 网站用户:主要执行页面浏览、注册登录、歌曲下载、歌曲收藏、在线试听、留言交流。2. 管理员:音乐管理、用户管理、类别管理、新闻管理、管理员管理、留言管理。3.2 系统使用者权限3.2.1 系统管理员统管理员通过管理员登录页面,在输入帐号、密码后,经系统验证正确后可进入系统管理界面。系统管理员便可管理用户信息、音乐信息、类别信息、新闻信息、留言信息;系统管理员也可进入系统管理员密码修改

22、页面,修改自己的密码。3.3 网站功能模块图ASP.MET音乐网分为管理员和网站用户模块。ASP.MET音乐网功能模块如下图3.1所示:ASP.MET音乐网前台模块后台模块注册登录浏览音乐试听音乐用户管理音乐管理新闻管理留言管理下载音乐收藏音乐类别管理图3.1 系统功能模块图第四章 数据库设计经过对本网站的功能分析,根据具体的需要,该网站利用SQL Server 2005设计了管理员信息表、类别信息表、音乐信息表、收藏信息表、用户信息表、新闻信息表、留言信息表、回复信息表。各个别的具体字段及详细设计如下:表名:tb_admin 管理员信息表序号列名数据类型长度小数位标识主键外键允许空默认值说明

23、1idint40是是否2usernvarchar500是3pwdnvarchar500是表名:tb_boardInfo 留言信息表序号列名数据类型长度小数位标识主键外键允许空默认值说明1idint40是是否2titlenvarchar500是留言标题3contentnvarchar00是留言内容4usernvarchar500是留言人帐号5datedatetime83是getdate时间表名:tb_feedbackInfo 回复信息表序号列名数据类型长度小数位标识主键外键允许空默认值说明1idint40是是否2bidint40是留言id3contentnvarchar00是回复内容4dated

24、atetime83是getdate回复时间5adminusernvarchar500是管理员帐号表名:tb_musicCollect 收藏信息表序号列名数据类型长度小数位标识主键外键允许空默认值说明1idint40是是否2musicTypeint40是3specialNamenvarchar500是4musicNamenvarchar500是5musicPathnvarchar500是7singerNamenvarchar500是8auditionSumnvarchar500是9downSumnvarchar500是10fileSizenvarchar500是11usernvarchar500

25、是表名:tb_musicInfo 音乐信息表序号列名数据类型长度小数位标识主键外键允许空默认值说明1idint40是否编号2musicTypeint40是歌曲类型3specialNamenvarchar500是专辑名称4musicNamenvarchar500是歌曲名称5musicPathnvarchar500是歌曲路径7singerNamenvarchar500是歌手姓名8auditionSumint40是0试听次数9downSumint40是0下载次数10fileSizenvarchar500是文件大小11recomnvarchar500是表名:tb_musicNews 音乐新闻表序号列名

26、数据类型长度小数位标识主键外键允许空默认值说明1idint40是是否编号2titlenvarchar500是标题3contentnvarchar00是内容4datedatetime83是getdate时间表名:tb_musicType 音乐类别表序号列名数据类型长度小数位标识主键外键允许空默认值说明1idint40是是否2musictypenvarchar500是表名:tb_userInfo 用户信息表序号列名数据类型长度小数位标识主键外键允许空默认值说明1idint40是是否2usernvarchar500是帐号3pwdnvarchar500是密码第五章 详细设计及功能实现本网站主要是通过网

27、络平台,运用ASP.NET和SQL Server技术实现ASP.NET音乐网的基本功能。该网站设计主要分为前台功能模块,和后台功能模块。前台主要是针对广大音乐用户,后台主要是管理员对整个网站进行管理。5.1 前台功能模块介绍前台用户主要针对广大音乐需求用户。网站用户未在该网站进行注册登录的时,只能在该网站浏览相关信息,不能进行其他操作。如果用户想要在该网站留言、收藏歌曲,必须先进行注册登录。5.2 登录注册界面设计用户在进行相关权限执行之前,必须在网站上进行注册,注册登录成功之后,网站系统根据用户的登录,进行相关页面的跳转,然后用户可以执行相关权限。登录注册页面设计效果如下:图 5.1 用户注

28、册界面功能代码:/判断GridView控件中是否拥有选择的复选框 protected bool isCheck( GridView gv ) bool c = false; /遍历GridView控件 foreach (GridViewRow gvr in gv.Rows) /判断复选框状态是否选中 if (CheckBox)gvr.FindControl(CheckBox1).Checked) c = true; break; return c; protected void Button1_Click(object sender, EventArgs e) if (!DB.isExists

29、(select * from tb_userInfo where user= + txt_name.Text.ToString().Trim() + ) string pwd = FormsAuthentication.HashPasswordForStoringInConfigFile(txt_pwd.Text.Trim(), SHA1); DB.ExecuteSql(insert into tb_userInfo(user,pwd)values( + txt_name.Text.ToString().Trim() + , + pwd + ); Common.ShowMessage(Page

30、, 注册成功!, ); else Common.ShowMessage(Page, 用户已存在!, ); 图 5.2 用户登录界面功能代码:/判断GridView控件中是否拥有选择的复选框 protected bool isCheck( GridView gv ) bool c = false; /遍历GridView控件 foreach (GridViewRow gvr in gv.Rows) /判断复选框状态是否选中 if (CheckBox)gvr.FindControl(CheckBox1).Checked) c = true; break; return c; protected v

31、oid Button1_Click(object sender, EventArgs e) string pwd = FormsAuthentication.HashPasswordForStoringInConfigFile(txt_pwd.Text.Trim(), SHA1); if (DB.isExists(select * from tb_userInfo where user= + txt_name.Text.ToString().Trim() + and pwd=+pwd+) Common.ShowMessage(Page, 登录成功!, ); HttpCookie cookies

32、; cookies = new HttpCookie(xzf); cookies.Values.Add(user, HttpUtility.UrlEncode(txt_name.Text.Trim(); cookies.Expires = DateTime.Now.AddHours(24); Response.Cookies.Set(cookies); Response.Redirect(index.aspx); else Common.ShowMessage(Page, 帐号或密码错误, ); 5.3 前台主界面设计前台用户主要针对广大音乐爱好者需求用户,网站用户在网站登录界面进行登录,在前

33、台主界面可以进行歌曲查询,根据导航进行相关页面的跳转:图 5.3前台主界面如果用户根据需要进行查询,系统会根据用户输入的关键字给出相应的结果,查询结果界面设计如下:图 5.4 房屋查询界面功能代码:protected void Page_Load(object sender, EventArgs e) if (!IsPostBack) string type = Requesttype; string text = Requesttext; string sqlSel = select * from tb_musicInfo where + type + like % + text + %;

34、gvMusic.DataSource = dataOperate.getRows(sqlSel); gvMusic.DataKeyNames = new string id ; gvMusic.DataBind(); labNum.Text = gvMusic.Rows.Count.ToString(); protected void gvMusic_RowCommand(object sender, GridViewCommandEventArgs e) /判断是否为下载操作 if (e.CommandName = down) /获取歌曲的id string id = e.CommandAr

35、gument.ToString(); /创建SQL语句,查询歌曲的详细信息 string sqlSel = select musicPath from tb_musicInfo where id= + id; /创建SQL语句,更新歌曲的下载次数 string sqlUpdate = update tb_musicInfo set downSum=downSum+1 where id= + id; ; /执行SQL语句 dataOperate.execSql(sqlUpdate); /调用自定义downFile方法实现歌曲的下载操作 downFile(dataOperate.getTier(s

36、qlSel); protected void downFile(string musicPath) string path = Server.MapPath(musicFile/) + musicPath; /初始化 FileInfo 类的实例,它作为文件路径的包装 FileInfo fi = new FileInfo(path); /判断文件是否存在 if (fi.Exists) /将文件保存到本机上 Response.Clear(); Response.AddHeader(Content-Disposition, attachment; filename= + Server.UrlEnco

37、de(fi.Name); Response.AddHeader(Content-Length, fi.Length.ToString(); Response.ContentType = application/octet-stream; Response.Filter.Close(); Response.WriteFile(fi.FullName); Response.End(); protected void imgBtnHaving_Click(object sender, ImageClickEventArgs e) /判断GridView控件中的复选框状态 if (isCheck(gv

38、Music) /遍历GridView控件 foreach (GridViewRow gvr in gvMusic.Rows) /将GridView控件中的复选框设置为选中状态 (CheckBox)gvr.FindControl(CheckBox1).Checked = false; else /遍历GridView控件 foreach (GridViewRow gvr in gvMusic.Rows) /将GridView控件中的复选框设置为不选中状态 (CheckBox)gvr.FindControl(CheckBox1).Checked = true; protected void img

39、BtnReverse_Click(object sender, ImageClickEventArgs e) foreach (GridViewRow gvr in gvMusic.Rows) (CheckBox)gvr.FindControl(CheckBox1).Checked = !(CheckBox)gvr.FindControl(CheckBox1).Checked; /判断GridView控件中是否拥有选择的复选框 protected bool isCheck(GridView gv) bool c = false; /遍历GridView控件 foreach (GridViewRow gvr in gv.Rows) /判断复选框状态是否选中 if (CheckBox)gvr.FindControl(CheckBox1).Checked) c = true;

展开阅读全文
相关资源
相关搜索
资源标签

当前位置:首页 > 学术论文 > 毕业设计

版权声明:以上文章中所选用的图片及文字来源于网络以及用户投稿,由于未联系到知识产权人或未发现有关知识产权的登记,如有知识产权人并不愿意我们使用,如有侵权请立即联系:2622162128@qq.com ,我们立即下架或删除。

Copyright© 2022-2024 www.wodocx.com ,All Rights Reserved |陕ICP备19002583号-1 

陕公网安备 61072602000132号     违法和不良信息举报:0916-4228922