基于JSP的私人牙科诊所管理系统

智术园

发布日期: 2020-07-31 16:55:31 浏览量: 39
评分:
star star star star star star star star star star_border
*转载请注明来自write-bug.com

摘 要

随着科技的飞速发展,计算机已经广泛的应用于各个领域之中。在医学领域中,计算机主要应用于两个方面:一是医疗设备智能化,以硬件为主。另一种是病例信息管理系统(HIS)以软件建设为主,以提高私人牙科诊所病例的现代化管理水平。本次毕业设计的主要任务是基于B/S模式开发设计一个私人牙科诊所病例管理系统以提高私人牙科诊所病例的现代化管理形象。该系统包括药品管理、挂号管理、开药管理和药房管理四个部分,可以实现药品、患者的录入、删除、修改和查询等功能,特别适应各大中小型私人牙科诊所病例,提高私人牙科诊所病例管理水平,系统设计合理操作简便。

本文采用面向对象分析的方法,详细阐述了一个功能比较强大的牙科诊所管理系统的前后台开发,操作流程和涉及的一些关键技术。首先进行了可行性分析,然后是面向对象分析,通过实际的业务流程需要,抽取和整理用户需求,建立了问题域精确模型;然后是面向对象设计阶段,主要是把分析阶段得到的对目标系统的需求转变成符合成本和质量要求的,抽象的系统实现方案,阐述了系统设计的思想,数据库的设计和系统设计的工具及技术。该阶段对本系统各个对象的属性和方法进行了详细设计,建立了本系统的对象模型,形成了本系统的类图;数据库设计时先进行了概念结构设计,然后进行了逻辑结构设计,最后完成了数据表的设计。

根据前几个阶段的分析和设计,本系统在设计方面采用B/S模式,同时使用JSP技术进行基本页面的设计与功能实现,后台数据库选用MySQL数据库。本系统的设计实施为牙科诊所管理系统的运行做基础,为牙科诊所管理系统工作提供良好的条件。

关键词:牙科诊所病例门诊管理;JSP;B/S模式

ABSTRACT

With the rapid development of science and technology, computers have been widely used in various fields. In the field of medicine, computers are mainly applied to two aspects: one is the intelligence of medical equipment and the hardware. The other is the case information management system (HIS), which focuses on software development to improve the level of modern management of cases in private dental clinics. The main task of this graduation design is based on B/S pattern development and design a private dental clinics case management system in order to improve the modern management image of the private dental clinic cases. The system includes drug management, register management, prescribe medicine and pharmacy management four parts, of drugs, patients can be accomplished by the input, delete, modify, and query, and other functions, especially for the small and medium-sized private dental clinic cases, improve the level of private dental clinics case management, reasonable system design is simple.

This article adopts the method of object-oriented analysis, elaborated the function of a more powerful Taiwan before and after the development of the dental clinic management system, operation process and some of the key technologies involved. First has carried on the feasibility analysis, then the object-oriented analysis, through the actual business process needs, extract and user needs, set up the precise model the problem domain; Then the object-oriented design phase, mainly with the analysis phase of the demand for the target system into conformity with the requirements of the cost and quality of abstract system implementation plan, expounds the ideas of system design, database design and system design tools and techniques. In this phase, the object model of the system is set up, and the class diagram of the system is formed. The design of the conceptual structure was carried out first, then the logical structure design was carried out, and the design of the data table was completed.

According to former several stages of the analysis and design, this system adopts B/S mode in terms of design, and using JSP technology of basic pages design and function implementation of background database choose MySQL database. The design of this system is implemented as the basis for the operation of the dental clinic management system, and provides good conditions for the operation of the dental clinic management system.

Key words: the patient outpatient clinic administration; JSP; B/S pattern

1.引言

私人牙科诊所病例信息系统(HOSPITAL INFORMATION SYSTEM)简称HIS,是私人牙科诊所病例实现现代化建设的重要基础工程,是提高私人牙科诊所病例管理水平、医疗水平、业务运转效率和服务质量的必要手段,是指应用电子计算机和网络通信设备,对私人牙科诊所病例的病人医疗信息、财务核算分析信息、预约信息进行收集、存储、处理、提取和数据通讯,满足所有授权用户对信息使用需求的计算机应用软件系统。

1.1 项目开发的背景

随着计算机产业的迅速发展,电子计算机已广泛的应用于信息管理,文字处理,辅助设计,辅助教学及人们的日常生活中。牙科诊所管理系统主要针对各医院门诊管理的一系列相关工作的管理,本系统的建立使得牙科诊所的管理更加规范化,系统化,查询手段更加便捷化。同时,本系统采用面向对象的开发方法,进一步解决了结构化范性存在的软件重用程度低,软件产品难以维护的问题。

近年来,随着就诊的病人的数量的逐渐增加,人工书写数据已经不能够处理如此庞大的数据。为了更好的适应信息时代的高效性,一个利用计算机来实现牙科诊所管理系统工作的系统必然诞生。基于这一点,所设计的牙科诊所管理系统用来就诊所进行管理,以便在最短时间内,高效准确的完成整个管理过程。

基于上述认识,收集相关资料和数据,查阅有关文献及技术参数,对用户需求进行调研,发现目前所采用的手工记录的方法进行管理存在对象范围广,数据存储不易,不易存档,成千上万的信息和堆积如山的单据对管理人员来说是个负担,需要大量的文档资料。而已经存在的一些面向过程设计的诊所管理系统软件重用程度低,软件产品不易维护。鉴于上述种种原因,牙科诊所管理急需一种面向对象的设计的软件来管理数据资料。

计算机技术在现代管理中的应用,使计算机成为领导者和管理人员应用现代技术的重要工具。计算机辅助门诊管理活动,可以极大地增强管理者采集,处理信息的能力,从而有利于管理者及时决策。计算机系统能根据管理过程的变化情况,将原始数据,资料等进行加工,保存,管理人员可以在解决具体问题需要信息资料时,随时进行检索查询,了解整个牙科门诊管理系统的动态情况,进行动态管理,从而有效的处理牙科门诊的管理工作,实现牙科诊所管理的自动化,提高效率。

1.2 项目开发的目的

牙科诊所管理系统的开发目的是使得牙科诊所管理系统模式从手工记录转变成信息管理,从面向过程开发的软件转变成面向对象开发的软件,为门诊管理人员提供方便,为软件维护工作人员提供方便。对用户的实际情况进行调研,进行详细的需求分析,对现有的管理模式进行改进,开发出一套新型的面向对象的管理系统,从中领悟系统开发的思想,掌握系统开发的流程和方法。随着门诊信息系统的不断完善,医院的管理将越来越依赖于信息化的管理。所以系统开发将围绕牙科门诊工作的实际情况,使之能迅速适应各牙科诊所的需要。

牙科诊所管理系统的实现的现实意义:减少管理诊所的工作人员;管理人员可以随时浏览查看,而且更加直观;改变了以前工资手工记录的方式,电脑录入更加快捷方便;实现了门诊管理系统的计算机化。

