1、成 都 信 息 工 程 学 院学 位 论 文基于 JSP 的毕业设计选题系统的设计与实现基于 JSP 的毕业设计选题系统的设计与实现摘 要随着全球信息化技术的兴起,特别是 Internet 的日益普及,我国各大中专院校都建立了自己的校园网。毕业生以班级为单位的原始手工报送的选题方式已经不能适应时代发展的需求, 所以基与互联网的毕业设计选题系统也就孕育而生了。毕业设计选题系统就是能够使学生通过互联网完成毕业设计课题的选定,它采用 Web 方式,同时适用于局域网和 Internet,它要实现审核,权限管理,邮件通知等功能,并能提供题目保存、题目查询等功能,该系统同时拥有最开放的题库管理系统和最灵活
2、的选题系统,能够自动进行权限的判断,对用户进行冻结。我们采用了 JSP 技术为主要手段,本系统采用了多级角色管理:包括系统管理员、系主任,学生和老师几种权限.本文主要介绍了用户权限的划分,并详细地论述了系统设计的思想和实现的方法步骤从而为以后的研究打下了基础。关键词: 审核;权限;多级角色管理The Design and Implementation of Subject Selection System for Graduation Based on JSPAbstractWith the rising of global information technology, especially
3、 the growing prevalence of Internet, the technical institute colleges and universities in our country have set up their own Campus Net. For the traditional way of manual submission of selected subject cannot adapt to current demands, the Internet-based graduation subject selection system born. Such
4、system enables students to choose subject for graduation design through Internet. It adopts B/S pattern, and is suitable to both the local area network and Internet. It must implement functions such as the verification of the subject, the jurisdiction management, mail notification, as well as subjec
5、t storage and searching. With the open subject management system and the flexible system, it can automatically verify the jurisdiction of a user and freeze the user. The system adopted the JSP as its main technology, and implemented the multistage role management. The system also implemented the man
6、agement of the privilege of system managers, deans, students and teachers.Key words: Verification; Jurisdiction; Multistage role management.目 录论文总页数:23 页1 引言 11.1 选题系统出现的趋势 11.2 选题系统常用的实现技术 12 基本技术简介 12.1 本系统拟采用的解决方法(技术) 22.2 主要技术简介 23 需求分析与方案设计 .33.1 功能需求分析 33.2 数据库需求 33.3 系统支撑环境 44 系统设计 44.1 功能设计
7、44.2 数据库设计 44.2.1 系统登陆,用户会话表(bsm_session_info) .44.2.2 系统用户信息管理表(bsm_sys_user) .54.2.3 毕业论文题库信息表(subject) 54.2.4 毕业论文选题信息管理表(select_sub) .65 系统功能实现 .75.1 系统组成和业务流程图 75.2 系统用户权限管理 85.2.1 系统登陆 .95.2.2 系统用户管理 .115.2.3 历届信息查看 135.2.4 个人信息维护 135.3 系统选题权限管理 .145.4 教师题库管理 .155.4.1 教师出题 .155.4.2 教师审核题目 .165
8、.5 学生在线选题 .165.6 系统登出 .185.7 系统基本控件使用 .185.7.1 数据库连接池实现 .185.7.2 邮件系统实现 .196 技术难点分析 .20结 论 20参考文献 20致 谢 21附 录 22TOMCAT 简介 .22声 明 23第 1 页 共 23 页1 引言1.1 选题系统出现的趋势在网络飞速发展的今天,互联网成为人们快速获取,发布和传递信息的重要渠道,在人们政治,经济,生活等各方面发挥着重要的作用。因此网站建设在Internet 应用上地位显而易见,它已成为政府,企事业单位信息化建设中的重要组成部分,从而倍受人们的重视。从 20 世纪 90 年代初期随着
9、www 的发展,Internet 逐渐普及化由于 www 通过良好的界面大大简化了 Internet 操作难度使得用户数量急剧增加,许多人开始重视 Internet,发现到 Internet 具有巨大得潜力。于是纷纷大量加入Internet。这样 Internet 上得站点大大增加,网络信息五花八门,十分丰富。如今 Internet 已经深入到人们生活得各个部分。Internet 大大方便了信息的传播,给人们带来了全新得生活方式。这次我们所设计的课题正是互联网与大学生学习生活紧密相关的,现今的社会人们已经离不开网络,传统的选题方式也面临着变革,而网络选题则是一个很重要的方向。基于 Web 技术
10、的网络选题系统可以借助于遍布全球的 Internet进行,因此选题既可以在本地进行,也可以在异地进行,大大拓展了选题的灵活性。题目可以根据题库中的内容生成,从而使用计算机选题大大的提高了选题效率;还可以直接把题目送到数据库中保存,作为老师以后出题的参考。现在较好的选题方式为网络选题,题目内容放在服务器上,学生通过帐号和口令进行登陆,学生也可以第一时间得到选题信息。因此,采用网络选题方式将是以后的大趋势。1.2 选题系统常用的实现技术网络选题系统的实现技术有多种,可以采用传统的客户机/服务器(C/S)型的 MIS 型架构,即论文题目内容放在远程的服务器上,在选题机上安装考试应用程序和数据库客户机
11、配置,因此每次选题时要对机器进行安装、配置,这样一来选题工作比较烦琐;而且选题程序放在客户机上,安全性也受到一定影响。另外一种考试系统采用 Web 技术实现。Web 技术超越了传统的“客户机/服务器”两层结构,采用了三层体系结构:用户界面层/事务层/数据库层。因此Web 结构有着更好的安全性。在用户机上不需要安装任何应用程序,应用程序可以安装在作为服务器的计算机上,题目存放在数据库服务器上(事务层和数据库可以是同一台机器)。2 基本技术简介本系统全称为毕业设计选题系统,开发的目的是为学生提供通过学校的网络进行毕业设计题目的选择。第 2 页 共 23 页2.1 本系统拟采用的解决方法(技术)本系
12、统要求实现网络选题系统的各项基本功能,从安全性和易维护性考虑,选择了 Web 实现技术。简单的说就是将系统做成一种 B/S 模式,可以让用户通过浏览器直接访问位于服务器上的试题以及对系统进行远程维护。服务器端程序的实现技术也很多,本人选用了当前比较流行的网络编程技术JSP 作为主要实现手段(配合 Java Servlet,HTML 等) 。JSP 作为一种Web 实现技术,它的效率是很高的。这一点正好符合了选题系统所要求的实时性。JSP 自身的安全性,再加上实现模式的特点,完全能够达到选题的要求。除此之外,作为 Java 平台的一部分,JSP 拥有 Java 语言“一次编写,各处运行”的特点。
13、又随着越来越多的服务器供应商将 JSP 支持添加到他们的产品中,这样一来用 JSP 做成的这套系统可以轻松移植到其它平台来运行。种种优点使得这套系统不但为目前校内的网络教学以至于今后远程教育的实现都打下了良好的基础。所以 JSP 是实现本系统的最佳技术,它是完全可行的。2.2 主要技术简介JSP 是 Java Server Pages 的简称,它是由 Sun Microsystem 公司于 1999年 6 月推出,是基于 Java Servlet 以及整个 Java 体系的 Web 开发技术。作为J2EE 体系中的重要一环,JSP 为创建高度动态的 Web 应用提供了一个独特的开发环境。JSP
14、 能够适应市场上包括 Apache WebServer、IIS4.0 在内的 85的服务器产品,这足以胜任绝大多数的商业事务处理。同时 JSP 代码经过服务器的解释执行后会直接嵌入到 HTML 语言中,这样就简化了页面的输出,也保留了脚本语言易于使用的优点。SUN 公司开发出这个规范来整合和平衡已经存在的规范,对 JAVA 编程环境进行支持的技术和工具。其结果是产生了一种新的,开发基于 WEB 应用程序的方法,给予使用基于组件应用逻辑的页面设计者以强大的功能支持。JSP 设计目标是为了使动态页面编写更容易,更简单。JSP 特点主要有以下几点:到处可执行,JSP 技术完全与平台无关的设计,包含它
15、的动态网页和底层 Server 元件设计,加强元件功能,更容易建立动态网页。JDBC 是 Java Data Base Connectivity 的简称,也就是 java 数据库连接。它是一种用于执行 SQL 语句的 Java API,可以为多种关系数据库提供统一访问,它由一组用 Java 语言编写的类和接口组成。JDBC 提供了一种基准,据此可以构建更高级的工具和接口,使数据库开发人员能够编写数据库应用程序。将Java 语言和 JDBC 结合起来使程序员只须写一遍程序就可以让它在任何平台上运行,这也是 Java 语言“编写一次,各处运行“的特点。同时 JDBC 扩展了 Java 的功能。例如
16、,用 Java 和 JDBC API 可以发布含有 applet 的网页,而该 applet 使用的信息可能来自远程数据库企业也可以用 JDBC 通过 Intranet 第 3 页 共 23 页将所有职员连到一个或多个内部数据库中。3 需求分析与方案设计3.1 功能需求分析作为高校毕业生的一个毕业设计选题系统,它就面对着许多用户的操作,而这些用户对系统的操作应该有所不同,所以我们在设计时必须要对不同的用户设立不同的的权限。在本系统中,我考虑了 4 种权限(管理员,系主任,指导教师,学生) 。管理员可以添加的用户系主任,而系主任能添加的用户为指导教师和学生。同时,我们为了使本系统更加的符合我们的
17、实际,教师能在线出题,但是所出的题目必须经过系主任的审核后学生才能进行选择。在学生的选题中,在实现选题的基础上,也要考虑学生选择志愿的顺序,所以在学生的选择过程中,要设立多个志愿,但是在教师的审核过程中,我们必须根据学生的志愿依次进行审核。也就是说在学生的第一志愿未被审核的时候,第二志愿的老师不能对该生的第二志愿进行审核。3.2 数据库需求在信息世界中,信息从客观事物出发流经数据库,通过决策机构最后又回到客观世界,信息的这一循环经历了三个领域:信息世界,数据世界,现实世界。现实世界的事物反映到人的头脑中,人的大脑对它有个认识过程,经过分析(选择、命名、分类等)进入信息世界。这些信息再进一步加工
18、、编码,然后进入数据世界,而软件系统的开发工作需要考虑这两个方面的问题,也就是要考虑系统开发所需要的数据,以及如何对这些数据进行操作。这两个问题贯穿了整个软件系统的开发过程,这也就是数据库的设计问题,软件设计的一个核心。作为一个具有一定应用价值的教学管理系统,从本质上说其操作的对象为数据库中存储的具体记录。因此,不仅要求所使用的数据库系统具有比较高的稳定性、安全性及高负载下保持足够相应的能力,还要求设计者清楚需求,做出科学的数据库逻辑结构设计,以提高数据库的利用效率和减少数据冗余。用户的需求具体体现在各种信息的提供、保存、更新和查询,这就要求数据库结构能充分满足各种信息的输入和输出。收集基本数
19、据、数据结构及数据处理的流程,组成一份详尽的数据字典,为后面的具体设计打下基础。数据库的概念结构设计完毕以后,现在可以将上面的数据库概念结构转化为某种数据库系统所支持的实际数据模型,也就是数据库的逻辑结构。数据库系统的选用需要根据系统的需求而定。该系统主要涉及到几种信息的存储,首先是毕业班学生的信息,论文的题目第 4 页 共 23 页信息,学校指导教师和系主任的信息,所以每个信息保存在一张表中,在对表的操作中可以对任意一个表独立操作,也可以对几个表关联操作。3.3 系统支撑环境1)操作系统:WINDOWS 20002)应用服务器:TOMCAT 5.0.283)数据库:SQL20004)JAVA
20、 VM:JDK 1.4.2_075)硬件:建议内存在 512M 以上4 系统设计4.1 功能设计在线选题系统的功能主要包括三部分:用户管理、教师题库信息管理、学生在线选题信息管理。其软件设计结构图结构如图 1:毕业设计选题系统管理员系主任老师学生增加系主任信息系统维护增加老师,学生信息审核老师的出题录入毕业设计题审核学生选题网上选题查看历年的选题图 1:系统总结构设计图4.2 数据库设计4.2.1 系统登陆,用户会话表(bsm_session_info)表 1:用户会话表第 5 页 共 23 页4.2.2 系统用户信息管理表(bsm_sys_user)表 2:系统用户信息管理表4.2.3 毕业
21、论文题库信息表(subject) 编号 项目名 字段名 主键/外键 类型 内容作 用 可否为空1 用户编号 user_no numeric(18, 0) not null2 用户会话 id session_id varchar(32) not null3 用户 ip 地址 visit_address varchar(15) not null4 当前登陆时间 login_date varchar(25) not null5 上次登陆时间 last_update varchar(25) not null编号 项目名 字段名 主键/外键 类型 内容作用 可否为 空1 用户编号 user_no num
22、eric(18, 0) 系统自增字段 not null2 用户帐号 user_code PK varchar (20) not null3 姓名 user_name varchar (50) not null4 密码 passwd varchar (32) not null5 邮箱 user_mail varchar (100)6 联系方式 user_phone varchar (20)7 用户状态 user_stat char (1)1 正常用户 2 冻结用户not null8 用户类型 user_type char (1)0 管理员1 系主任2 指导教师3 学生not null9指导学生人
23、数上限 stu_num Varchar(10)该字段主要控制指导教师10 备注 remark varchar (500) not null11 操作人员编号 op_no numeric(18, 0)控制数据操作权限not null12 操作时间 op_time varchar(25) not null第 6 页 共 23 页表 3:毕业论文题库信息表4.2.4 毕业论文选题信息管理表(select_sub)表 4:毕业论文选题信息表编号 项目名 字段名 主键/外键 类型 内容作用 可否为 空1 选题编号 select_no numeric(18, 0) 系统自增字段 not null2 教师编
24、号 teacher_no numeric(18, 0) bsm_sys_user表中 user_no not null3 题目编号 sub_no numeric(18, 0)Subject 表中sub_nonot null4 学生编号 stu_no numeric(18, 0) bsm_sys_user表中 user_no not null5 教师审核标志 postil_flag char(1) null6指导教师审核意见 postil varchar(200)0 未审核1 审核通过2 审核未通过null7 年 级 yearl char(4) not null8 志愿标志 wish_flag
25、char(1) null编号 项目名 字段名 主键/外键 类型 内容作用 可否为空1 题目编号 sub_no numeric(18, 0) 系统自增字段 not null2 题目名称 sub_name varchar (100) not null3 教师编号 teacher_no numeric(18, 0) bsm_sys_user表中 user_no not null4参与学生的上限 part_in_no numeric(2, 0) not null5 题目内容 sub_viscera varchar(1000) not null6 主任审核标志 postil_flag char(1)0
26、未审核1 审核通过2 审核未通过null7 主任审核意见 postil varchar(200) null8 年 级 year char(4) not null9 操作人员 op_no numeric(18, 0) not null10 操作时间 op_time varchar(25) not null第 7 页 共 23 页9 选择理由 wish varchar (500)1 第一志愿2 第二志愿3 第三志愿4 其他志愿null10 操作人员 op_no numeric(18, 0) not null11 操作时间 op_time varchar(25) not null5 系统功能实现5.
27、1 系统组成和业务流程图系统组成和业务流程图(一)系统组成本系统由四个子模块组成:系主任管理,教师出题,学生在线选题和系统的维护。它们各自功能如下叙述:(1)学生在线选题学生通过系主任录入的学生信息,姓名,学号和密码登陆系统进行查询题目并且进行选题并且可以修改自己的登陆密码。系统分配给学生 4 个选题项,学生可以根据自己的实际情况做出几个选择,当第一志愿未被审核,其他的就不能审核,第一志愿审核未通过自动指向第二志愿,依次类推,如果全部都没有通过学生将重新选择过程同上。学生还可以查看历届的毕业设计题目以做参考。(2)教师出题此部分主要由教师使用,教师信息由系主任录入,教师必须通过系住任给其分配的
28、帐号,密码登陆次系统。当教师进入次系统后便由教师负责出题,并且对学生选题进行审核,并且可以查看历届题目作为参考。(3)系主任管理系主任由此批量录入学生以及教师信息并负责进行对教师所出的题目进行审核,只有审核通过的题目学生才可以进行选题,同时系主任还拥有对教师和学生帐号进行冻结的权限。(4)管理员系统管理员主要负责进行对系主任的资料录入并可以冻结。(二)业务流程图:用户系统用户管理个人信息管理登录系用户管理论文题目审查历届信息查询个人信息维护论文题库管理论文选题审查历届信息查询个人信息维护论文选题历届信息查询个人信息维护身份认证系统管理员系主任指导老师学生图 2:业务流程图5.2 系统用户权限管
29、理本系统分为 4 个模块,系主任管理,教师出题,学生在线选题和管理员模第 8 页 共 23 页块。系统用户管理的基本处理流程是:1 管理员权限在建立数据库时初始化数据库脚本创建,管理员登陆后可以对自身的信息进行维护,同时还可以为不同系的系主任分配帐号,以及对系主任信息进行维护。2 各系主任登陆系统后可以对自身的信息进行维护,以及为本系的教师和学生创建系统用户,各系只能查看本系的相关信息。系统用户管理结构如图 3:管理员系主任指导老师 学生分配任务认证选题管理用户信息1N1N1 N图 3:用户管理表由上图分析,本系统共有四种角色,所以系统在实现过程中根据用户角色判断其所拥有的权限, (根据 SQ
30、L 判断) 。1)系统管理(bsm_sys_user.user_type = 0)2)系主任(bsm_sys_user.user_type = 1)3)指导教师(bsm_sys_user.user_type = 2)4)学生(bsm_sys_user.user_type = 3)5.2.1 系统登陆为了保证用户信息的一致性、用户操作的方便性以及方便系统的安全模块升级和维护,该系统采用单点登陆的模式。系统主页:http:/10.0.0.11:8080(服务器在 10.0.0.11 上)如图 4:第 9 页 共 23 页图 4:系统主页页面功能:1 通知信息点击页面下方的“关于网上报毕业设计题目的
31、通知”可以查看网上毕业论文选题信息的相关信息。2 系统用户登陆a).正确的选择用户类型、输入用户名和密码就可以进入系统用户管理信息界面。b).当输入系统不存在的帐号进行登陆时,系统将提示拒绝登陆并提示用户登陆帐号不存在。c).如果用户为学生类别,当他选择用户类型为非学生类型的其他类型时系统拒绝其登陆并显示登陆帐号和用户类型不匹配。d).当用户选择的类型正确,帐号也正确但密码错误系统将提示用户使用帐号密码错误,请核对信息后重新登陆。1 注册会话信息HttpSession currentSession = request.getSession(false);currentSession = req
32、uest.getSession(true);第 10 页 共 23 页currentSession.setAttribute(“userNo“,userNo);/保存用户编号currentSession.setAttribute(“userName“,userName);/保存用户姓名currentSession.setAttribute(“userCode“,userCode);/保存用户帐号currentSession.setAttribute(“userType“,userType);/保存用户类型currentSession.setMaxInactiveInterval(-1);/设定
33、页面会话永不失效,直到关闭String sessionId = currentSession.getId();currentSession.setAttribute(“session_id“,sessionId);String remoteIp = request.getRemoteAddr();currentSession.setAttribute(“login_ip“,remoteIp);/增加用户会话LoginHome.addUserSession(userNo,sessionId,remoteIp);同时将信息增加到用户会话信息表 bsm_session_info 中5.2.2 系统用
34、户管理a).系统用户信息管理1.权限控制(如图 5)只有系统管理员和系主任具有对用户信息的操作权限,其他人员没有操作权限,代码在 jsp 中实现: if(!(userType.equals(“0“)|userType.equals(“1“)throw new DataException(“对不起没有查看权限!“);系统管理员和系主任同时公用同一组界面,但在界面上对操作权限也进行了控制。实现代码:第 11 页 共 23 页图 5:系统用户管理界面2.页面功能查询选择不同条件进行组合查询,就可以查询出相关的用户信息。增加点击“增加”按钮进入“增加用户”信息界面,见图 6:图 6:增加用户界面增加用
35、户操作只有两种权限拥有,一个为系统管理员,一个为系主任。管理员负责添加系主任的信息而系主任负责添加指导教师和学生的信息,当系主任该功能只有系主任才能使用该功能只会在主任操作时出现,同时只有用户类型为指导教师时使用第 12 页 共 23 页添加用户时会多出一个指导学生人数选项,它是限定老师所带的学生的人数。添加成功后信息通过电子邮件的形式发送给用户,并且由系统随机生成密码。实现代码:if(myForm.user_type.value =“2“)stu_num_id.innerHTML=“人“;if(myForm.user_type.value =“3“)stu_num_id.innerHTML=
36、“人“;修改管理员和系主任还拥有修改用户信息的功能,但系主任与管理员相比增加了修改老师能够指导的学生的人数的选项。邮件可以单独给某一用户发送邮件。冻结当系统用户的帐号到期,管理员和系主任就要对用户信息冻结。当用户进入系统时系统将提示该帐号被冻结。我们设计这系统是考虑的是冻结用户帐号而不是删除它冻结后系统将避免不必要的信息丢失。导入当系主任输入教师学生信息时由于输入信息量太多一个一个的输入不太现实在这里我们添加了文件导入的功能。如图 7:图 7:导入用户信息界面5.2.3 历届信息查看历届信息查看功能是对历年作过的毕业设计做的统计进行备份记载,它是为了方便教师和学生查询以做出题和选题参考,还为系
37、主任对题目的审核提供参考。第 13 页 共 23 页5.2.4 个人信息维护 当用户进入系统后可以通过点击“个人信息维护”对自己的个人信息进行修改,可以修改密码,邮箱联系方式等个人资料,见图 8:图 8:个人信息维护5.3 系统选题权限管理拟定教师拟订毕业设计题目,并提交系主任审核。审核系主任审核题目并对题目进行评定,供学生选择。选定学生选择系主任审核过后的题目,学生可以根据个人爱好与实际情况选择第一,第二,第三和其他四个志愿等待老师审核。审批老师根据对学生选择的题目进行审核决定学生最后的毕业论文课题。详细的设计流程图见下图 9:。图 9:选题权限管理图审核功能实现:系主任通过点击“审核”对教
38、师出的题目进行审核(见图10):1.拟定(指导教师)4.审批 ( 指导教师)2.审核(系主任)3.选定(学生)第 14 页 共 23 页图 10:论文题目审核管理界面进入审核页面(见图 11):图 11:审核界面5.4 教师题库管理教师作为系统的一个用户,进入系统后能进行题目的录入及修改,能对学生的选题进行审核,以及修改自己的个人信息等功能。5.4.1 教师出题教师作为系统的一个用户,他可以录入论文题目的信息。录入的题目必须经过系主任的审核后学生才能进行选择。录入如图 12:图 12:教师录入题目界面第 15 页 共 23 页5.4.2 教师审核题目 教师审核题目是学生选择了老师的题目后,老师
39、根据学生所选择的志愿的先后顺序来进行审核的,也就是说学生的第一志愿在未经审核或审核通过后,第二志愿的老师不能进行审核操作。如图 13:图 13:教师审核管理界面进入审核界面:如图 14:图 14:教师审核界面5.5 学生在线选题学生在本系统中,可以对毕业设计题目进行增加,修改以及查看历史信息和修改个人信息等操作。如图 15:第 16 页 共 23 页图 15:毕业论文选题信息管理界面页面功能:查询:可以查看学生自己已经选择的论文题目。增加:可以增加自己的论文题目,但必须是在自己所选的题目未被老师审核的情况下。删除:可以删除未被老师审核的论文题目。修改:可以修改自己的论文题目以及志愿信息。进入增
40、加页面: 图 16:毕业论文选择界面论文选择后,等待老师的审核。可以增加自己的论文题目第 17 页 共 23 页5.6 系统登出当用户进行完他的系统操作后他就要通过点击“退出系统”退出系统当他将退出系统后系统将自动注销 session。5.7 系统基本控件使用系统的数据库连接池、邮件系统和数据导入功能的实现主要是使用第三方组件进行开发,例如数据库连接池主要使用msbase.jar,mssqlserver.jar,msutil.jar,邮件系统主要使用mail.jar,activation.jar,数据导入时,使用的文件上传的组件 commons-fileupload-1.0.jar。5.7.1
41、 数据库连接池实现/新建连接池dataSource = new BasicDataSource();dataSource.setDriverClassName(“com.microsoft.jdbc.sqlserver.SQLServerDriver“);dataSource.setUrl(“jdbc:microsoft:sqlserver:/localhost“+“:“+this.dbport+“;DatabaseName=“+this.dbname);dataSource.setMaxActive(200);dataSource.setMaxIdle(150);dataSource.set
42、MaxWait(-1);dataSource.setRemoveAbandoned(true);dataSource.setRemoveAbandonedTimeout(60);dataSource.setLogAbandoned(true);dataSource.setUsername(this.username);dataSource.setPassword(this.password);/* 释放数据库连接* param conn 欲释放回连接池的连接*/Public void freeConnection(Connection conn, String clsName)tryif (c
43、onn != null)第 18 页 共 23 页conn.close();conn = null;String num = (String)connOutMap.get(clsName);if (num=null) num = String.valueOf(0);else num = String.valueOf(Integer.parseInt(num)+1);connOutMap.put(clsName,num);catch (Exception ex)ex.printStackTrace();5.7.2 邮件系统实现核心代码:private MimeMessage mimeMsg =
44、null; /MIME 邮件对象private Session session = null; /邮件会话对象private Multipart mp = null; /Multipart 对象,邮件内容,标题,附件等内容均添加到其中后,再生成 MimeMessage 对象mimeMsg.setContent(mp);mimeMsg.saveChanges();System.out.println(“正在发送邮件“);Session mailSession = Session.getInstance(props,null);mailSession.setDebug(DEBUG);mimeMsg
45、.saveChanges(); /存储邮件信息Transport transport = mailSession.getTransport(“smtp“); transport.connect(smtpServer, username, password);transport.sendMessage(mimeMsg,mimeMsg.getRecipients(Message.RecipientType.TO);System.out.println(“发送邮件成功!“);mailSession = null;transport.close();第 19 页 共 23 页6 技术难点分析本系统采用
46、 MVC 的架构,它可以解决完全由 JSP 或完全由 servlet 实现的应用程序中的固有的问题。也就是解决了用 JSP 很难将内容同内容的显示分开和很容易将 Java 代码同 HTML 混在一起的问题。这样做出来的系统易于维护。在数据处理上选用 DAO 的数据处理模式,就是建立一个接口,接口中定义了此应用程序中将会用到的所有事务方法。在这个应用程序中,当需要和数据源进行交互的时候则使用这个接口,并且编写一个单独的类来实现这个接口在逻辑上对应这个特定的数据存储。把对数据库的操作全部封装在 DAO 里面,这样便于以后系统数据库的升级。本系统要求实现管理员、院系领导、指导教师和学生的不同操作,所
47、以控制好用户的权限操作是我们本系统重点中的重点。结 论本系统基本上实现了毕业论文选题系统的功能,本系统首先实现了动态的更新内容,如更新学生信息,管理员信息,论文信息等。要保持良好的动态性就要求与数据库有良好的连接。本系统还实现了交互性,交互性就是指教师和学生之间能进行信息交流,另外学生在使用系统时实现了学生操作系统方便操作界面美观,实现系统安全性可靠性避免他人进入系统破坏系统信息。这次的毕业设计选题系统虽然实现了一些功能但是还是存在一些问题和缺陷,但是我还是通过亲自参加毕业设计使自己的知识得到提高,并且我充分体会到理论与实践之间的重要联系,更一步的了解了 JAVA 和数据库的知识。毕业设计就是
48、我们大学四年学习的总结,让我更清楚的认识到了自己的。参考文献1 耿详义.JSP 实用教程 M.北京:清华大学出版社,2003。2 张跃平.JAVA2 实用教程 M.北京:清华大学出版社,2004。3 朱洪江.Java Servlet & JSP 经典实例 M.北京:中国电力出版社,2005。4 卢银鹃.JSP 网络开发技术 M.北京:人民邮电出版社,2001。5 李盛恩.数据库基础与应用 M.北京:人民邮电出版社,2002。6 李洪成.tomcat 与 java Web 开发技术详解M.上海: 电子工业出版社,2006。7 张怀中. 常用工具软件实用教程 M.北京:中国水利水电出版社,2004
49、。8 周良中. Eclipse 插件开发.北京:人民邮电出版社,2005。第 20 页 共 23 页致 谢本文是在郭涛老师和王燚老师的热情关心和指导下完成的,他渊博的知识和严谨的治学作风使我受益匪浅,对顺利完成本课题起到了极大的作用。在此向他表示我最衷心的感谢!在论文完成过程中,本人还得到了杨林老师和许多同学的热心帮助,本人向他们表示深深的谢意!最后向在百忙之中评审本文的各位专家、老师表示衷心的感谢!作者简介:姓 名:曾建文 性别: 男出生年月:1983.10.19 民族: 汉E-mail:第 21 页 共 23 页附 录Tomcat 简介Tomcat 是一个免费的开源的 Servlet 容器。与传统的桌面应用程序不同,Tomcat 中的应用程序是一个 WAR(Web Archive)文件。WAR 是 Sun 提出的一种Web 应用程序格式,与 JAR 类似,也是许多文件的一个压缩包。这个包中的文件按一定目录结构来组织:通常其根目