高校科研管理系统毕业论文.doc
目 录第一章 概论4第二章 ASP和ACCESS的认识5一、ASP的简介:5二、ACCESS简介:6第三章 开发环境及需求8一、开发目的8二、项目背景8三、开发环境8四、系统开发的思想与原则8第四章 结构设计10一、数据库10二、功能模块流程图11第五章 功能设计12一、科研管理系统显示12二、后台管理12第六章 功能说明13一、组合查询模块如图13二、个人信息模块如图:14三、修改个人信息模块的如图:16四、管理登陆模块如图:19五、参数设置模块:22第七章 结论26第八章 致谢和参考27引 言高校科研管理系统,我负责的是前台的部分(组合查询、个人信息、后台登陆)和部分后台管理(管理员管理)首先输入网址可运行的数据库处理系统软件及动态网页制作的软件和毕业设计报告。摘 要我们从学校的实际情况出发,经过对学校有关科研管理事项的一番考察和分析,随着办学规模的不断扩大,教师人数的增加以及平时中种种的记录不断提高,管理工作量之大,任务之繁重,给管理部门人员带来诸多困难,差错率高,对学校教学和科研工作产生较大的影响,所以这种对科研管理的软件把把管理人员从繁重的工作中解放出来,降低差错率,会方便许多,同时也可以对每个老师进行管理。在对科研管理需求的分析基础上,确立了科研管理系统的具体实现功能。并阐述系统的结构设计和功能设计,实现科研管理的分类显示。前台是给老师申请各种著作或作品的申报,以及申报的处理,和获奖情况。后台,一是:对各种作品、文章、著作等的管理。二是:对老师的信息以及个人信息的管理。三是:后台管理员的信息管理。第一章 概论伴随着网络的出现,网页逐渐融入人们的生活。快速及时的新闻浏览,五彩缤纷的网上信息,使网络与人们的生活息息相关,于是世界上又出现了第三媒体Internet。它打破了地域限制,真正使信息得以共享,改变了人们的工作和生活方式。制作网页是企业和个人的宣传自己的重要手段,同时也是学习者获取学习信息的重要手段。尤其是在教育领域,在素质教育与终身教育成为必然的今天,人们对信息的需求有了更新,更高的要求,而网页由于本身所具有的信息量大,传递快速,没有时空限制等特点恰好满足这种要求。所以网页也逐渐成为一种新兴的教育资源。也正是由于网络实现网站的数据信息能够进行实时交互,保证网站数据的实时性。随着Internet的进一步发展,静态Web站点的开发与维护变得越来越困难,一方面信息的不断增加和变化,使站点维护人员不得不经常修改他们的网页,特别是基于数据库驱动的Web站点更是如此,随着Internet上信息量的增多和交互性的加强使HTML显得越来越难以胜任。另一方面静态网页由于不能与浏览者进行有效交互,使人们感到越来越乏味,而不愿意再一次地进入同一站点。所以开发动态网页或动态内容成了越来越多的站点所追求目标。所谓动态内容是由每一个用户按照自己的需求发出请求而特殊制作的Web网页。网络发展前景无限,及早与网络结合,与信息时代同步,与高科技汇合,定会给社会各行各业的发展注入新鲜的活力。站在网络时代的前夜,我们清晰地听到了网络时代的宣言:谁掌握了网络,谁就掌握了未来。第二章 ASP和ACCESS的认识一、ASP的简介:ASP 全称为 Active Server Pages(动态服务器主页),它是一种应用程序环境,可以利用 VBscript 或 Java Script 语言来设计,主要用于网络数据库的查询与管理。其工作原理是当浏览者发出浏览请求的时候,服务器会自动将 ASP 的程序码,解释为标准 HTML 格式的网页内容,再送到浏览者浏览器上显示出来。我们也可以将 ASP 理解为一种特殊的 CGI。利用 ASP 生成的网页,与HTML相比具有更大的灵活性。只要结构合理,一个 ASP 页面就可以取代成千上万个网页。尽管 ASP 在工作效率方面较之一些新技术要差,但胜在简单、直观、易学,是涉足网络编程的一条捷径。它具备一个服务器端的脚本执行环境,用它可产生和执行动态的、交互的、高性能的Web服务器应用程序。Active Server的另一大优点是代码的安全性。页面的访问者所能看到的只是服务器方的处理结果。ASP文件可以用常规的文本编辑器编辑, ASP使用VBScript、JavaScript等脚本语言作为开发工具,镶嵌于HTML文本中,使用"<%>"将ASP的程序包含起来。当用户从浏览器向Web服务器提出请求时,Web服务器会自动将ASP的程序解释为标准的HTML格式的主页内容,用户端只要使用常规可执行HTML程序的浏览器,就可浏览ASP所设计的主页内容,因此与浏览器无关,并且保证了ASP的源程序代码不会外漏。ASP中包括五个内置的ActiveX服务器组件和五个内置的对象:Database Access component(数据库访问组件)、File Access component(文件访问组件)、Ad Rotator component(广告轮播器组件)、Content Linking component(内容链接组件)、Browser Capabilities component(浏览器信组件)以及Request(请求对象)、Server(服务器对象)、Session(会话对象)、Response(响应对象)、Application(应用程序对象)。在所有ASP组件中,最有用的是数据库访问组件,也称为ActiveX数据对象或ADO。在站点发布数据库将使用这个组件及其中包含的对象,以完成对ODBC数据源的读写。此外,ASP技术的另一个重要特点是,程序员可以利用Java、Visual Basic、 Visual C+等语言制作适应自己特殊需要的ActiveX服务器组件来扩充ASP的功能,使自己的动态网页几乎具有无限的扩充能力,这是传统的CGI程序所不及的。总而言之ASP具有学习快、设计快的特点,不需花许多时间即可学会和快速设计出WEB应用程序。ASP的源程序码在服务器端执行,代码保密性好。集成与HTML中,无需编译链接可直接执行,而且使用文本编辑器即可设计。二、ACCESS简介:美国Microsoft公司于1994年推出的微机数据库管理系统。它具有界面友好、易学易用、开发简单、接口灵活等特点,是典型的新一代桌面数据库管理系统。其主要特点如下: 1.完善地管理各种数据库对象,具有强大的数据组织、用户管理、安全检查等功能。 2.强大的数据处理功能,在一个工作组级别的网络环境中,使用Access开发的多用户数据库管理系统具有传统的XBASE(DBASE、FoxBASE的统称)数据库系统所无法实现的客户服务器(Cient/Server)结构和相应的数据库安全机制,Access具备了许多先进的大型数据库管理系统所具备的特征,如事务处理/出错回滚能力等。 3.(3)可以方便地生成各种数据对象,利用存储的数据建立窗体和报表,可视性好。 4.作为Office套件的一部分,可以与Office集成,实现无缝连接。 5.能够利用Web检索和发布数据,实现与Internet的连接。 Access主要适用于中小型应用系统,或作为客户机/服务器系统中的客户端数据库。 用它可以做数据库,还可以用SQLserver,oracle OFFICE 的一员。可以说是一个数据库软件 ACCESS是微软公司出的OFFICE中一个软件 是一个小型数据库 其他小型的数据库还有VFP等 SQL 和ORACLE是大型数据库 做个人网站用ACCES就可以了, 可以实现用户名和密码注册.等的 个人用ACCESS就可以了。 MicrosoftAccess是一种关系式数据库,关系式数据库由一系列表组成,表又由一系列行和列组成,每一行是一个记录,每一列是一个字段,每个字段有一个字段名,字段名在一个表中不能重复。表与表之间可以建立关系(或称关联,连接),以便查询相关联的信息。Access数据库以文件形式保存,文件的扩展名是MDB。Access 数据库由七种对象组成,它们是表、查询、窗体、报表、宏、页和模块。表(Table) 表是数据库的基本对象,是创建其他5种对象的基础。表由记录组成,记录由字段组成,表用来存贮数据库的数据,故又称数据表。查询(Query)查询可以按索引快速查找到需要的记录,按要求筛选记录并能连接若干个表的字段组成新表。窗体(Form)窗体提供了一种方便的浏览、输入及更改数据的窗口。还可以创建子窗体显示相关联的表的内容。窗体也称表单。报表(Report)报表的功能是将数据库中的数据分类汇总,然后打印出来,以便分析。宏(Macro)宏相当于DOS中的批处理,用来自动执行一系列操作。Access列出了一些常用的操作供用户选择,使用起来十分方便。模块(Module)模块的功能与宏类似,但它定义的操作比宏更精细和复杂,用户可以根据自己的需要编写程序。模块使用Visual Basic编程。页是一种特殊的直接连接到数据库中数据的一种WEB页。通过数据访问页将数据发布到Internet 或Intranet上,并可以适用浏览器进行数据的维护和操作第三章 开发环境及需求一、开发目的随着计算机技术的发展,网络技术对我们生活和工作显得月来越重要,特别是现在信息高度发达的今天,人们对最新信息的需求和发布迫切的需要及时性。而动态交互式网页刚好提供了这些功能,本系统就是一个能够在网上实现新闻的网上多用户发布,多栏目管理,实时的进行行为统计和记录的网上交互系统。二、项目背景HTML作为一种样式语言,随着Internet上信息量的增多和交互性的加强使HTML显得越来越难以胜任的情况之下,在ASP编程语言高度发展的形式下,我们开始了对新闻发布系统的开发。三、开发环境1. 开发工具基于Web的系统开发工具应使开发者使用各种各样的技术来创建动态的Web应用程序,并且应是一个可视化的工具。我们采用了DreamweaverMX进行开发,ODBC连接数据库,脚本语言为简单易学的JavaScript或VBScript。2. 运行需求正常使用时不应出错,若运行时遇到不可恢复的系统错误,也必须保证数据完好无损,对数据的精确度、时间特性、适应性等都有一定要求,要求系统运行时能够保证正确性、可靠性、高效性、完整性、易使用性、可维护性、可测试性、复用性、安全保密性、可移植性、互联性。四、系统开发的思想与原则我们开发的是高校科研管理系统的思想是它可以对以下进行操作:1、对教师申报的科研项目进行“立项”、“结项”等工作;2、对教师申报的论文、专著、专利、获奖成果、鉴定成果进行审核工作;3、对科研项目、论文、专著、专利、获奖成果、鉴定成果进行多种单项查询;4、按各个教师进行组合查询(包括科研项目、论文、专著、专利、获奖成果、鉴定成果);5、对系统的各种参数进行设置,包括重设管理员密码;6、对教师信息进行查询、添加、修改和删除。我们对系统开发的原则是:1、必须具有较高的人机交互的灵活性与方便性;2、系统响应时间与信息处理时间必须满足业务的需求;3、由于行业的关系,必须确保数据具有很高的正确性和完善性,不允许出现数据计算错误等情况;第四章 结构设计一、数据库数据只有用数据库来管理才能有自动化管理的可能。数据的结构将影响整个管理机制的应用,而且一但建立以后要修改常会出现麻烦。所以一开始就要仔细慎重地搭建一个完整而合理的结构。Microsoft Access数据库相对其它的数据库来说要简单容易操作些,本科研管理系统中的数据库文件就是Access类型的数据库.以下是本系统与数据库建立连接的ASP源代码<%Dim MM_conn_STRINGMM_conn_STRING = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:kygldatabasescienceitem.asp;Persist Security Info=False"%>二、功能模块流程图科研管理系统后台管理前台显示科研项目科研论文科技著作专利发明获奖项目成果鉴定组合查询个人信息管理登陆退出系统管理系统退出后台参数设置教师信息组合查询鉴定管理获奖管理专利管理专著管理论文管理项目管理参数设置部门项目状态研究类型项目来源项目等级学位职称管理员信息第五章 功能设计一、科研管理系统显示 1.在前台,组合查询模块,单击此模块时进行查询与登陆用户相关的所有信息。2.在前台,个人信息模块,单击此模块时进行查询与登陆用户相关的所有信息,同时在此模块中也可以进行用户的信息的修改和删除等。3.后台登陆界面,要在此模块中输入超级管理员的用户名和密码才可以进入后台中,对系统的各处模块进行管理。4.在后台,参数设置选项中进行(部门、职位、学位、项目等级、项目来源、研究类型、项目状态、管理员管理)查询和增加、修改、删除等操作。二、后台管理我在后台做的是:参数设置1、部门:单击部门时,页面会显示数据库中所有已存在的部门名称,同时也可以单击插入、修改、删除等来跳转到相应的增加、修改页面,去做相应的操作,如果要删除,直接选重要删除的对象,然后再去删除。2、职称:单击职称时,页面会显示数据库中所有已存在的职称名称,同时也可以单击插入、修改、删除等来跳转到相应的增加、修改页面,去做相应的操作,如果要删除,直接选重要删除的对象,然后再去删除。3、学位:单击学位时,页面会显示数据库中所有已存在的学位名称,同时也可以单击插入、修改、删除等来跳转到相应的增加、修改页面,去做相应的操作,如果要删除,直接选重要删除的对象,然后再去删除。同时在系统中还有(项目等级、项目来源、研究类型、项目状态、)的功能也是和这几个模块的功能是相同的。4、管理员:在这个模块中,会显示管理员有用户名和密码,单击修改,可以进行管理的更改,改好的再单击更新按钮。第六章 功能说明一、组合查询模块如图1. 单击给合查询后,右边的页面就会显示用户在此系统中所有的基本信息和所作的科研项目。2.此模块的主要ASP代码:If (session("MM_username") <> "") Then teacher_dept_m_name = session("MM_username")End If%><%Dim t_itemDim t_item_numRowsSet t_item = Server.CreateObject("ADODB.Recordset")t_item.ActiveConnection = MM_conn_STRINGt_item.Source = "SELECT * FROM teacher_dept_item WHERE name = '" + Replace(t_item_m_name, "'", "''") + "'"t_item.CursorType = 0t_item.CursorLocation = 2t_item.LockType = 1t_item.Open()t_item_numRows = 0%>二、个人信息模块如图:1.此模块是显示登陆的用户有个人信息,并可以进行修改和删除。2.个人信息模的主要ASP代码如下:<%Dim MM_keepNoneDim MM_keepURLDim MM_keepFormDim MM_keepBothDim MM_removeListDim MM_itemDim MM_nextItem' create the list of parameters which should not be maintainedMM_removeList = "&index="If (MM_paramName <> "") Then MM_removeList = MM_removeList & "&" & MM_paramName & "="End IfMM_keepURL=""MM_keepForm=""MM_keepBoth=""MM_keepNone=""For Each MM_item In Request.QueryString MM_nextItem = "&" & MM_item & "=" If (InStr(1,MM_removeList,MM_nextItem,1) = 0) Then MM_keepURL = MM_keepURL & MM_nextItem & Server.URLencode(Request.QueryString(MM_item) End IfNextFor Each MM_item In Request.Form MM_nextItem = "&" & MM_item & "=" If (InStr(1,MM_removeList,MM_nextItem,1) = 0) Then MM_keepForm = MM_keepForm & MM_nextItem & Server.URLencode(Request.Form(MM_item) End IfNextstringsMM_keepBoth = MM_keepURL & MM_keepFormIf (MM_keepBoth <> "") Then MM_keepBoth = Right(MM_keepBoth, Len(MM_keepBoth) - 1)End IfIf (MM_keepURL <> "") Then MM_keepURL = Right(MM_keepURL, Len(MM_keepURL) - 1)End IfIf (MM_keepForm <> "") Then MM_keepForm = Right(MM_keepForm, Len(MM_keepForm) - 1)End IfstringsFunction MM_joinChar(firstItem) If (firstItem <> "") Then MM_joinChar = "&" Else MM_joinChar = "" End IfEnd Function%>三、修改个人信息模块的如图:1.此模块的主要代码:在此模块中,如(教师号、姓名、登录密码、)是不能为空的,必须填写。<%If (CStr(Request("MM_update") = "form1" And CStr(Request("MM_recordId") <> "") Then MM_editConnection = MM_conn_STRING MM_editTable = "teacher" MM_editColumn = "id" MM_recordId = "" + Request.Form("MM_recordId") + "" MM_editRedirectUrl = "teacher_list.asp" MM_fieldsStr = "teacherid|value|name|value|deptid|value|pw|value|birthdate|value|sex|value|zhicheng|value|xuewei|value|tel|value|mobile|value|email|value|brief|value" MM_columnsStr = "teacherid|',none,''|name|',none,''|deptid|',none,''|pw|',none,''|birthdate|',none,NULL|sex|',none,''|zhicheng|',none,''|xuewei|',none,''|tel|',none,''|mobile|',none,''|email|',none,''|brief|',none,''" MM_fields = Split(MM_fieldsStr, "|") MM_columns = Split(MM_columnsStr, "|") For MM_i = LBound(MM_fields) To UBound(MM_fields) Step 2 MM_fields(MM_i+1) = CStr(Request.Form(MM_fields(MM_i) Next If (MM_editRedirectUrl <> "" And Request.QueryString <> "") Then If (InStr(1, MM_editRedirectUrl, "?", vbTextCompare) = 0 And Request.QueryString <> "") Then MM_editRedirectUrl = MM_editRedirectUrl & "?" & Request.QueryString Else MM_editRedirectUrl = MM_editRedirectUrl & "&" & Request.QueryString End If End IfEnd If%><%If (CStr(Request("MM_update") <> "" And CStr(Request("MM_recordId") <> "") Then MM_editQuery = "update " & MM_editTable & " set " For MM_i = LBound(MM_fields) To UBound(MM_fields) Step 2 MM_formVal = MM_fields(MM_i+1) MM_typeArray = Split(MM_columns(MM_i+1),",") MM_delim = MM_typeArray(0) If (MM_delim = "none") Then MM_delim = "" MM_altVal = MM_typeArray(1) If (MM_altVal = "none") Then MM_altVal = "" MM_emptyVal = MM_typeArray(2) If (MM_emptyVal = "none") Then MM_emptyVal = "" If (MM_formVal = "") Then MM_formVal = MM_emptyVal Else If (MM_altVal <> "") Then MM_formVal = MM_altVal ElseIf (MM_delim = "'") Then ' escape quotes MM_formVal = "'" & Replace(MM_formVal,"'","''") & "'" Else MM_formVal = MM_delim + MM_formVal + MM_delim End If End If If (MM_i <> LBound(MM_fields) Then MM_editQuery = MM_editQuery & "," End If MM_editQuery = MM_editQuery & MM_columns(MM_i) & " = " & MM_formVal Next MM_editQuery = MM_editQuery & " where " & MM_editColumn & " = " & MM_recordId If (Not MM_abortEdit) Then Set MM_editCmd = Server.CreateObject("ADODB.Command") MM_editCmd.ActiveConnection = MM_editConnection MM_editCmd.CommandText = MM_editQuery MM_editCmd.Execute MM_editCmd.ActiveConnection.Close If (MM_editRedirectUrl <> "") Then Response.Redirect(MM_editRedirectUrl) End If End IfEnd If%>四、管理登陆模块如图:待添加的隐藏文字内容11. 在登陆界面中,要输入用户名和密码,如果不输入或输入错误出现提示错误请从新输入。2. 此模块的代码:<%Dim Recordset1Dim Recordset1_numRowsSet Recordset1 = Server.CreateObject("ADODB.Recordset")Recordset1.ActiveConnection = MM_conn_STRINGRecordset1.Source = "SELECT * FROM admin"Recordset1.CursorType = 0Recordset1.CursorLocation = 2Recordset1.LockType = 1Recordset1.Open()Recordset1_numRows = 0%><%MM_LoginAction = Request.ServerVariables("URL")If Request.QueryString<>"" Then MM_LoginAction = MM_LoginAction + "?" + Server.HTMLEncode(Request.QueryString)MM_valUsername=CStr(Request.Form("textname")If MM_valUsername <> "" Then MM_fldUserAuthorization="" MM_redirectLoginSuccess="admin_index.asp" MM_redirectLoginFailed="loginfail.asp" MM_flag="ADODB.Recordset" set MM_rsUser = Server.CreateObject(MM_flag) MM_rsUser.ActiveConnection = MM_conn_STRING MM_rsUser.Source = "SELECT adminname, adminpw" If MM_fldUserAuthorization <> "" Then MM_rsUser.Source = MM_rsUser.Source & "," & MM_fldUserAuthorization MM_rsUser.Source = MM_rsUser.Source & " FROM admin WHERE adminname='" & Replace(MM_valUsername,"'","''") &"' AND adminpw='" & Replace(Request.Form("textpw"),"'","''") & "'" MM_rsUser.CursorType = 0 MM_rsUser.CursorLocation = 2 MM_rsUser.LockType = 3 MM_rsUser.Open If Not MM_rsUser.EOF Or Not MM_rsUser.BOF Then ' username and password match - this is a valid user Session("MM_Username") = MM_valUsername If (MM_fldUserAuthorization <> "") Then Session("MM_UserAuthorization") = CStr(MM_rsUser.Fields.Item(MM_fldUserAuthorization).Value) Else Session("MM_UserAuthorization") = "" End If if CStr(Request.QueryString("accessdenied") <> "" And false Then MM_redirectLoginSuccess = Request.QueryString("accessdenied") End If MM_rsUser.Close Response.Redirect(MM_redirectLoginSuccess) End If MM_rsUser.Close Response.Redirect(MM_redirectLoginFailed)End If%><%Recordset1.Close()Set Recordset1 = Nothing%>五、参数设置模块:1.在此模块中的参数设置,主要是为像部门、职称、学位、项目来源、项目等级、研究类型,项目状态和管理员设置的。2,此模块的主要类似代码:<%0URL and Form parametersDim MM_keepNoneDim MM_keepURLDim MM_keepFormDim MM_keepBothDim MM_removeListDim MM_itemDim MM_nextItemMM_removeList = "&index="If (MM_paramName <> "") Then MM_removeList = MM_removeList & "&" & MM_paramName & "="End IfMM_keepURL=""MM_keepForm=""MM_keepBoth=""MM_keepNone=""For Each MM_item In Request.QueryString MM_nextItem = "&" & MM_item & "=" If (InStr(1,MM_removeList,MM_nextItem,1) = 0) Then MM_keepURL = MM_keepURL & MM_nextItem & Server.URLencode(Request.QueryString(MM_item) End IfNextFor Each MM_item In Request.Form MM_nextItem = "&" & MM_item & "=" If (InStr(1,MM_removeList,MM_nextItem,1) = 0) Then MM_keepForm = MM_keepForm & MM_nextItem & Server.URLencode(Request.Form(MM_item) End IfNextMM_keepBoth = MM_keepURL & MM_keepFormIf (MM_keepBoth <> "") Then MM_keepBoth = Right(MM_keepBoth, Len(MM_keepBoth) - 1)End IfIf (MM_keepURL <> "") Then MM_keepURL = Right(MM_keepURL, Len(MM_keepURL) - 1)End IfIf (MM_keepForm <> "") Then MM_keepForm = Right(MM_keepForm, Len(MM_keepForm) - 1)End IfFunction MM_joinChar(firstItem) If (firstItem <> "") Then MM_joinChar = "&" Else MM_joinChar = "" End IfEnd Function%><%Recordset1.Close()Set Recordset1 = Nothing%>第七章 结论ASP从推出至今时间也不算漫长,由于它具有开发简单,功能强和灵活等优点,现在已被广泛接受,成为开发动态网络站点的主要技术之一。随着现代信息技术的发展,它将越来越受到人们的关注,21世纪它将成为构筑终身学习体系的主要内容。而基于Web的动态交互式新闻发布系统则是现代网络教育不可缺少的一部份。又由于ASP编程所用的Vbscript 与 Jscript语言较其它语言较简洁、易操作、功能较强非常适合广大用户进行网站的开发。ASP虽然提供了功能强大的Web应用程序开发环境,但和其它技术一样,它也存在着某些缺点,现在越来越多的Web服务器已开始支持ASP。