随着私人牙科诊所病例数字化建设的蓬勃发展,数字化私人牙科诊所病例的理念已经被广大私人牙科诊所病例所接受,目前面临的主要问题是如何去建设数字化私人牙科诊所病例。

因此,目前我国数字化私人牙科诊所病例的建设重点必须以医疗数字化为主,即着重发展私人牙科诊所病例内与医疗活动相关的各类信息的数字化管理和综合利用,实现诊疗工作的数字化以及医疗流程的自动化,并保证系统的开放性,为将来扩展到区域医疗打下基础。相应地,医疗信息系统作为数字化私人牙科诊所病例建设的系统基础,它的研究重点也将转为面向纯粹医疗活动的各类医疗信息系统及其集成研究。以医疗数字化为建设重点的数字化私人牙科诊所病例的总体规划,它通过各类医疗信息系统的有机集成而实现。可以说,新一代医疗信息系统将在“数字化私人牙科诊所病例”的建设中发挥举足轻重的作用。

1.3 结构概述和技术介绍

1.3.1 JSP概述

JSP是服务器端脚本环境可以用来创建交互式Web应用程序。当服务器收到对JSP文件的请求时,它处理包含在用于构建发送给浏览器的Web页文件中的服务器端脚本。除服务器端脚本外,JSP文件也可以包含HTML(包括相关的客户端脚本)和COM组件调用,这些组件可执行不同任务,如连接到数据库或处理商业逻辑。

  • 对于HTML创作者:HTML创作者,将会发现用JSP编写服务器端脚本可使创建更为复杂、使用的Web应用程序变得十分简单。JSP对于将HTML表单信息存储在数据库中、根据访问者的自选项自定义Web站点或对不同的浏览器使用不同的HTML功能,提供了优异的解决方案。例如,从前要在Web服务器上处理用户输入,必须首先用Perl或C等语言建立传统的公共网关接口(CGI)应用程序。而使用JSP后,仅通过在HTML文档中直接嵌入的简单服务器端脚本,便可以收集HTML表单信息,并传递到数据库。如果已熟悉Microsoft JSPScript或Microsoft(r)Jscript,那么学习JSP将不会感觉到困难

  • 对于高级Web脚本语言编写者:由于JSP使用了中性语言,因此只要熟悉JSPScript、Jscript或PERL等脚本语言,就了解了JSP的使用方法。在JSP页中,可以使用已经装有COM脚本兼容编辑引擎的任何脚本编辑语言。JSP使用java和Jscript脚本引擎,但仍可安装用于PERL、REXX和Python的脚本引擎,他们可从第三方供应商处获得

  • 对于Web开发和编程人员:如果使用Visual Basic、C++或Java等编程语言开发过后端Web应用程序,将会发现JSP是创建Web应用程序灵活而快速的方法。除了添加脚本为应用程序创建HTML界面之外,还可以建立自己的COM组件。可以将应用程序的商业逻辑封装在可重复使用的模块中,以便在脚本、其他组件或其他程序中调用

  • Active Server Pages模型:当浏览器向Web服务器请求.JSP文件时,服务器断脚本便开始运行。于是Web服务器调用JSP,用它从头至尾处理所请求的文件、执行脚本命令,并将Web页发送到浏览器。因为脚本运行于服务器而不是客户端,所以Web服务器负责生成发送到浏览器的HTML页等工作。服务器端脚本无法被预先复制,因为返回到浏览器的只是脚本的运行结果,用户无法得知当前页面的脚本命令

1.3.2 JSP的新特性

JSP新增了许多特性,有助于轻松编写脚本和开发Web应用程序。

  • 新的流控制能力:JSP的Server对象具有两种可用来控制程序流的新方法:Server .Transfer 和Server .Execute。与重定向请求(需要往返于客户端)不同,使用这些方法可将请求直接传送到.JSP文件,而不需要离开服务器

  • 错误处理:JSP具有新的错误处理能力,可以使用自定义的错误信息.JSP文件来捕捉错误,也可以使用新的Server.GetlastError方法来显示有用信息,如错误描述或发生错误的行号

  • 无脚本:通常JSP静态内容的处理速度快于服务器端内容的处理速度,因此以前只将.JSP文件扩展名指派给包含JSP功能性的文件。无论何时,如果需要在静态.html文件中添加JSP,只能手工添加.JSP文件扩展名并修正相关超级链接。不过,在JSP的最新版本中,不包含服务器端功能性的.JSP文件的处理速度比以前快了许多。因此,如果正在创建展开的Web应用程序并且其中的文件最终可能需要JSP功能性,现在就可以很方便地为这些文件指派.JSP文件扩展名,而不必考虑他们是否包含静态或服务器端内容

  • 性能增强的对象:JSP提供流行的可安装组件的性能怎增强版本。这些对象能够可靠的使用与各种Web发布环境

  • XML集成:XML(扩展表及语言)允许描述复杂的数据结构或文档,可以在各种应用程序、客户端和服务器之间共享此信息。使用Microsoft Internet Explorer 4.0或根高版本附带的Microsoft XML Parser,可以创建服务器端应用程序,该应用程序允许Web服务器与Internet Explorer4.0(或更高版本)或任何包含XML结息能力的服务器交换XML格式的数据

  • Windows脚本组件:JSP支持Microsoft强大的脚本新技术——Windows脚本组件。现在可以将商业逻辑脚本过程转换为可以重复使用的COM组件,该组件可用于Web应用程序和其他组件对象模型(COM)适用的程序

  • 确定浏览器能力的新方法:JSP具有可确定浏览器准确能力的新特性。当浏览器发送能描述其能力的Cookie(可通过使用简单的客户端脚本来安装这样的Cookie)时,可以创建一个“浏览器能力组件”实例,以便检索随Cookie返回的浏览器属性。可以使用此特性来确定浏览器能力并对应用程序做相应调整

  • JSP自动调整:JSP现在可以检测执行请求何时被外外部资源阻断,并自动提供更多县城以便同时执行附加请求和继续正常处理。如果CPU负担过重,JSP将减少线程数量,以便减少因太多费阻断请求同时执行而产生的持续不断的交换

  • 服务器端包含(使用SRC属性):现在可以使用HTML(SCRIPT)…(/SCRIPT)标签的SRC属性来完成服务器端包含。当使用SRC属性制定虚拟或相对路径并使用RUNAT=SERVER属性表示服务器端执行时,可以完成与“#Include”命令一样的功能

  • 编码的JSP脚本:以前Web开发人员禁止他人查看隐藏在脚本后面的逻辑。JSP现在支持Microsoft Visual Basic Scripting Edition(JSPScript)和Microsoft Jscript5.0 附带的新的脚本编码实用程序。Web开发人员可以对客户端和服务器端脚本应用编码方案,以便使程序逻辑(使用非标准ASCCII字符)不可读。已编码的脚本在运行时由脚本引擎解码,因此不需要单独的实用程序。虽然此特性不是专门的安全加密解决方案,但可防止大多数用户无意中查看或复制脚本

