毕业设计说明书
面向特定群体的健康管理平台
设计与实现
班 级: 学号:
姓 名:
软件学院
学 院:
软件工程
专 业:
指导教师:
2014年 6 月
面向特定群体的健康管理平台设计与实现
摘要
随着网络技术的不断发展,网站的开发与运用变得更加广泛。这次采用java语言SSH框架设计并实现了面向特定群体的健康管理平台。该网站主要有教师饮食管理、教师健康日志、教师体检管理、疾病预测评估等功能模块。通过该网站,教师可以更好的关注自己的体检状况以及最近的身体状况,根据自身情况调整饮食,睡眠等生活习惯,并且可以及时预测高血压以及糖尿病的患病可能性大小,以便采取有效地预防措施。
本系统采用的是典型的J2EE 三层结构,分为表现层、中间层(业务逻辑层)和数据服务层。三层体系将业务规则、数据访问及合法性校验等工作放在中间层处理。客户端不直接与数据库交互,而是通过组件与中间层建立连接,再由中间层与数据库交互。
关键词:健康管理,慢性病,Spring,Struts,Hibernate
Design and Implement of Health Management Platform for the Specific Groups
Abstract
With the continuous development of network technology , the use of web site has became more widespread. This time I use JAVA language and SSH frame (Spring , Struts , Hibernate) to design and implement the health management platform for specific groups. Dietary management of teachers, teachers’ health log, medical management for teachers, disease forecast are designed in the web. Through the site, teachers can focus on their physical condition better, also can according to their circumstances to adjust their diet, sleep habits, etc. At the same time, we can take preventive measures to avoid hypertension and diabetes effectively.
The system uses a three-tier structure called J2EE, divided into presentation layer, intermediate layer (business logic layer) and data services layer. Three-tier system put business rules, data access and legality verification work on the middle layer to process. Client does not establish a direct interaction with database, but make connections with the middle tier by components and then interacts with the database on the middle layer .
Keywords: Healthy Manage , Chronic disease , Spring , Struts , Hibernate
目 录
1引言11
1.1设计背景11
1.2设计目的和意义11
1.3 国内外研究现状2
2 系统需求分析3
2.1系统目标3
2.2 系统功能要求3
2.2.1前台功能3
2.2.2后台功能4
2.3 系统性能要求4
2.4系统数据要求4
2.4.1数据的性质4
2.4.2数据字典5
2.4.3实体联系图6
3 系统设计9
3.1 开发工具介绍9
3.1.1 My eclipse介绍9
3.1.2 Oracle介绍9
3.2开发技术介绍10
3.2.1 Struts 2介绍10
3.2.2 Spring介绍11
3.2.3 Hibernate介绍11
3.2.4 Jsp介绍12
3.2.5 Jquery介绍12
3.2.6 Dwr(Ajax)介绍13
3.3 系统架构设计13
3.3.1 Hibernate持久化15
3.3.2 Service层16
4 系统概要设计17
4.1系统体系结构17
4.1.1 设计原则17
4.1.2 运行架构17
4.2 网站功能结构18
4.3数据库表设计19
4.3.1 数据库详细设计19
4.3.2 数据库逻辑结构设计19
4.3.3 数据库表设计20
4.4 信息安全设计21
4.4.1 网络安全22
4.4.2 其他安全22
5详细设计23
5.1 系统流程图23
5.2 前台主页界面设计23
5.2.1前台主页功能设计23
5.2.2教师饮食管理功能设计24
5.2.3教师健康日志功能设计25
5.2.4教师体检管理功能设计26
5.2.5疾病预测评估功能设计27
5.2.6注册功能设计28
5.3后台主页界面设计29
5.3.1管理员用户登录功能29
5.3.2管理管理员功能30
5.3.3管理员管理体检结果31
5.3.4管理员管理健康新闻32
5.3.5管理员管理教师功能33
6 系统测试34
6.1编写测试用例34
6.2单元测试34
6.3系统和集成测试35
7 结论36
参 考 文 献37
致 谢38
1 引言
1.1 设计背景
紧张的工作节奏、教学和科研的压力、个人不良的工作生活习惯、以及伴随工作压力而来的家庭关系、人际关系紧张等因素使得高校群体成为慢性病的高发群体[1]。学生入学的定期体检,教职工人入职体检,以及所有学生和教职工的定期体检工作,甚至个人自愿定期进行身体健康检查等都离不开医院的体检。人们对体检工作越来越重视,目前,传统的体检一直延用手工管理的方式,对健康信息的可视化平台需求迫切。
实现对健康信息分析的可视化,根据高危人群的日常行为,建立由此引发的发病概率预测模型,对高危人群做出相应的行为干预。健康管理平台不仅包含对个体健康曲线的可视化,同时包含对某群体健康曲线的可视化及预测,并以此为基础对个体日常行为的干预显示,以此为背景我选择设计健康管理平台。
1.2 设计目的和意义
健康管理既是一个概念,也是一种方法,更是一套完善、周密的服务程序,其目的在于使病人以及健康人更好地拥有健康、恢复健康、促进健康并尽量节约经费开支,有效降低医疗支出。健康管理有如下几大作用:一是可以了解居民的身体年龄,判断疾病指向;二是可以根据日常行为判断发病概率,以此为基础由医生提供降低慢性病发生危险性的行为干预方案;三是可以长期(终生)跟踪高危人群的健康,最大限度减少重大疾病的发生;四是可以节省维护健康的时间和金钱,提高保健效率[2]。
建立面向教师的健康管理平台的目的,对于个人,是如何利用健康体检系统中的信息为人们的健康保驾护航。而健康信息信息管理系统的管理和利用,不仅需要具备基础医学知识、临床医学知识、流行病学知识、计算机技术、数学统计知识等综合素质的专业人员,同时需要有保健医学、预防医学、临床医学、康复医学等专业的资深专家团队的支持,才能够为个人提供一系列的健康管理服务。
当今世界,信息管理数字化非计算机莫属,只有利用计算机技术,使用我国各个高校统一标准的健康体检系统表格,开发高校健康体检系统的系统软件,设置教师健康体检系统的计算机编号,制作教师的健康体检档案,并详细记录其本次体检程中所发现的健康问题和处理情况等,实现用户的健康体检系统信息在学校范围内的网络信息交换和共享,利用计算机技术,对用户的健康体检系统实现连续的动态管理。健康信息管理系统以计算机为工具,通过对用户体检所得的数据进行信息管理,把管理人员从繁琐的数据计算处理中解脱出来,为更好的帮组用户身体健康监督检查,从而全面提高质量。具体通过本系统可以对用户的基本健康状况进行各种必要的统计和分析[3]。
本项目将针对高校群体研发多模态的健康数据采集系统,对历年体检数据、就诊数据、膳食结构、生活习惯等健康相关信息建立统一管理系统,并在此基础上采用数据挖掘方法对诸如心血管疾病、高血压、糖尿病等慢性病进行有效建模与评估,对高校群体内广泛存在的亚健康状态进行综合客观评价和风险预测,最终实现针对高校群体慢性病患者及其高危人群的动态跟踪健康管理与干预。
1.3 国内外研究现状
健康管理的概念最早见于美国,早在1929年美国洛杉矶水利局就成立了最早的健康维护组织。早在20世纪70年代的美国,由于健康保险的发展以及医疗服务模式的改变,要求医生能更好地指导病人进行疾病预防以及更加节省医疗费用。健康服务组织通过对人群的健康状况进行评价和疾病的风险评估,科学预测疾病的危险因素,制定具体的、有针对性的预防和保健措施。通过健康管理美国的医疗费比以前节省了大约10%,同时避免了疾病的发生,提高了生活质量。资料显示,通过健康管理计划,在1978-1983年,美国人的胆固醇水平下降了2%;高血压水平下降了4%;冠心病发病率下降了16%。美国密执安大学健康管理研究中心主任第·艾鼎敦博士(Dee.W.Edington)曾经提出美国20多年的研究得出了9:1定律结论,即90%的人通过健康管理后,医疗费用降到了原来的10%;10%的人未做健康管理,医疗费用比原来上升了90%。通过经济学分析发现,在健康管理方面投入1元钱,相当于减少3-6元医疗费用的开销。如果加上由此产生的劳动生产率提高的回报,实际效益达到投入的8倍[4]。
健康管理在中国刚刚起步,是一个朝阳的产业。目前在中国大陆地区仅有少数专业的健康管理机构,大部分为医院及体检中心的附属部门。健康管理的从业人数没有准确的数据,估计全国在10万人以上,也就是说我国享受科学、专业的健康管理服务的人数只占人口总数的万分之二,这一比例与美国70%居民能够在健康管理公司或企业接受完善的服务相去甚远。而且目前健康管理仍然主要依赖于简单的单次体检或就诊数据由医生提供一些生活习惯的建议和意见,并没有把个人的历史病历以及日常行为对个人慢性病的影响考虑进去。此外,目前的健康管理也主要是针对已患病的患者,还未做到“早筛选、早预防、早发现、早诊断”的动态追踪的健康管理模式。
2 系统需求分析
2.1 系统目标
健康管理平台的总目标是:在计算机网络,数据库和先进的开发平台上,利用现有的软件,配置一定的硬件,开发一个具有开放体系结构的、易扩充的、易维护的、具有良好人机交互界面的教师健康管理平台。
具体的要求如下:
为了达到以上的开发目的,健康管理平台应遵循一定的设计和开发与原则:
2) 基础类库和接口设计合理,尽量建立叮扩展的接口和抽象类;
3) 数据库操作使用标准SQL语句,如果一定要使用有差别的SQL语句,则尽量集中在一起,以减少将来维护和移植的难度;
4) 采用开放的标准和工具等。
2.2 系统的功能要求
2.2.1 前台功能
在前台的功能实现上,可以分为以下几个部分:
1.教师饮食管理:根据教师的相关信息,计算其每天所需热量,给出一周的推荐菜单。
2.教师健康日志:用户可以记录自己健康日记,记录每一天的睡眠,饮酒,吸烟,血压,体重等情况。
3.教师体检管理:教师可通过该平台查询每次的体检结果,显示部分项目随时间变化的曲线。
4.疾病预测评估:针对糖尿病和高血压两种疾病,利用数学线性回归的方法,模拟计算出教师患病概率。
2.2.2 后台功能
后台主要有四个功能:
1.管理员用户登录功能:通过编号登录系统。
2.管理员管理教师功能:可以增删改查教师基本信息。
3.管理员管理体检结果:可以增删改查教师体检记录。
4.管理员管理健康新闻:可以发布或删除新闻。
2.3 系统的性能需求
健康管理平台的特性要求网站系统需要具备以下几个主要特性:
2.4 系统的数据要求
2.4.1 数据的性质
整个健康管理平台的数据是共享的。然而,从网站开发的角度上看,共享会给设计和调试带来困难。因此,应该提供灵活的配置,使各个分系统能够独立运行,而通过人工干预的手段进行系统数据的交换。这样,也能提供系统的强壮性。
2.4.2 数据字典
健康管理平台主要涉及到真实姓名数据字典,如表2.1所示:
表2.1 真实姓名数据字典
名称:真实姓名
别名:realname
描述:教师注册时需要输入自己的真实姓名,需与体检表中的名字统一。
定义:真实姓名=[{字}2|{字}3|{字}4]
位置:用户注册界面
用户注册界面涉及到电话的数据字典,如表2.2所示:
表2.2 电话数据字典
名称:电话
别名:phone
描述:教师注册时需要输入自己的联系方式。
定义:电话={0···9}11
位置:用户注册界面
用户注册界面涉及到邮箱的数据字典,如表2.3所示:
表2.3 邮箱数据字典
名称:邮箱
别名:email
描述:教师注册时需要输入自己的邮箱。
定义:邮箱= [a···z|0···9|A···Z] +@+([a···z|0···9|A···Z]
位置:用户注册界面
2.4.3 实体联系图
健康管理平台主要涉及的实体联系图有六个,实体有Teacher、Manager、Food、
Notice、Exam、Dairy。
图2.1 教师E-R图
图2.2 食物E-R图
图2.3 新闻E-R图
图2.4 体检 E-R图
图2.5 管理员 E-R图
图2.6 日志 E-R图
3 系统设计
3.1 开发工具介绍
3.1.1 My Eclipse 介绍
My Eclipse企业级工作平台(MyEclipseEnterprise Workbench ,简称My Eclipse)是对EclipseIDE的扩展,利用它我们可以在数据库和Java EE的开发、发布以及应用程序服务器的整合方面极大的提高工作效率。它是功能丰富的Java EE集成开发环境,包括了完备的编码、调试、测试和发布功能,完整支持HTML,Struts,JSP,CSS,SQL,Javascript,Spring,Hibernate。
My Eclipse 是一个十分优秀的用于开发Java, J2EE的 Eclipse 插件
集合,My Eclipse的功能非常强大,支持也十分广泛,尤其是对各种开源产品的支持十分不错。My Eclipse目前支持Java Servlet , AJAX, JSP, JSF, Struts, Spring, Hibernate, EJB3,JDBC数据库链接工具等多项功能。My Eclipse几乎囊括了目前所有主流开源产品的专属eclipse开发工具[6]。
My Eclipse 2013支持HTML5、JQuery 和主流的JavaScript 库。随着My Eclipse 2013支持Html5,可以添加音频、视频和API元素到项目,从而为移动设备创建复杂的Web应用程序。甚至还可以通过HTML5 可视化设计器设计令人难以置信的用户界面。同时,随着My Eclipse 2013支持JQuery,可以通过插件提升性能,并添加动画效果到设计中。
3.1.2 Oracle 介绍
Oracle数据库系统是美国ORACLE公司(甲骨文)提供的以分布式数据库为核心的一组软件产品,是目前最流行的客户/服务器(CLIENT/SERVER)或B/S体系结构的数据库之一。比如Silver Stream就是基于数据库的一种中间件。ORACLE数据库是目前世界上使用最为广泛的数据库管理系统,作为一个通用的数据库系统,它具有完整的数据管理功能;作为一个关系数据库,它是一个完备关系的产品;作为分布式数据库它实现了分布式处理功能。
Oracle数据库最新版本为Oracle Database 12c。Oracle数据库12c 引入了一个新的多承租方架构,使用该架构可轻松部署和管理数据库云。此外,一些创新特性可最大限度地提高资源使用率和灵活性,如Oracle Multitenant可快速整合多个数据库,而Automatic Data Optimization和Heat Map能以更高的密度压缩数据和对数据分层。这些独一无二的技术进步再加上在可用性、安全性和大数据支持方面的主要增强,使得Oracle数据库12c成为私有云和公有云部署的理想平台[7]。
3.2 开发技术介绍
3.2.1 Struts2
Struts是 Apache软件基金会(ASF)赞助的一个开源项目。它最初是 Jakarta项目中的一个子项目,并在2004年3月成为ASF的顶级项目。它通过采用 Java Servlet/JSP 技术,实现了基于Java EE的Web应用的MVC设计模式的应用框架,是MVC经典设计模式中的一个经典产品。
在Struts 中,已经由一个名为ActionServle的 Servlet 充当控制器(Controller)的角色,根据描述模型、视图、控制器对应关系的struts-config.xml的配置文件,转发视图(View)的请求,组装响应数据模型(Model)。在 MVC 的模型(Model)部分,经常划分为两个主要子系统(系统的内部数据状态与改变数据状态的逻辑动作),这两个概念子系统分别具体对应 Struts 里的ActionForm与Action两个需要继承实现超类。在这里,Struts 可以与各种标准的数据访问技术结合在一起,包括Enterprise Java Beans(EJB),JDBC与JNDI。在Struts的视图(View) 端,除了使用标准的JavaServer Pages(JSP)以外,还提供了大量的标签库使用,同时也可以与其他表现层组件技术(产品)进行整合,比如 Velocity Templates,XSLT 等。通过应用 Struts 的框架,最终用户可以把大部分的关注点放在自己的业务逻辑(Action)与 映射关系的配置文件(struts-config.xml)中。
在Java EE的Web应用发展的初期,除了使用Servlet技术以外,普遍是在JavaServer Pages(JSP)的源代码中,采用HTML与Java代码混合的方式进行开发。因为这两种方式不可避免的要把表现与业务逻辑代码混合在一起,都给前期开发与后期维护带来巨大的复杂度。为了摆脱上述的约束与局限,把业务逻辑代码从表现层中清晰的分离出来,2000年,Craig McClanahan采用了MVC的设计模式开发Struts。后来该框架产品一度被认为是最广泛、最流行JAVA的WEB应用框架。2006年,WebWork与Struts这两个优秀的Java EE Web框架(Web Framework〕的团体,决定合作共同开发一个新的,整合了WebWork与Struts优点,并且更加优雅、扩展性更强的框架,命名为“Struts 2”,原Struts的1.x 版本产品称为“Struts 1”。
其全新的Struts 2的体系结构与Struts 1的体系结构差别巨大。Struts 2以WebWork为核心,采用拦截器的机制来处理用户的请求,这样的设计也使得业务逻辑控制器能够与ServletAPI完全脱离开,所以Struts 2可以理解为WebWork的更新产品。虽然从Struts 1到Struts 2有着太大的变化,但是相对于WebWork,Struts 2的变化很小。
3.2.2 Spring 介绍
2002 年wrox 出版了《Expert one on one J2EE design and development》一书。该书的作者是Rod Johnson。在书中, Johnson 对传统的J2EE 架构提出深层次的思考和质疑。并提出J2EE 的实用主义思想。2003 年, J2EE 领域出现一个新的框架: Spring ,该框架同样出自Johnson 之手。事实上, Spring 框架是《Expert one on one J2EE design and development》一书中思想的全面体现和完善, Spring 对实用主义J2EE 思想进一步改造和扩充,使其发展成更开放、清晰、全面及高效的开发框架。一经推出,就得到众多开发者的拥戴。传统J2EE 应用的开发效率低,应用服务器厂商对各种技术的支持并没有真正统一,导致J2EE 的应用并没有真正实现Write Once 及Run Anywhere 的承诺。Spring 作为开源的中间件,独立于各种应用服务器,甚至无须应用服务器的支持,也能提供应用服务器的功能,如声明式事务等。Spring 致力于J2EE 应用的各层的解决方案,而不是仅仅专注于某一层的方案。可以说Spring 是企业应用开发的"一站式"选择,并贯穿表现层、业务层及持久层。然而,Spring 并不想取代那些已有的框架,而与它们无缝地整合[8]。总结起来, Spring 有如下优点:
1.低侵入式设计,代码污染极低。
2.独立于各种应用服务器,可以真正实现Write Once, Run Anywhere 的承诺。
3.Spring 的DI 机制降低了业务对象替换的复杂性。
4.Spring 并不完全依赖于Spring ,开发者可自由选用Spring 框架的部分或全部。
3.2.3 Hibernate 介绍
Hibernate 是目前最流行的ORM 框架,其采用非常优雅的方式将SQL 操作完全包装成对象化的操作。其作者Gavin King 在持久层设计上极富经验,采用非常少的代码实现了整个框架,同时完全开放源代码,即使偶尔遇到无法理解的情况,也可以参照源代码来理解其在持久层上灵巧而智能的设计。下面通过对比来了解Hibernate 和传统JDBC 操作数据库持久层之间的差异[9]。
3.2.4 JSP 介绍
JSP是由SunMicrosystems公司倡导、许多公司参与一起建立的一种动态技术标准。在传统的网页HTML文件(*.htm,*.html)中加入Java程序片段(Scriptlet)和JSP标签,就构成了JSP网页java程序片段可以操作数据库、重新定向网页以及发送E-mail等,实现建立动态网站所需要的功能。所有程序操作都在服务器端执行,网络上传送给客户端的仅是得到的结果,这样大 大降低了对客户浏览器的要求,即使客户浏览器端不支持Java,也可以访问JSP网页。
JSP全名为Java Server Pages,其根本是一个简化的Servlet设计,他实现了Html语法中的java扩张(以 <%, %>形式)。JSP与Servlet一样,是在服务器端执行的。通常返回给客户端的就是一个HTML文本,因此客户端只要有浏览器就能浏览。Web服务器在遇到访问JSP网页的请求时,首先执行其中的程序段,然后将执行结果连同JSP文件中的HTML代码一起返回给客户端。插入的Java程序段可以操作数据库、重新定向网页等,以实现建立动态网页所需要的功能。
JSP技术使用Java编程语言编写类XML的tags和scriptlets,来封装产生动态网页的处理逻辑。网页还能通过tags和scriptlets访问存在于服务端的资源的应用逻辑。JSP将网页逻辑与网页设计的显示分离,支持可重用的基于组件的设计,使基于Web的应用程序的开发变得迅速和容易。 JSP(JavaServer Pages)是一种动态页面技术,它的主要目的是将表示逻辑从Servlet中分离出来。
JSP页面由HTML代码和嵌入其中的Java代码所组成。服务器在页面被客户端请求以后对这些Java代码进行处理,然后将生成的HTML页面返回给客户端的浏览器。Java Servlet是JSP的技术基础,而且大型的Web应用程序的开发需要Java Servlet和JSP配合才能完成。JSP具备了Java技术的简单易用,完全的面向对象,具有平台无关性且安全可靠,主要面向因特网的所有特点。
3.2.5 Jquery(JavaScript) 介绍
JavaScript是一种基于对象和事件驱动并具有相对安全性的客户端脚本语言。同时也是一种广泛用于客户端Web开发的脚本语言,常用来给HTML(标准通用标记语言的子集)网页添加动态功能,比如响应用户的各种操作。它最初由网景公司(Netscape)的Brendan Eich设计,是一种动态、弱类型、基于原型的语言,内置支持类。JavaScript是Sun公司(已被oracle收购)的注册商标。Ecma国际以JavaScript为基础制定了ECMAScript标准。JavaScript也可以用于其他场合,如服务器端编程。完整的JavaScript实现包含三个部分:ECMAScript,文档对象模型,浏览器对象模型。
jQuery是一个兼容多浏览器的javascript框架,核心理念是write less,do more(写得更少,做得更多)。jQuery是免费、开源的,使用MIT许可协议。jQuery的语法设计可以使开发者更加便捷,例如操作文档对象、选择DOM元素、制作动画效果、事件处理、使用Ajax以及其他功能。除此以外,jQuery提供API让开发者编写插件。其模块化的使用方式使开发者可以很轻松的开发出功能强大的静态或动态网页。
3.2.6 DWR(Ajax)介绍
AJAX 指异步JavaScript及XML(AsynchronousJavascript+XML)。核心是JavaScript对象XmlHttpRequest。该对象在Internet Explorer 5中首次引入,它是一种支持异步请求的技术。简而言之,XmlHttpRequest使您可以使用JavaScript向服务器提出请求并处理响应,而不阻塞用户。
AJAX不是一种新的编程语言,而是一种用于创建更好更快以及交互性更强的 Web 应用程序的技术。在浏览器与 Web 服务器之间使用异步数据传输(HTTP 请求),这样就可使网页从服务器请求少量的信息,而不是整个页面;可使因特网应用程序更小、更快,更友好;是一种独立于 Web 服务器软件的浏览器技术。DWR它包含两个主要的部分:允许JavaScript从WEB服务器上一个遵循了AJAX原则的Servlet中获取数据.另外一方面一个JavaScript库可以帮助网站开发人员轻松地利用获取的数据来动态改变网页的内容。DWR采取了一个类似AJAX的新方法来动态生成基于JAVA类的JavaScript代码。这样WEB开发人员就可以在JavaScript里使用Java代码,就像它们是浏览器的本地代码一样;但是Java代码运行在WEB服务器端而且可以自由访问WEB 服务器的资源。
3.3 系统架构设计
本系统采用严格的J2EE 应用结构,主要有如下几个分层。
对于不同的持久层技术,Spring 的DAO 提供一个DAO 模板,将通用的操作放在模板里完成,而对于特定的操作,则通过回调接口完成。
3.3.2 Service层
Service 组件采用正面模式封装多个DAO 组件, DAO 对象与Service 组件之间的关Service 组件需要实现的业务方法主要取决于业务的需要,通常需要在业务组件中包含对应的方法。
业务层组件的实现业务层组件与具体的数据库访问技术分离,使所有的数据库访问依赖于DAO 组件,定义一个Facade Manager Impl来包装7个Dao这样就可以把逻辑层和Dao分开,达到松散耦合的效果。事务管理将推迟到Service组件而不是DAO 组件,因为只有对业务逻辑方法添加事务才有实际的意义,对于单个DAO方法(基本的CRUD 方法)增加事务操作是没有太大实际意义的。关于事务属性的配置,本系统使用Spring 提供的Transaction Proxy Factory Bean配置事务代理。这样不必为每个目标对象配置代理bean;避免了目标对象被直接调用。部署业务层组件单独配置系统的业务逻辑层,可避免因配置文件过大引起配置文件难以阅读。将配置文件按层和模块分开配置,可以提高Spring 配置文件的可读性和可理解性。在application Context.xml 配置文件中配置数据源、事务管理器、业务逻辑组件和事务管理器等bean[10]。
4 系统概要设计
4.1 系统体系结构
基于B/S结构的健康管理平台,应由终端(用户主机/浏览器)、WEB服务器、数据服务器构成。健康管理平台的核心是中间的接入服务器和应用服务器部分。健康管理平台的总体结构图如图4.1所示:
图4.1 健康管理平台总体结构
4.1.1 设计原则
在进行软件系统开发的最初环节,一般都需要进行系统的选型,即根据系统功能的实际需求,选择合适的开发工具及软件架构。
本系统设计时,比较主流的B/S设计有基于JSP、ASP、PHP、CGI及J2EE等模式。相比较而言PHP的功能相对简单,不适合做大程序;而CGI效率相对较低,所以也不考虑。由于J2EE的开源的框架中提供了MVC模式实现框架Struts、对象关系模型中的Hibernate的框架及拥有事务管理和依赖注入的Spring。利用现存框架可以更快开发系统,所以选择Java技术作为健康平台的开发工具。
4.1.2 运行架构
首先要对系统进行分析,确定对系统的综合要求,分析系统的数据要求,导出系统的逻辑模型。再对系统分析后确定系统的模块,对每个模块进行研究,这也是该系统的一个主要解决的地方。本系统包括了用户,管理员等很多信息,所以对该系统要建立数据库。管理系统是基于WEB的,所以需要一定的网页支持以及与数据库的连接。该系统主要是以JSP技术为主来开发的,所以要对该技术进行了解,学习。除此之外采用的技术和环境要求如下:
数据库访问:oracle数据库
服务器访问:Tomcat系列服务器
网页编程技术:DIV+CSS、JAVASCRIPT、AJAX等
后台处理技术:Struts2+Hibernate+Spring
硬件需求:PIII/512M/10G 及以上配置
操作系统:Windows2000及以上操作系统
4.2 网站功能结构
网站前台功能结构图,如图4.2所示:
图4.2 网站前台功能结构图
网站后台功能结构图,如图4.3所示:
网站后台功能
管理员
管
理
管理教师信息
管理体检
信息
管理健康信息
图4.3 网站后台功能结构图
4.3 数据库设计
4.3.1 数据库详细设计
数据项和数据结构如下:
1.管理员表(Manager): 管理员编号,管理员名字,管理员密码;
2.新闻表(Notice):新闻编号,新闻标题,新闻内容,发布时间,图片路径,发布者;
3.食物表(Food):食物编号,食物名字,食物热量,食物类型,食物碳水化合物,纤维素,脂肪,蛋白质;
4.体检表(Exam):收缩压,舒张压,体重指数,腰臀比,尿素,尿酸,肌酐,甘油三酯,胆固醇,高密度脂蛋白胆固醇,低密度脂蛋白胆固醇,葡萄糖,同型半膀胱氨酸,微量白蛋白,微量白蛋白/尿肌酐;
5.教师表(Teacher):教师编号,教师昵称,教师密码,教师年龄,教师性别,教师邮箱,找回密码问题,找回密码答案,教师真实名字;
6.日志表(Dairy):日志内容,日志时间,睡眠时间,心情,抽烟,体重,压力,高压,低压,心率;
7.日志食物表(Dairy-food):日志编号,食物编号。
4.3.2 数据库逻辑结构设计
数据库逻辑结构设计汇总表,如表4.1所示:
表4.1 汇总表
表名
功能说明
Manager
管理员表
Notice
新闻表
Food
食物表
Exam
体检表
Teacher
教师表
Dairy
日志表
Dairy-food
日志食物表
4.3.3 数据库表设计
数据库中共涉及到七张表,分别是管理员表,新闻表,食物表,日志表,日志食物表,体检表以及教师表。
表4.2 管理员表
字段名称
字段含义
数据类型
长度
NULL
注释
id
ID
Number
10
NO
主键
name
用户名
Varchar2
20
NO
password
密码
String
20
NO
表4.3 新闻表
字段名称
字段含义
数据类型
长度
NULL
注释
id
ID
Number
10
NO
主键
title
用户名
Varchar2
50
NO
content
密码
Varchar2
2000
NO
datetime
发布时间
Timestamp
6
NO
imagepath
图片路径
Varchar2
30
NO
manager_id
发布者
Number
10
YES
表4.4 食物表
字段名称
字段含义
数据类型
长度
NULL
注释
id
ID
Number
10
NO
主键
name
食物名
Float
20
NO
heat
热量
Float
126
YES
carbohydrate
碳水化合物
Float
126
YES
fat
脂肪
Float
126
YES
fiber
纤维素
Float
126
YES
protein
蛋白质
Float
126
YES
type
类型
Number
10
NO
表4.5 日志表
字段名称
字段含义
数据类型
长度
NULL
注释
datetime
ID
Varchar2
20
NO
主键
text
日志
Varchar2
2000
YES
sleephour
睡眠
Float
126
YES
mood
心情
Varchar2
255
YES
cigrette
抽烟
Number
10
YES
weight
体重
Float
126
YES
pressure
压力
Varchar2
255
YES
bphigh
高压
Float
126
YES
bplow
低压
Float
126
YES
bs
心率
Float
126
YES
teacher_id
教师号
Number
10
YES
表4.6 日志食物表
字段名称
字段含义
数据类型
长度
NULL
注释
dairy_id
日志ID
Varchar2
20
NO
主键
food_id
食物ID
Number
10
NO
主键
表4.7 体检表
字段名称
字段含义
数据类型
长度
NULL
注释
id
ID
Number
10
NO
主键
datetime
体检时间
Varchar2
6
NO
sbp
收缩压
Float
255
YES
dbp
舒张压
Float
255
YES
bmi
体重指数
Float
255
YES
whr
腰臀比
Float
255
YES
bun
胆固醇
Float
255
YES
ua
尿素
Float
255
YES
crea
尿酸
Float
255
YES
tg
肌酐
Float
255
YES
chol
甘油三酯
Float
255
YES
glu
葡萄糖
Float
255
YES
hcy
同型半膀胱氨酸
Float
255
YES
m_alb
微量白蛋白
Float
255
YES
m_alb_crea
微量白蛋白/尿肌酐
Float
255
YES
teacher_id
教师ID
Number
10
YES
表4.8 教师表
字段名称
字段含义
数据类型
长度
NULL
注释
id
ID
Number
10
NO
主键
name
教师名
Varchar2
20
NO
password
密码
Varchar2
20
NO
age
年龄
Number
10
NO
sex
性别
Varchar2
10
NO
邮箱
Varchar2
30
NO
question
找回密码问题
Varchar2
50
NO
answer
找回密码答案
Varchar2
50
NO
phone
电话
Varchar2
11
NO
realname
真实名字
Varchar2
20
NO
4.4 信息安全设计
网络的开放性导致网络技术的全面开放,任何团体和个人都可以获得网络资源,因而网络所面临的破坏将会是多方面的,可以是对软件环境实施攻出,也可以是对硬件环境实施攻。网络的国际性还意味着网络的攻将不仅仅来自本地网络用户,它可能来自Internet上的任何一台机器。即,发起攻的节点可以位于世界上任何地方。因此可以说,网络安全所面临的将是一个国际性全球化的挑战。网络的自由性意味着网络最初对用户的使用并没有提供任何的技术约束,用户可以自由地访问网络,自由地使用和发布各种类型的信息。用户只对自己的行为负责,而没有受到任何的法律限制。如何保护个人的机密信息不受入侵,己成为信息安全化健康发展所要考虑的重要事情之一。
健康管理平台用户个人信息的安全问题是至关重要的,制定切实可行的安全策略和实施有力的防范手段是非常必要的。系统的安全体系由下述结构组成,如下图4.4所示:
环境安全
物理安全
网络安全
主机系统安全 人员管理安全
操作安全规则 安全策略
图4.4 系统的安全体系结构
4.4.1 网络安全
Jsp技术虽然比较安全,但还是存在着很多安全上的问题的,客观的说,服务器软件的开发商在内部测试中不可能将系统中的所有bug 找出来,即使发布了软件后,被发现的漏洞也只会是其中的很小一部分,将来还会不断的有新的安全问题出现,所以我们必须时刻提高警惕。网站服务器的操作系统要打好补丁,进行安全权限的设置,并安装好防火墙,杀毒软件等,定时对数据进行备份。
4.4.2 其他安全
环境安全是整个系统安全的基础,要把信息泄露的危险减至最低限度,需要选择适当的设施位置,要充分考虑水灾、地震、电磁干扰与辐射以及其他等人为威胁,保证净化电源等等。物理安全也是整个系统安全的基础设置之一,物理安全涉及以系统中微机和主机、服务器等资源的房间,必须进行严格的管理。
5 详细设计
5.1 系统流程图
在计算教师所需标准热量值得流程图,如图5.1所示:
判断性别
[No]
男
男
[Yes]
判断年龄
判断年龄
18<age<30 31<age<60 age>60 18<age<30 31<age<60 age>60
15.2*体重+680
15.2*体重+680
15.2*体重+680
15.2*体重+680
15.2*体重+680
15.2*体重+680
图5.1 计算热量值流程图
5.2 前台功能设计
5.2.1 前台主页面设计
健康管理平台的主页面主要功能有教师的登陆,注册功能,后台界面的入口,四项主要功能的入口和简单介绍,健康新闻的展示,校园风景的动态展示以及相关部门的网站链接,此界面在实现登录时采用DWR异步刷新。主页面具体界面如图5.2所示:
图5.2 健康管理平台主界面
5.2.2 教师饮食管理功能设计
教师饮食管理功能中,主要是根据教师身高,体重,年龄,性别,活动量来计算其每天所需热量,给出一周的推荐菜单。用到的计算式是[11]:
人体基础代谢的需要的基本热量(REE)精确算法如表5.1所示:
表5.1 基本热量精确算法表
女子
18- 30 岁
14.6 x 体重(公斤) + 450
31- 60 岁
8.6 x 体重(公斤) + 830
60岁以上
10.4 x 体重(公斤) + 600
男子
18- 30 岁
15.2 x 体重(公斤)+ 680
31- 60 岁
11.5 x 体重(公斤) + 83
60岁以上
13.4 x 体重(公斤) + 490
每天所需的热量 = REE × 活动系数 = (大卡)
表5.2 活动系数表
活动内容
活动系数
卧床(全天)
1.2
轻活动生活模式(多坐或缓步)
1.3
一般活动度
1.5-1.75
活动量大的生活模式
2.0
该功能具体界面如图5.3所示:
图5.3 教师饮食管理功能界面
5.2.3 教师健康日志功能设计
用户可以记录自己健康日记,还可记录每一天的睡眠,饮酒,吸烟,血压体重,心情等情况,录入自己一天的饮食量,记录健康日志采用的是kindeditor这款文本编辑器健康日志功能界面具体如图5.4所示:
图5.4 健康日志功能界面
5.2.4 教师体检管理功能设计
校医院从后台导入体检结果,教师可通过该平台查询每次的体检结果,并且利用Highcharts 显示体检部分项目随时间变化的曲线,例如血压,血糖等。
Highcharts 是一个用纯JavaScript编写的一个图表库, 能够很简单便捷的在web网站或是web应用程序添加有交互性的图表,并且免费提供给个人学习、个人网站和非商业用途使用。目前Highcharts支持的图表类型有曲线图、区域图、柱状图、饼状图、散状点图和综合图表。Highcharts界面美观,由于使用JavaScript编写,所以不需要像Flash和Java那样需要插件才可以运行,而且运行速度快。另外Highcharts还有很好的兼容性,能够完美支持当前大多数浏览器[12]。体检管理功能具体界面如图5.5所示:
图5.5 教师体检管理功能界面
5.2.5 疾病预测评估功能设计
主要是针对糖尿病和高血压两种疾病,根据用户的体检相关项以及数据库近十年同类人患病情况,分析出致病的危险因素,利用数学线性回归的方法,建立预测模型,未来体检者可输入相关体检项来模拟计算出教师患病概率,预测模型如图5.6所示:
图5.6 疾病预测模型图
疾病预测评估界面具体如图5.7所示:
图5.7 疾病预测功能界面
5.2.6 注册功能设计
新用户可以按提示进行注册,每一项都用具体的正则表达式进行表单验证,确保信息有效可用,注册界面具体如图5.8所示:
图5.8 注册功能界面
5.3 后台功能设计
5.3.1 管理员登录功能
管理员使用用户名密码登陆系统后台,登陆界面如图5.9所示:
图5.9 管理员后台登录界面
管理员登陆后台后进入欢迎界面,此界面显示后台主要功能菜单以及登录时间,欢迎界面图5.10所示:
图5.10 后台欢迎界面
5.3.2 管理管理员功能
对管理员管理主要有查询、删除和添加操作,其中查询出来的管理员采用分页显示,调用的是Hibernate Template中的excutefind方法,此方法中的参数为一个回调函数,查询及删除管理员具体界面如图5.11所示:
图5.11 管理员查询及删除界面
添加管理员中分别对用户名密码进行验证添加,管理员添加界面如图5.12所示:
图5.12 管理员添加界面
5.3.3 管理员管理体检结果
教师体检结果管理可显示所有教师体检结果并可以删除不需要的记录,体检结果采用分页显示,每页默认显示10条记录,体检结果显示及删除具体界面如图5.13所示:
图5.13 管理员管理体检结果界面
教师体检结果的添加使用POI读取Excel表格, POI 是apache的子项目,目标是处理ole2对象。目前比较成熟的是HSSF接口,处理Excel对象。它不仅仅是用csv生成的没有格式的可以由Excel转换的东西,而是真正的Excel对象,可以控制一些属性如sheet,cell等[13]。体检结果添加具体界面如图5.14所示:
图5.14 体检结果添加界面
5.3.4 管理员管理健康新闻
健康新闻管理中可以添加,修改以及删除新闻,修改和删除具体界面如图5.15所示:
图5.15 健康新闻修改删除界面
健康新闻的添加功能中,图片的上传采用struts处理文件上传,具体界面如图5.16所示:
图5.16 健康新闻添加界面
5.3.5 管理员管理教师功能
教师个人信息管理中有查看及删除教师信息功能,具体界面如图5.17所示:
图5.17 教师管理界面
6.1 编写测试用例
表6.1 登陆测试用例
字段名称
描述
标识符
UC001
测试项
用户登录功能测试
测试环境要求
1.用户test/pass为有效登陆用户,用户test1为无效登录用户;2.浏览器的cookie为被禁用
输入标准
用户输入正确的用户名和密码,单击登陆按钮输入错误的用户名密码,单击登陆按钮不输入用户名密码,单击登陆输入正确的用户名不输入密码,单击登陆
输出标准
1.数据库中存在的用户可以正确登陆2.显示错误提示界面3.提示“请输入用户名”4.提示“请输入密码”
表6.2 注册测试用例
字段名称
描述
标识符
UC002
测试项
用户注册功能测试
测试环境要求
用户未注册过
输入标准
1.用户输入真实名字大于四个或小于两个2.用户输入手机号不是11位3.用户输入邮箱不含@4.用户必填项输入为空
输出标准
1.系统提示输入正确的名字2.系统提示输入正确的手机号3.系统提示输入正确的邮箱格式 4.系统提示完成所有必要输入
6.2 单元测试
在单元测试的时候,主要测试的是前后台各功能模块的功能是否都正常运行,是否和预期的结果相同,页面间的跳转和页面数据显示是否正常,实现的方式是单步调试,调试工具是用VS2005,辅助工具使用IE的脚本调试。在VS2005中设置断点,跟踪语句,逐句或者逐过程的调试,对出现的问题进行记录,并在完成所有测试后,对BUG进行了修复。
6.3 系统和集成测试
系统测试是通过将健康管理的前后系统进行整合,整体的测试平台的性能,测试前后台是否有数据不匹配,或者数据冲突等问题。集成测试是将整个平台放在服务器上,通过远程的访问、使用,测试系统平台是否能正常运行,通过使用VS2005提供的压力测试工具,对平台进行压力测试,以测试在用户使用高峰期时,平台的承受能力。
集成压力测试方法:
1.创建测试项目;
2.添加Web测试;
3.运行健康管理平台,此时web测试工具将对网站的相应操作记录,记录充足后停止记录,并生成相应代码;
4.添加负载测试;
5.在向导中设置需要测试环境,运行测试。
7 结论
本文从健康管理平台所需要实现的功能模块开始分析,决定使用Java开发该网站。并利用JDK,Tomcat,My Eclipse,Oracle等软件来搭建开发环境,利用Java技术的Spring、Hibernate、Struts等开源框架设计J2EE三层结构的中业务逻辑层和数据服务层,健康管理平台以Spring 框架为核心,向下整合Hibernate 进行持久层访问;向上整合Struts 按清晰的MVC 模式控制。这样可以更快开发松散耦合的健康管理平台。通过这次毕业设计学会利用java构建Web 网站,在毕业设计中接触过不少开源框架。开源框架的强大让我觉得还有很多技术需要去学习,这也让我明白,要不断地学习新知识才会利于自己各方面的发展。
参 考 文 献
[1] 王磊,河南省高校教师亚健康状态状况研究,河南师范大学学报(自然科学版),39(4): 163-167, 2011.
[2] 中国卫生部疾病预防控制局,中国慢性病报告,北京,2009.
[3] 北京交通大学校医院,北京交通大学教职工慢性病统计报告,北京,2012.
[4] World Health Organization. Preventing chronic disease: a vital investment. Geneva, 2005.
[5] 辛立伟,张帆.Java从初学到精通.北京:电子工业出版社,2010.552.
[6] 林建素,孟康健.《Eclipse开发学习笔记》 (第1版)北京:电子工业出版社. 2008.4.
[7] 《程序员》杂志社.程序员2004合订本下 北京:电子工业出版社:2005.
[8] 辛立伟,张帆.Java从初学到精通.北京:电子工业出版社,2010.552.
[9] 耿祥义,张跃平.java2实用教程.北京:清华大学出版社,2006.134.
[10] 朱福喜,唐晓军.Java程序设计技巧与开发实例 北京:人民邮电出版社:2004.
[11] 万方数据库,亚健康相关论文,http://s.g.wanfangdata.com.cn/Paper.aspx?q= subhealth,2012.
[12] 张智勇. JavaScript开发技术大全.北京:清华大学出版社,2009.201.
[13] 李松林,陈华清,任鑫.《Eclipse宝典》(第1版).北京:电子工业出版社. 2007.9.
致 谢
在论文结束之际,首先要感谢我的基地指导老师和校内指导老师,在我的论文设计以及实现过程中均给了我大量的帮助和指导,他们严谨的敬业精神和治学态度给我留下了深刻的印象。从他们身上,我学到了许多能使我受益终身的东西,再次对两位老师表示衷心的感谢。
感谢学院领导以及老师给我们创造的良好的学习环境和诸多帮助。
感谢父母,对我学业的支持;感谢寝室同学对我学习生活的诸多帮助。
感谢的人太多,只能说感谢所有给我关心、帮助和支持的人们。