题目:在线课程学习网站的设计与实现摘要随着互联网的普及,网络在人们生活中的应用越来越广泛。在线课程学习系统平台是信息化教育资源建设的关键环节,学生通过网络平台了解专业动态、自助学习课程知识、提出学习过程中遇到的问题,教师通过网络平台与学生形成交互式教学。针对web开发的最流行的php语言程序设计的在线学习的网站较少,本系统尝试用wamp在网络上架构一个php语言在线学习系统,为学生提供一个自主学习的平台,弥补了学生课后对php语言程序设计学习资源的不足。本文从理论和实践两个角度出发,对系统的开发背景、系统的开发和运行环境、系统功能分析、系统功能模块设计、数据库结构实现、各个功能模块的创建等各个过程进行了阐述,设计、实现一个具有数据挖掘功能php语言在线学习系统。本在线学习系统采用php技术进行开发,选用mysql作为后台数据库。系统实现了用户管理、查看文件、分类查找、课件下载、留言板、教学大纲、网站管理等功能。关键词:php;mysql;在线学习系统;AbstractWiththepopularityoftheInternet,networkapplicationsinpeople'slivesmoreandmorewidely.Onlinecoursesystemisthekeylinkoftheconstructionofeducationalinformationresources,studentsthroughthenetworkplatformtounderstanddynamic,vironmentprofessionallearningcourseknowledge,theproposedlearningproblemsencounteredintheprocess,teachersandstudentsthroughthenetworkplatformofinteractiveteaching.InsidetheClanguageprogrammingonlinelearningsiteisless,thesystemattemptstousetheVisualStudio2008onthenetworkstructureofaClanguageonlinelearningsystem,toprovidestudentswithalearningplatform,madeupofstudentsontheClanguageprogramdesignlearningresource.Thearticlefromtheoryandpracticetwoanglesetout,thesystemdevelopmentbackground,systemdevelopmentandrunningen,systemfunctionanalysis,thesystemfunctionmoduledesign,databasestructure,thecreationofvariousfunctionalmodulesandsooneachprocessaredescribed,thedesign,therealizationofahasthefunctionsofdatamininginClanguageonlinelearningsystem.Theonlinelearningsystemusingtechnologydevelopment,usingSQLServer2005databaseasabackground.Systemusermanagement,viewthefile,classificationsearch,coursewaredownload,messageboards,syllabus,websitemanagementandotherfunctions.Keywords:php;mysql;onlinelearningsystem;目录...................................................................22致谢41绪论课题的提出随着互联网的普及,网络在人们生活中的应用越来越广泛,在教学学习方面网络带来的便利尤为突出。而php语言程序设计作为目前我国计算机类专业必须开设的一门基础类课程,它的应用已经深入到了人类生活的各个角落,渗透到了各行各业各行业,各部门进行计算机应用、管理和维护都需要熟练的操作员掌握扎实的程序设计语言基础[1]。但是对于大多数学生来说,学习这部分知识都是初学者,在这之前根本就没有接触过这些知识,程序学习不同于其它课程的学习,很容易形成一种恶性循环从而完全散失学习兴趣。但是作为计算机类专业的学生,毕业后可能要承担计算机软件应用和开发的任务,就应具有一定的编程能力和应用开发能力。在线课程学习网站是一种全新的网上学习平台,它改变传统的学习方式,让程序学习不再受时间、地理位置、师资水平及教学资源方面的限制,调动了学生的自主性和积极性[2]。面对目前php语言学习资源的缺乏、自主学习尚存在诸多问题的状况以及php语言课程的重要性,为学生提供一个自主学习的平台,是目前让学生更好学习的有效途径。在线课程学习网站的研究现状我国互联网行业较国外起步晚,所以课程网站的起步也较晚,但目前中国课程网站的发展十分迅速,几乎涵盖了所有包括中小学、大学及各种技能证书培训的所有课程,内容丰富而冗余,分类庞杂而紊乱,大多功能相似,内容相仿[3]。在线课程学习网站研究的意义在线学习又称网络化学习,是应用网络进行在线学习的一种全新方式。网上学习社区及网络技术平台构成的全新的学习环境。在线课程学习网站是计算机技术、网络技术、数据库技术和多媒体技术相结合的现代网络在线学习的平台[4]。主要表现在三个方面:1、内容资料丰富。在良好的网络学习界面基础上不受实物陈列空间的限制,系统向学生提供了多种学习方法,学生可选择不同的学习媒体与学习方法。2、方便学习交流、疑难解答。学生通过系统中的留言板等功能模块,向老师寻求在线帮助及解答。3、完备的学习功能。学生可进行课程授课计划等信息的查看,相关课件、作业的下载,疑难问题的提问等操作[5]。在线课程学习网站不仅是学校提高教学质量进行教学改革的窗口,也是学生自主学习、教学互动、学习交流的重要平台。在线课程学习网站除了具有丰富的课件、作业试题等相关资料,应该具有运行良好的开放式教学课程网站。通过网络学习平台,教师可以了解学生的学习状况,在线解决学生的疑问,听取学生的意见,发布相关信息资源等。及时消除学生学习中的疑惑,便于巩固所学的知识。2需求分析可行性分析技术可行性分析目前,网络应用程序的开发主要采用的框架是Browser/Server(浏览器/服务器)和Client/Server(客户端/服务器)模式。B/S采用Internet技术,适用于广域网环境,支持更多的用户,可根据访问量动态配置Web服务器,应用程序,以保证系统性能。客户端只需安装标准浏览器即可。采用面向对象技术,代码可重复性较好,系统扩展维护简单。C/S适用于局域网环境,可以连接用户数量有限,当用户数量增多时性能会明显下降,客户端要安装应用程序,系统扩展维护比较复杂,代码可重复性比较差[6]。本系统所面向的对象是广大的互连网用户,从均衡服务器和客户端的负载的角度出发,采用B/S三层结构。操作可行性分析在线课程学习网站在操作上,界面整洁,使用简单。对于教师而言,操作简单,只要登录后台管理,就能很方便的进行教学课件、作业查看发布等操作。1、系统软件硬件的风险。系统存在一定的软硬件崩溃带来的风险,可以定期备份数据以降低风险。2、计划的拖延。网站的开发存在因计划拖延带来的风险。系统需求分析系统功能需求本系统由角色分可分为三类,即:学生用户,教师用户和管理员。根据调查研究,本系统教师用户需实现的功能有:学习课件的上传,作业的发布及查看,留言板的设置及回复。教师用户的用例图如图1所示:图1管理员用户用例图系统性能需求1、实用性:方便快捷,便于管理,调动学生学习积极性,提高教学质量。2、操作简单:本系统适用于不同水平的使用者,要求系统不太复杂和繁琐,以便系统操作尽可能简单易行。3、适应性:应该能广泛应用于该校学生,采用模块化设计,用户可以根据自身情况自行自合,合理使用该系统。4、安装使用简便:服务器端的安装简洁明了,无需安装任何软件,只要能访问Internet都可以使用该系统[7]。3系统开发工具及相应技术B/S体系结构在B/S体系结构系统中,用户通过浏览器向分布在网络上的许多服务器发出请求,服务器对浏览器的请求进行处理,将用户所需信息返回到浏览器。B/S结构简化了客户机的管理员学习课件上传作业发布留言板设置学生问题回复作业查看工作,客户机上只需配置少量的客户端软件。服务器将担负更多的工作,对数据库的访问和应用程序的执行将在服务器上完成。浏览器发出请求,而其余如数据请求、加工、结果返回以及动态网页生成等工作全部由WebServer完成[8]。这种三层体系结构如图2所示:图2B/S三层结构图B/S模式具有C/S模式无法替代的优越性,它简化了系统的开发和维护。因此,我小组开发的系统采用了基于B/S模式的体系结构。wampWindows下的Apache+Mysql/MariaDB+Perl/PHP/Python,一组常用来搭建动态网站或者服务器的开源软件,本身都是各自独立的程序,但是因为常被放在一起使用,拥有了越来越高的兼容度,共同组成了一个强大的Web应用程序平台。随着开源潮流的蓬勃发展,开放源代码的LAMP已经与J2EE和.Net商业软件形成三足鼎立之势,并且该软件开发的项目在软件方面的投资成本较低,因此受到整个IT界的关注。LAMP是基于Linux,Apache,MySQL/MariaDB和PHP的开放资源网络开发平台,PHP是一种有时候用Perl或Python可代替的编程语言。这个术语来自欧洲,在那里这些程序常用来作为一种标准开发环境。名字来源于每个程序的第一个字母。每个程序在所有权里都符合开放源代码标准:Linux是开放系统;Apache是最通用的网络服务器;mySQL是带有基于网络管理附加工具的关系数据库;PHP是流行的对象脚本语言,它包含了多数其它语言的优秀特征来使得它的网络开发更加有效。开发者在Windows操作系统下使用这些Linux环境里的工具称为使用WAMP。数据库SQLserver是一个使用非常广泛的数据库,对于我们常见的数据库有好几种,这里,我们来列举一下,包括mysql,access,oracle,还有sqlserver,那么他们的特点各不相同,有各自的优点和缺点,那么,我们来列举一下,mysql的优点是比较灵活,是个开源的数据库,受广大自由开发者的喜爱啊,经常和php语言进行搭配,acess的优点是比较小,适合于小型的企业使用,经常和asp的语言进行搭配,oracle,这个大家应该知道,是个非常好的数据库软件,甲骨文公司的产品,大型的数据库,成本,非常的高,使用的要求,也非常的高。甲骨文的老板,甚至是可以和微软的盖茨比肩的商业巨头。但是对于开发小企业的的网站来说,成本太高了。经常和jsp的语言配合使用。最后就是sqlserver,微软自己研发的数据库,有多个版本,最老的版本,是sql2000,然后发展到了,sql2005,sql2008,最新的是sql2012,他的优点是不需要收费,使用成本比较低,而且是微软的软件,开发的平台,就可以在windows上面开启,非常的方便,经常和的语言搭配使用,是个不错的数据库语言。[10]。4系统总体设计系统总体设计面对面的人际交互不再是在线学习系统的主要教学形式,因此,以媒体为中介的交互是实现在线学习系统中教与学再度整合的关键过程。该学习系统中,学生用户可以以原有的注册帐号或新注册帐号登录,进入学生操作功能页面进行课件及视频的下载,新闻浏览,学生基本信息的修改,学生在线留言,提出问题,下载作业等功能。