1.3.3 JSP的基本概念

  • URL:URL(Uniform Resource Location,统一资源定位器)有协议名、web服务器地址、路径名和文件名四部分组成,它只是了文件在Internet中的位置

  • HTML:HTML(Hypertext Markup Language,超文本标记语言)是一种用于编写超文本文档的标记语言,它不是一种程序设计语言而是一种结构语言。它具有凭他无关性,无论是何种操作系统,只要有相应的浏览器程序,就可以运行HTML文档

  • Web站点:Web站点是计算机网络上的一个位置,它以网页或文档形式提供信息,访问者只需通过Web浏览器链接到站点

  • 主页:主页是Web站点上一组网页或其他文件的起始页。它是HTML格式的文档,可用来说明站点内容、作者所在公司或部门的新闻、指向其他相关文档的链接或站点作者的个人信息等

2.系统分析

2.1 需求分析

根据调研情况进行分析,认识到完整的管理系统非常复杂 ,其功能随医院病例规模等条件的变化而不同。目前各种医院病例管理系统的不断涌现,但是大多都是针对大型医院来设计的,而很少考虑到众多私人牙科诊所病例的实际情况,其功能在私人牙科诊所病例并不适用,从而增加了院方不必要的投资。此外,系统一般也不支持远程访问,信息的共享性差。为适应医疗信息管理发展的需要,开发基于B/S结构的私人牙科诊所病例管理系统。该系统应具有以下功能:

  • 登陆模块,可分为管理员登陆和普通用户医生登录三个模块

  • 用户注册模块,对用户注册的用户名的要求,不同的用户要求要有不同的用户名

  • 系统管理模块,包括添加管理员,管理员密码的修改

  • 挂号管理模块,包括患者的名字、性别、年龄、现住地址和患者简介

  • 患者管理模块,对患者进行增加、患者删除、患者信息的修改

  • 开药管理模块,对药品的增加、删除、修改、查询,患者病历查

  • 科室管理模块,管理员可以新建,修改,删除,科室信息

  • 留言管理,管理员可以新建,修改,删除留言信息

  • 预约挂号模块,用户可以在线进行预约挂号,用户可以选择普通号和专家号

2.2 系统设计原则

2.1.1 技术可行性

本系统是采用基于Web的程序设计思想进行编制的,利用JSP语句结合Microsoft SQL Server 2000后台数据库开发“私人牙科诊所病例信息管理系统”,可应用于各大中小型私人牙科诊所病例。整个系统由若干个表、窗口、菜单构成的。用户可通过菜单来调用系统的各项功能。

基于Web的程序设计语言JSP,之所以成为功能强大的服务器端程序是因为它为Web编程人员提供了一组功能强大的内置对象,通过这些内置对象,编程人员可以控制Web页面的各个方面。

2.1.2 经济可行性

鉴于次系统是毕业设计,所以本系统不需要多余的格外开发成本,硬件配置和软件配置环境家用机可完全胜任,所以在经济上是可行的。

2.1.3 操作可行性

本设计力求界面简单明了,操作简单,便于上手,使用户可以在最短的时间内熟练掌握各功能。所以在操作上是可行的。

2.1.4 时间可行性

从时间上看,在两个月的时间里学习相关知识,并开发网站,时间上是有点紧,但是不是不可能实现,通过两个多月的努力功能基本实现。

3.概要设计

功能模块的设计是整个系统设计的重要部分,它决定怎么实现系统的功能,不仅要求功能完善,而且还要界面友好,因此,对于一个成功的系统设计,功能模块的设计是关键。

3.1 数据库设计

目前流行的数据库管理系统有Oracle、Mysql DB2、Sybase、MS Access和Microsoft SQL Server等。Oracle和Mysql是性能卓越、稳定可靠的大型数据库管理系统,目前拥有较多的用户。 MS Access 是一种性能可靠、使用方便的小型数据库系统。一般而言,数据库是由特定的操作系统环境上的一个或者一组文件组成的,而数据库管理系统一般是由运行于用户计算机或网络上的远程计算机上面的一整套程序组成的。

根据对数据组织方式的不同,数据库系统分成关系数据库、层次数据库和网状数据库。目前常见的数据库系统上基本上都是关系型数据库系统。在关系型数据库系统中,数据被组织成为二维表格形式,表格中的每个数据行称为一条记录或直接称为行,每一个列有时被称为字段或直接称为列,通过指定行和列定位一个指定的数据项。

一个优秀的数据库系统应具备如下特征:

  • 最大限度的减少数据的重复存储(称为“冗余”),以减少存储空间的占用

  • 尽可能地提高数据的查询(搜索)速度

  • 提供灵活的数据组织和统计手段

  • 保章数据的安全

本系统采用的数据库是MySQL是一个关系型数据库管理系统 瑞典MySQL AB公司开发,目前属于Oracle公司。MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。MySQL的SQL语言是用于访问数据库的最常用标准化语言。由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择MySQL作为网站数据库。所有对数据库访问操作的管理信息系统都是根据用户的需求设计的,如果对数据库概念理解不深,那么设计出的数据库,不但访问速度慢,让用户不满意,而且还存在很多的重复数据,大量的浪费计算机资源。所以如何符合逻辑的有组织的设计好数据库,使数据库不仅容易维护,而且还让用户方便快捷的访问操作,这将是一个重点。因此,要设计好数据库,先了解一下关于数据库的基本概念是必要的。

3.2 建立数据库

现在管理数据库的工具是越来越多了 有了他们我们可是很方便的创建数据库删除数据库 还可以通过工具查看数据库的表的结构表中的字段数据进行数据库以及表的设计 极大地方便了我们 。不用再为创建数据库只有使用sql语句提供了方便.。

3.3 建立数据库的任务

数据库设计实际上主要是所要处理的数据的表示方法和存储结构的设计。在采用数据库技术之前,这些工作分散在应用程序中进行;在采用数据库技术之后,这些工作可以通过数据库设计集中起来系统地进行。

上图可以看出,进行数据库设计的首要任务是考虑信息需求,也就是数据库要存入什么样的数据。创建数据库并不是仅仅为了存储数据,更主要的目的是从中提取有用的信息。除了考虑数据存储什么数据外,还应考虑存取方式,也就是处理需求。即要根据用户提出的存取要求来设计数据模式和应用程序。

3.4 建立数据库的方法

数据库设计方案应该是将用户需求充分融入其中的,所以同用户进行充分的接触和交流是比不可少的。就设计方法来说,应遵循以下几个步骤:

  • 确定该数据库中需要的表

  • 确定表中需要的字段

  • 明确有唯一值的字段

  • 确定表之间的关系

  • 优化设计

  • 输入数据并新建其他数据库对象

建立私人牙科诊所病例信息管理系统的数据库的操作步骤:

  • 打开企业管理器,在“数据库”上单击鼠标左键,之后在弹出的快捷菜单中选择“新建数据库”命令。保存并命名为“demo”

  • 在企业管理器,选择“安全性”的“登录”选项单击右键选择“新建登录”创建用户

  • 选择“demo”中的“表”单击右键弹出快捷菜单选择“新建表”命令,在显示的窗口中设置表中各个字段的名称、数据类型、长度和允许空等信息,并保存

  • 选择用户信息表,单击鼠标右键。在弹出的快捷菜单中选择“打开表”然后选择“返回所有行”命令,在显示的窗口中输入表的信息,然后关闭窗口,完成在表中输入信息的工作

这样名为demo的数据库就建成了,系统建立的数据库文件扩展名为.sql,文件主名是在database name编辑框中键入的数据库名称。

3.5 数据项和数据结构

用户身份,包括的数据项:用户身份ID号、用户身份名称,其E-R图如图3-1所示:

用户登录信息,包括的数据项有:用户名称、用户密码、用户身份、用户登录次数,其E-R图如图3-2所示:

用户登录日志信息,包括的数据项有:日志记录编号、用户编号、登录时间、离开时间,其E-R图如图3-3所示:

3.6 建立数据表

在系统数据库设计中,数据表的设计是关键,如何根据系统要实现的功能合理地设计数据表,将关系到整个系统数据表的运行效率甚至整个系统的成败,在表设计中要注意遵循数据库计数的原则。

规范化逻辑数据库设计包括使用正规的方法来讲数据分为多个相关的表。拥有大量窄表(列较少的表)是规范化数据库的特征。而拥有少量宽表(列较多的表)是非规范化的特征。数据库表设计理论的基本原理是:每个表都应有一个惟一的行标识符,可以使用列或列集将任何单个记录同表中的所有其他记录去区别开来。每个表都应有一个ID列,任何两个记录都不可以共享同一ID值。作为表的唯一行标识符的一列或多列是表的主键。同是,表应只能存储单一类型实体的数据并且应避免可为空的列,更重要的是表不应有重复的值或列。

因为私人牙科诊所病例信息管理系统包括挂号信息管理、药品管理等模块,还有其他子模块构成,包括的数据比较多,每一个表都要确定主关键字。这样本系统所有的表结构都建成了。

sysuser表

字段 字段名 数据类型 长度 说明
1 id Int 4 编号
2 uname varchar 50
3 upass varchar 50
4 tname varchar 50
5 sex varchar 50
6 birth varchar 50
7 tel varchar 50
8 ismarage varchar 50
9 addr varchar 50
10 email varchar 50
11 idcard varchar 50
12 byschool varchar 50
13 utype varchar 50
14 dept varchar 50

notice信息表

字段 字段名 数据类型 长度 说明
1 id Int 4 编号
2 title varchar 50
3 note varchar 50
4 savetime varchar 50

zd信息表

字段 字段名 数据类型 长度 说明
1 ghno Int 4 编号
2 bg varchar 50
3 zd varchar 50
4 info varchar 50
5 numinfo varchar 50
6 oper varchar 50
7 savetime varchar 50
8 qystatus varchar 50
9 fkstatus varchar 50
10 totalprice varchar 50
11 sfoper varchar 50
12 sfsavetime varchar 50
13 fyoper varchar 50
14 fysavetime varchar 50

4.详细设计

4.1 模块的设计

4.1.1 登录模块

管理员登录:包括用户名、密码 ,注册用户 界面图如图4-1所示:

实现管理员登陆界面的部分代码如下

  1. <title>私人牙科诊所病例管理系统 </title>
  2. <meta http-equiv="pragma" content="no-cache">
  3. <meta http-equiv="cache-control" content="no-cache">
  4. <meta http-equiv="expires" content="0">
  5. <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
  6. <meta http-equiv="description" content="This is my page">
  7. <!--
  8. <link rel="stylesheet" type="text/css" href="styles.css">
  9. -->
  10. <LINK href="admin/css/admin.css" type="text/css" rel="stylesheet">
  11. </head>
  12. <%
  13. String message = (String)request.getAttribute("message");
  14. if(message == null){
  15. message = "";
  16. }
  17. if (!message.trim().equals("")){
  18. out.println("<script language='javascript'>");
  19. out.println("alert('"+message+"');");
  20. out.println("</script>");
  21. }
  22. request.removeAttribute("message");
  23. String code=yzm.getCheckCode();
  24. %>
  25. <body onload=document.f1.uname.focus();>
  26. <form action="/srykzsblmis/studysite?ac=login" method="post" name="f1" onsubmit="return ck()">
  27. <TABLE height="100%" cellSpacing=0 cellPadding=0 width="100%" bgColor=#002779
  28. border=0>
  29. <TR>
  30. <TD align=middle>
  31. <TABLE cellSpacing=0 cellPadding=0 width=468 border=0>
  32. <TR>
  33. <TD align="center"><font size="4" color="white"><b>私人牙科诊所病例管理系统 </b></font></TR>
  34. <TR>
  35. <TD><IMG height=147 src="admin/images/login_2.jpg"
  36. width=468></TD></TR></TABLE>
  37. <TABLE cellSpacing=0 cellPadding=0 width=468 bgColor=#ffffff border=0>
  38. <TR>
  39. <TD width=16><IMG height=122 src="admin/images/login_3.jpg"
  40. width=16></TD>
  41. <TD align=middle>
  42. <TABLE cellSpacing=0 cellPadding=0 width=230 border=0>
  43. <TR height=5>
  44. <TD width=5></TD>
  45. <TD width=56></TD>
  46. <TD></TD></TR>
  47. <TR height=36>
  48. <TD></TD>
  49. <TD>用户名</TD>
  50. <TD><INPUT
  51. style="BORDER-RIGHT: #000000 1px solid; BORDER-TOP: #000000 1px solid; BORDER-LEFT: #000000 1px solid; BORDER-BOTTOM: #000000 1px solid"
  52. maxLength=30 size=24 name=uname></TD></TR>
  53. <TR height=36>
  54. <TD>&nbsp; </TD>
  55. <TD>口 令</TD>
  56. <TD><INPUT
  57. style="BORDER-RIGHT: #000000 1px solid; BORDER-TOP: #000000 1px solid; BORDER-LEFT: #000000 1px solid; BORDER-BOTTOM: #000000 1px solid"
  58. type=password maxLength=30 size=24 name=upass></TD></TR>
  59. <TR >
  60. <TD>&nbsp; </TD>
  61. <TD>验证码</TD>
  62. <TD><input type="text" style="BORDER-RIGHT: #000000 1px solid; BORDER-TOP: #000000 1px solid; BORDER-LEFT: #000000 1px solid; BORDER-BOTTOM: #000000 1px solid"
  63. size="5" id="yzm" name="yzm" class=input onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"
  64. onkeyup="value=value.replace(/[\W]/g,'')"><%=code %></TD></TR>
  65. <TR height=5>
  66. <TD colSpan=3></TD></TR>
  67. <TR>
  68. <TD>&nbsp;</TD>
  69. <TD>&nbsp;</TD>
  70. <TD><INPUT type=image height=18 width=70
  71. src="admin/images/bt_login.gif"></TD></TR></TABLE></TD>

普通用户登录:只有合法的用户在输入正确的密码后方可进入系统,否则将提示密码或用户名输入错误,并询问用户是否重新输入,界面图如图4-2所示:

实现普通用户登录的部分代码如下

  1. <jsp:include page="top.jsp"></jsp:include>
  2. <%HashMap user = (HashMap)session.getAttribute("user");
  3. CommDAO dao = new CommDAO();
  4. HashMap map = dao.select("select * from patient where id='"+user.get("id")+"' ").get(0);%>
  5. <div style="margin-top:10px;text-align:center;">
  6. <table width=800 border="0" cellpadding="0" cellspacing="0">
  7. <tr height=320 bgcolor="#1FA9FE" style="color:white;font-weight:bold;">
  8. <td align="center" width=110 bgcolor="#ECECED" valign="top" style="">
  9. <jsp:include page="menu.jsp"></jsp:include>
  10. </td>
  11. <td align="center" bgcolor="white" style="padding-left:20px;padding-top:15px;color:Black;font-weight:normal;" valign="top">
  12. <form action="/srykzsblmis/studysite?ac=userinfo&id=<%=map.get("id") %>" name="f1" method="post" onsubmit="return ck()">
  13. <table border=0 style="font-size:12px">
  14. <tr bgcolor="#ffffff">
  15. <td width=130 >
  16. 登录名称:
  17. </td>
  18. <td width=570 align="left">
  19. <input name="uname" type="text" id="uname" style="width:150px;" />&nbsp;
  20. </td>
  21. </tr>
  22. <tr bgcolor="#ffffff">
  23. <td >
  24. 登录密码:
  25. </td>
  26. <td align="left">
  27. <input name="upass" type="password" id="upass" style="width:150px;" />&nbsp;
  28. </td>
  29. </tr>
  30. <tr bgcolor="#ffffff">
  31. <td >
  32. 重复密码:
  33. </td>
  34. <td align="left">
  35. <input name="upass1" type="password" id="upass1" style="width:150px;" />&nbsp;
  36. </td>
  37. </tr>
  38. <tr bgcolor="#ffffff">
  39. <td>病人姓名</td>
  40. <td><input type="text" id="tname" name="tname" size="5"/>*</td>
  41. </tr>
  42. <tr bgcolor="#ffffff">
  43. <td>性别</td>
  44. <td>
  45. <select id="sex" name="sex">
  46. <option value="男"></option>
  47. <option value="女"></option>
  48. </select>
  49. </td>
  50. </tr>
  51. <tr bgcolor="#ffffff">
  52. <td>年龄</td>
  53. <td><input type="text" id="age" name="age" size="2"/>*</td>
  54. </tr>
  55. <tr bgcolor="#ffffff">
  56. <td>身份证</td>
  57. <td><input type="text" id="idcard" name="idcard" />*</td>
  58. </tr>
  59. <tr bgcolor="#ffffff">
  60. <td>电话</td>
  61. <td><input type="text" id="tel" name="tel" />*</td>
  62. </tr>
  63. <tr bgcolor="#ffffff">
  64. <td>住址</td>
  65. <td><input type="text" id="addr" name="addr" />*</td>
  66. </tr>
  67. <tr height=60>
  68. <td align="center" colspan="2">
  69. <input type="submit" value="提交">
  70. </td>
  71. </tr>
  72. </table>
  73. </form>
  74. </td>
  75. </tr>
  76. </table>
  77. <div style="margin-top:10px;height:1px;background-color:#1FA9FE;text-align:center;width:800px;">
  78. </div>
  79. </div>
  80. <jsp:include page="foot.jsp"></jsp:include>
  81. </center>
  82. <script type="text/javascript">
  83. function ck(){
  84. if(f1.upass.value==""){
  85. alert("密码不能为空");
  86. return false;
  87. }if(f1.upass1.value==""){
  88. alert("再次输入密码");
  89. return false;
  90. }if(f1.upass1.value!=f1.upass.value){
  91. alert("两次密码不一致");
  92. return false;
  93. }if(f1.tname.value==""){
  94. alert("姓名不能为空");
  95. return false;
  96. }if(f1.sex.value==""){
  97. alert("性别不能为空");
  98. return false;
  99. }if(f1.idcard.value==""){
  100. alert("身份证不能为空");
  101. return false;
  102. }
  103. }
  104. <%
  105. String suc = (String)request.getAttribute("suc");
  106. String no = (String)request.getAttribute("no");
  107. if(no!=null)
  108. {
  109. %>
  110. alert("已存在的用户名");
  111. <%}
  112. if(suc!=null)
  113. {
  114. %>
  115. alert("修改成功");
  116. location.replace("/srykzsblmis/userinfo.jsp");
  117. <%}%>
  118. </script>
  119. </body>
  120. </html>
  121. <%=Info.tform(map)%>

4.1.2 用户注册模块

用户注册包括用户名、登录密码、密码确认,界面图如4-3图所示:

实现用户注册的部分代码如下

  1. <title>私人牙科诊所病例管理系统</title>
  2. <meta http-equiv="pragma" content="no-cache">
  3. <meta http-equiv="cache-control" content="no-cache">
  4. <meta http-equiv="expires" content="0">
  5. <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
  6. <meta http-equiv="description" content="This is my page">
  7. <!--
  8. <link rel="stylesheet" type="text/css" href="styles.css">
  9. -->
  10. <STYLE type=text/css>
  11. BODY
  12. {
  13. padding-right: 0px;
  14. padding-left: 0px;
  15. padding-bottom: 0px;
  16. margin: 0px;
  17. padding-top: 0px;
  18. font-size: 12px;
  19. }
  20. .STYLE2 {
  21. FONT-SIZE: 12px
  22. }
  23. .STYLE3 {
  24. FONT-WEIGHT: bold
  25. }
  26. .style7 {
  27. FONT-FAMILY: "黑体", "方正美黑简体", "华文细黑"; COLOR: #646464; FONT-SIZE: 18px
  28. }
  29. BODY {
  30. BACKGROUND-IMAGE: url(img/lbg.gif); PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; FONT-SIZE: 12px; PADDING-TOP: 0px
  31. }
  32. .tb {
  33. WIDTH: 926px
  34. }
  35. .td2 {
  36. TEXT-ALIGN: left; PADDING-LEFT: 80px; BACKGROUND-REPEAT: no-repeat; HEIGHT: 100%
  37. }
  38. .txtBox {
  39. BORDER-BOTTOM: #e7ad01 1px solid; BORDER-LEFT: #e7ad01 1px solid; WIDTH: 130px; HEIGHT: 20px; COLOR: #000000; FONT-SIZE: 13px; BORDER-TOP: #e7ad01 1px solid; BORDER-RIGHT: #e7ad01 1px solid
  40. }
  41. #div1 {
  42. }
  43. #diqu {
  44. TEXT-ALIGN: center; WIDTH: 588px; BACKGROUND: url(images/2009_index_04.gif) no-repeat; COLOR: #2e466f
  45. }
  46. #diqu A {
  47. COLOR: #2e466f
  48. }
  49. .pageWidth {
  50. TEXT-ALIGN: left; MARGIN: 0px auto; WIDTH: 850px; BACKGROUND: #ffffff
  51. }
  52. #nav {
  53. PADDING-BOTTOM: 0px; LIST-STYLE-TYPE: none; MARGIN: 1em 0px 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; FONT-SIZE: 16px; FONT-WEIGHT: 200; LIST-STYLE-IMAGE: none; PADDING-TOP: 0px
  54. }
  55. #nav LI {
  56. FONT-FAMILY: "宋体"; FLOAT: left; FONT-SIZE: 14px; MARGIN-RIGHT: 1px
  57. }
  58. #nav LI A {
  59. TEXT-ALIGN: center; LINE-HEIGHT: 35px; MARGIN: 0em 0px 0px; WIDTH: 120.5px; DISPLAY: block; BACKGROUND: #f6ad79; COLOR: #000000; FONT-SIZE: 14px; TEXT-DECORATION: none; PADDING-TOP: 5px
  60. }
  61. .bi:hover SPAN {
  62. TEXT-ALIGN: center; LINE-HEIGHT: 35px; MARGIN: 0em 0px 0px; WIDTH: 120.5px; DISPLAY: block; BACKGROUND: #f6ad79; COLOR: #000000; FONT-SIZE: 14px; TEXT-DECORATION: none; PADDING-TOP: 5px
  63. }
  64. #nav LI A:hover {
  65. BACKGROUND: #dc3e0b; COLOR: #ffffff; FONT-SIZE: 14px; CURSOR: hand; PADDING-TOP: 0px
  66. }
  67. .bi:hover SPAN {
  68. BACKGROUND: #dc3e0b; COLOR: #ffffff; FONT-SIZE: 14px; CURSOR: hand; PADDING-TOP: 0px
  69. }
  70. .bi:hover SPAN {
  71. PADDING-TOP: 5px
  72. }
  73. .la {
  74. COLOR: #044a8e; TEXT-DECORATION: none
  75. }
  76. .la:hover {
  77. TEXT-DECORATION: underline
  78. }
  79. </STYLE>
  80. <LINK rel=stylesheet type=text/css href="/frontfile/css.css">
  81. </head>
  82. <body>
  83. <jsp:include page="top.jsp"></jsp:include>
  84. <div style="margin-top:10px;text-align:center;">
  85. <table width=800 border="0" cellpadding="0" cellspacing="0">
  86. <tr height=320 bgcolor="#1FA9FE" style="color:white;font-weight:bold;">
  87. <td align="center" width=800 bgcolor="#ECECED" valign="top" style="">
  88. <div style="margin-left:20px;font-size:16px;font-weight:bold;color:#044A8E;margin-top:20px;text-align:center;">
  89. 用户注册
  90. </div>
  91. <hr>
  92. <div style="font-size:12px;color:#044A8E;margin-top:20px;text-align:center;font-weight:normal;">
  93. <form action="/srykzsblmis/studysite?ac=regedit" name="f1" method="post">
  94. <table border=0 width=700 style="font-size:12px">
  95. <tr bgcolor="#ffffff">
  96. <td width=130 >
  97. 登录名称:
  98. </td>
  99. <td width=570 align="left">
  100. <input name="uname" type="text" id="uname" style="width:150px;" />&nbsp;
  101. </td>
  102. </tr>
  103. <tr bgcolor="#ffffff">
  104. <td >
  105. 登录密码:
  106. </td>
  107. <td align="left">
  108. <input name="upass" type="password" id="upass" style="width:150px;" />&nbsp;
  109. </td>
  110. </tr>
  111. <tr bgcolor="#ffffff">
  112. <td >
  113. 重复密码:
  114. </td>
  115. <td align="left">
  116. <input name="upass1" type="password" id="upass1" style="width:150px;" />&nbsp;
  117. </td>
  118. </tr>
  119. <tr bgcolor="#ffffff">
  120. <td>病人姓名</td>
  121. <td><input type="text" id="tname" name="tname" size="5"/>*</td>
  122. </tr>
  123. <tr bgcolor="#ffffff">
  124. <td>性别</td>
  125. <td>
  126. <select id="sex" name="sex">
  127. <option value="男"></option>
  128. <option value="女"></option>
  129. </select>
  130. </td>
  131. </tr>
  132. <tr bgcolor="#ffffff">
  133. <td>年龄</td>
  134. <td><input type="text" id="age" name="age" size="2"/>*</td>
  135. </tr>
  136. <tr bgcolor="#ffffff">
  137. <td>身份证</td>
  138. <td><input type="text" id="idcard" name="idcard" />*</td>
  139. </tr>
  140. <tr bgcolor="#ffffff">
  141. <td>电话</td>
  142. <td><input type="text" id="tel" name="tel" />*</td>
  143. </tr>
  144. <tr bgcolor="#ffffff">
  145. <td>住址</td>
  146. <td><input type="text" id="addr" name="addr" />*</td>
  147. </tr>
  148. <tr height=60>
  149. <td align="center" colspan="2">
  150. <img src="images/reg.png" border="0" onclick="ck()"/>
  151. </td>
  152. </tr>
  153. </table>
  154. </form>
  155. </div>
  156. </td>
  157. </tr>
  158. </table>
  159. <div style="margin-top:10px;height:1px;background-color:#1FA9FE;text-align:center;width:800px;">
  160. </div>
  161. </div>
  162. <jsp:include page="foot.jsp"></jsp:include>
  163. <script type="text/javascript">
  164. function ck(){
  165. if(f1.uname.value==""){
  166. alert("用户名不能为空");
  167. return false;
  168. }if(f1.upass.value==""){
  169. alert("密码不能为空");
  170. return false;
  171. }if(f1.upass1.value==""){
  172. alert("再次输入密码");
  173. return false;
  174. }if(f1.upass1.value!=f1.upass.value){
  175. alert("两次密码不一致");
  176. return false;
  177. }if(f1.tname.value==""){
  178. alert("姓名不能为空");
  179. return false;
  180. }if(f1.sex.value==""){
  181. alert("性别不能为空");
  182. return false;
  183. }if(f1.idcard.value==""){
  184. alert("身份证不能为空");
  185. return false;
  186. }else{
  187. f1.submit();
  188. }

4.1.3 系统管理模块

系统管理模块是私人牙科诊所病例信息管理系统中一个基础的部分,在本模块中包括管理员对自身密码的重新设置,可以定时更换密码,确保资料的安全;同时还有登陆日志模块,记录每一次登陆信息,如果出现特殊情况,可以查询登陆日志查询,增加了系统的安全性和保密性,便于控制和管理,界面图如图4-4所示:

实现系统界面的部分代码如下

  1. //添加科室
  2. if(ac.equals("deptadd")){
  3. String deptname = request.getParameter("deptname");
  4. String tel = request.getParameter("tel");
  5. String addr = request.getParameter("addr");
  6. String delstatus = "0";
  7. String sql = "insert into dept (deptname,tel,addr,delstatus) values('"+deptname+"','"+tel+"','"+addr+"','"+delstatus+"')";
  8. dao.commOper(sql);
  9. request.setAttribute("suc", "");
  10. go("/admin/deptadd.jsp", request, response);
  11. }
  12. //修改科室
  13. if(ac.equals("deptedit")){
  14. String id = request.getParameter("id");
  15. String tel = request.getParameter("tel");
  16. String addr = request.getParameter("addr");
  17. String deptname = request.getParameter("deptname");
  18. String sql = "update dept set deptname='"+deptname+"',tel='"+tel+"',addr='"+addr+"' where id= "+id;
  19. dao.commOper(sql);
  20. request.setAttribute("suc", "");
  21. go("/admin/deptadd.jsp", request, response);
  22. }
  23. //添加药品、处置
  24. if(ac.equals("ypcfadd")){
  25. String yno = request.getParameter("yno");
  26. String cksql = "select * from ypcf where yno='"+yno+"'";
  27. ArrayList cklist = (ArrayList)dao.select(cksql);
  28. if(cklist.size()!=0){
  29. request.getParameter("no");
  30. go("/admin/ypcfadd.jsp", request, response);
  31. }else{
  32. String yname = request.getParameter("yname");
  33. String price = request.getParameter("price");
  34. String type = request.getParameter("type");
  35. String gg = request.getParameter("gg");
  36. String company = request.getParameter("company");
  37. if(!type.equals("药品")){
  38. gg = "";
  39. company = "";
  40. }
  41. String delstatus = "0";
  42. String sql = "insert into ypcf (yno,yname,gg,price,company,delstatus,type)values('"+yno+"','"+yname+"','"+gg+"','"+price+"','"+company+"','"+delstatus+"','"+type+"')";
  43. dao.commOper(sql);
  44. request.setAttribute("suc", "");
  45. go("/admin/ypcfadd.jsp", request, response);

4.1.4 挂号管理模块

挂号管理模块是私人牙科诊所病例信息管理系统中一个部分,本模块主要实现后台管理,包括添加、删除、修改,患者挂号添加功能如图4-5所示:

4.1.5病例管理模块

医生可以对病人病例信息进行管理,在本模块中包括所有患者的信息的添加、删除、修改,增加患者图如图4-6所示:

4.1.6 用户模块

用户可以预约就诊,可以对个人信息进行管理,可以查询病例信息,同时可以与医生进行在线交流留言,在本模块中包括所有添加、删除、修改、查询如图4-7所示:

5.系统调试与测试

5.1 程序调试

在设计系统的过程中,存在一些错误是必然的。对于语句的语法错误,在程序运行时自动提示,并请求立即纠正,因此,这类错误比较容易发现和纠正。但另一类错误是在程序执行时由于不正确的操作或对某些数据的计算公式的逻辑错误导致的错误结果。这类错误隐蔽性强,有时会出现,有时又不出现,因此,对这一类动态发生的错误的排查是耗时费力的。

5.2 软件的测试

5.2.1 测试的重要性及目的

测试的重要性

软件的测试在软件生命周期中占据重要的地位,在传统的瀑布模型中,软件测试学仅处于运行维护阶段之前,是软件产品交付用户使用之前保证软件质量的重要手段。近来,软件工程界趋向于一种新的观点,即认为软件生命周期每一阶段中都应包含测试,从而检验本阶段的成果是否接近预期的目标,尽可能早的发现错误并加以修正,如果不在早期阶段进行测试,错误的延时扩散常常会导致最后成品测试的巨大困难。

事实上,对于软件来讲,不论采用什么技术和什么方法,软件中仍然会有错。采用新的语言、先进的开发方式、完善的开发过程,可以减少错误的引入,但是不可能完全杜绝软件中的错误,这些引入的错误需要测试来找出,软件中的错误密度也需要测试来进行估计。测试是所有工程学科的基本组成单元,是软件开发的重要部分。自有程序设计的那天起测试就一直伴随着。统计表明,在典型的软件开发项目中,软件测试工作量往往占软件开发总工作量的40%以上。而在软件开发的总成本中,用在测试上的开销要占30%到50%。如果把维护阶段也考虑在内,讨论整个软件生存期时,测试的成本比例也许会有所降低,但实际上维护工作相当于二次开发,乃至多次开发,其中必定还包含有许多测试工作。

在实践中,软件测试的困难常常使人望而却步或敷衍了事,这是由于对测试仍然存在一些不正确的看法和错误的态度,这包括:

  • 认为测试工作不如设计和编码那样容易取得进展难以给测试人员某种成就感

  • 以发现软件错误为目标的测试是非建设性的,甚至是破坏性的,测试中发现错位是对责任者工作的一种否定

  • 测试工作枯燥无味,不能引起人们的兴趣

  • 测试工作是艰苦而细致的工作

  • 对自己编写的程序盲目自信,在发现错误后,顾虑别人对自己的开发能力的看法

这些观点对软件测试工作是极为不利的,必须澄清认识、端正态度,才可能提高软件产品的质量。

测试的目的

如果测试的目的是为了尽可能多地找出错误,那么测试就应该直接针对软件比较复杂的部分或是以前出错比较多的位置。如果测试目的是为了给最终用户提供具有一定可信度的质量评价,那么测试就应该直接针对在实际应用中会经常用到的商业假设。

在谈到软件测试时,许多人都引用Grenford J. Myers在《The Art of Software Testing》一书中的观点:

  • 软件测试是为了发现错误而执行程序的过程

  • 测试是为了证明程序有错,而不是证明程序无错误

  • 一个好的测试用例是在于它能发现至今未发现的错误

  • 一个成功的测试是发现了至今未发现的错误的测试

这种观点可以提醒人们测试要以查找错误为中心,而不是为了演示软件的正确功能。但是仅凭字面意思理解这一观点可能会产生误导,认为发现错误是软件测试的唯一目,查找不出错误的测试就是没有价值的,事实并非如此。

首先,测试并不仅仅是为了要找出错误。通过分析错误产生的原因和错误的分布特征,可以帮助项目管理者发现当前所采用的软件过程的缺陷,以便改进。同时,这种分析也能帮助我们设计出有针对性地检测方法,改善测试的有效性。其次,没有发现错误的测试也是有价值的,完整的测试是评定测试质量的一种方法。

5.2.2 测试的步骤

与开发过程类似,测试过程也必须分步骤进行,每个步骤在逻辑上是前一个步骤的继续。大型软件系统通常由若干个子系统组成,每个子系统又由若干个模块组成。因此,大型软件系统的测试基本上由下述几个步骤组成:

  • 模块测试:在这个测试步骤中所发现的往往是编码和详细设计的错误

  • 系统测试:在这个测试步骤中发现的往往是软件设计中的错误,也可能发现需求说明中的错误

  • 验收测试:在这个测试步骤中发现的往往是系统需求说明书中的错误

5.2.3 测试的主要内容

为了保证测试的质量,将测试过程分成几个阶段,即:代码审查、单元测试、集成测试、确认测试和系统测试。

单元测试

单元测试集中在检查软件设计的最小单位—模块上,通过测试发现实现该模块的实际功能与定义该模块的功能说明不符合的情况,以及编码的错误。

身份认证时候要保证在以下输入情况时候系统能够健康运行:

  • 输入用户ID时候键入非法字符,如:•#¥%……等

  • 在操作员编码框输入非数字字符,如abc,!•#¥《》

  • 输入的用户ID,或者操作员编码不存在

  • 输入的用户ID,或者操作员编码与密码不相符合

  • 输入的用户ID,操作员编码不能登陆本模块

  • 输入的信息超过规定字符长度

  • 输入的信息有一项为空

查询信息时候:

  • 查询条件键入时有非法字符,如:#$%^等

  • 输入不存在的查询条件

  • 入查询条件超过规定字符长度

  • 输入查询条件一项为空

集成测试

集成测试是将模块按照设计要求组装起来同时进行测试,主要目标是发现与接口有关的问题。如一个模块与另一个模块可能有由于疏忽的问题而造成有害影响;把子功能组合起来可能不产生预期的主功能;个别看起来是可以接受的误差可能积累到不能接受的程度;全程数据结构可能有错误等。

确认测试

确认测试的目的是向未来的用户表明系统能够像预定要求那样工作。经集成测试后,已经按照设计把所有的模块组装成一个完整的软件系统,接口错误也已经基本排除了,接着就应该进一步验证软件的有效性,这就是确认测试的任务,即软件的功能和性能如同用户所合理期待的那样。

系统测试

软件开发完成以后,最终还要与系统中其他部分配套运行,进行系统测试。包括恢复测试、安全测试、强度测试和性能测试等。

单独对系统的测试主要从以下几方面入手:

  • 功能测试:测试是否满足开发要求,是否提供设计所描述的功能,是否用户的需求都得到满足。功能测试是系统测试最常用和必须的测试,通常还会以正式的软件说明书为测试标准

  • 强度测试及性能测试:测试系统能力最高实际限度,即软件在一些超负荷情况下功能实现的情况

  • 安全测试:验证安装在系统内的保护机构确实能够对系统进行保护,使之不受各种非常的干扰。针对本系统主要是对权限系统的测试和对无效数据、错数据、和非法数据干扰的能力的测试

经过上述的测试过程对软件进行测试后,软件基本满足开发的要求,测试宣告结束。

6.结论

6.1 系统评价

本文通过私人牙科诊所病例信息管理的设计与开发,从而得出下列结论:

  • 学习一门新技术,最重要的是实践,只有多动手才能尽快掌握它

  • 一个系统的开发,经验是最重要的,经验不足,就难免会有许多考虑不周之处

  • 要想吸引更多的用户,网站的界面必须要美观、有特色、友好,功能要健全。不过由于经验不足,我设计的图形界面比较简单。只是对基本功能进行了开发

  • 本次开发,我参考了很多私人牙科诊所病例信息管理系统的例子,吸取了一些别的私人牙科诊所病例信息管理系统的长处,对自己的毕业设计进行了完善,但是还有很多的不足之处,有待以后进一步学习

由于时间仓促,本次设计由我完成私人牙科诊所病例信息管理系统的制作,对我这样一个JSP新手而言所制作的模块还有不完善的地方。数据库的设计也比较简单。还有很多毕业设计中用到JSP语言的知识也不够全面,还有很多地方不能够作到完全的理解和掌握。通过这次毕业论文的设计制作使本人受益匪浅。首先,由于毕业设计所用的JSP技术和其中用到JSP语言的其他部分是在课堂上没有接触过的,要用它来做设计必须通过大量自学来掌握,在这个过程中,不仅大大提高了我的自学能力而且让我对JSP的学习有了进一步的认识 。由于是独立完成在毕业设计的过程遇到了很多的困难,我求教了不少老师和同学,在这个过程中让我体会到了,一个团队的重要性。

6.2 安全性问题

Web开发中安全性是必须考虑的一个很重要的方面,特别是在诸如毕业设计成绩信息等敏感数据的模块中更是关键,所以这也是后期开发需要引起重视的。下面就这方面的技术和解决方案加以讨论。

  • 安装防火墙:安装防火墙并且屏蔽数据库端口能有效地阻止了来自Internet 上对数据的攻击

  • 输入检查和输出过滤:客户在请求中嵌入恶意HTML标记来进行攻击破坏,防止出现这种问题要靠输入检查和输出过滤,而这类检查必须在服务器端进行,一旦校验代码发现有可疑的请求信息,就将这些可疑代码替换并将其过滤掉

  • 用户授权认证:对于关键用户必须进行系统授权,只有授权的用户才能访问系统。为了防止用户绕过登陆页面,系统在重要的页面检查用户是否登陆过并检验用户的操作权限,如果没有登陆或没有操作权限,将用户重定向到登陆页面。系统的后台数据库日志记录了所有登陆用户的用户名、IP 地址、登陆时间等

参考文献

[1] 王龙、黄峰,JSP管理信息系统项目开发实践,北京:科学出版社,2015.9

[2] 高怡新,JSP网络应用程序设计,北京:人民邮电出版社,2015.1

[3] 杨世锡、赵辉,JSP+SQL Server动态网站开发 从基础到实践,北京:电子工业出版社,2015.7

[4] 陈建伟、李美军、施建强。JSP动态网站开发教程(第二版).北京:清华大学出版社,2015.9

[5] 吴豪。 SQL Server 2000基础[M]. 红旗出版社/北京:希望电子出版社,2015.4

[6] (英)福塔 著 刘晓霞,钟鸣 译《mysql必知必会》 人民邮电出版社 2009.1

[7] 王虎, 张俊. 管理信息系统[M]. 武汉:武汉理工大学出版社,2014.7.

[8] Budi kurniawan.struts 2design and programming:a tutorial brainysoftware,second edition edition,2008.1.25

[9] Roger s-pressman,software engineering[m].new delhi:tata mcgraw-hill publishingcompary ltd,2006

[10] On the integration of smalltalk and java:Marcel hlopko,Jan kurs,jan vrany,claus gittinger science of computer programming,2013-爱思唯尔期刊

上传的附件 cloud_download 基于JAVA的私人牙科诊所管理系统.zip ( 8.07mb, 1次下载 )
error_outline 下载需要13点积分

发送私信

14
文章数
0
评论数
最近文章
eject