目 录
人力资源管理系统开发与设计 ........................................................... 3
内容摘要 ................................................................... 3 关键词 ..................................................................... 3 ABSTRACT ................................................................... 4 Keywords ................................................................... 4 第1章绪论 ................................................................. 5 1.1课题研究的背景 ...................................................... 5 1.2国内外发展现状 ...................................................... 5 1.3课题研究的目的和意义 ................................................ 5 第2章相关知识的介绍 ....................................................... 6
2.1开发工具简介 ........................................................ 6 2.2 MVC框架简介 ........................................................ 7 2.3系统运行配置 ........................................................ 8 第3章 系统分析 ............................................................ 8
3.1可行性分析 .......................................................... 8
3.1.1技术可行性 ..................................................... 8 3.1.2操作可行性 ..................................................... 8 3.2需求分析 ............................................................ 9 第4章 系统总体设计 ........................................................ 9
4.1系统模块规划 ........................................................ 9 4.2系统功能结构图 ..................................................... 10 4.3系统数据库设计 ..................................................... 12
4.3.1数据库需求分析 ................................................ 13 4.3.2数据库概念结构设计 ............................................ 13 4.3.3数据库逻辑结构设计 ............................................ 13
第5章 系统详细设计 ....................................................... 18
5.1人事管理模块详细设计 ............................................... 18
5.1.1人事基本信息 .................................................. 18 5.1.2工种类型 ...................................................... 19 5.1.3职位类型 ...................................................... 19
第 1页 共 44页
西北工业大学毕业论文(设计)
5.1.4员工状态 ...................................................... 20 5.1.5部门信息 ...................................................... 20 5.1.6人事档案 ...................................................... 21 5.1.7专业资料 ...................................................... 22 5.1.8学历类型 ...................................................... 22 5.1.9人事变动 ...................................................... 23 5.1.10合同管理 ..................................................... 24 5.1.11统计分析 ..................................................... 24 5.2考勤管理模块详细设计 ............................................... 25
5.2.1请假管理模块 .................................................. 25 5.2.2出差管理模块 .................................................. 26 5.2.3日常考勤管理模块 .............................................. 27 5.2.4 加班管理模块.................................................. 28 5.2.5考勤数据分析 .................................................. 29 5.3权限管理 ........................................................... 30
5.3.1用户管理 ...................................................... 30 5.3.2密码修改 ...................................................... 30 5.3.3角色管理 ...................................................... 31 5.3.4资源权限管理 .................................................. 32
第6章 系统实现 ........................................................... 32
6.1系统开发环境 ....................................................... 32 6.2创建配置文件 ....................................................... 33 6.3实现数据持久层 ..................................................... 34 6.4控制层的实现 ....................................................... 38 6.5系统WEB层实现 ..................................................... 39 6.6系统部署 ........................................................... 39 6.7系统界面介绍 ....................................................... 40 第7章 总结 ............................................................... 42 致谢(References) ........................................................ 43 参考文献: ................................................................ 43
第 2页 共 44页
西北工业大学毕业论文(设计)
人力资源管理系统开发与设计
内容摘要
人力资源管理系统是现代企业管理的核心内容。随着计算机信息技术的高速发展,电子商务模式的空前盛行,企业之间的竞争也从有形的经济市场转向了网络。开发以计算机技术、网络技术、信息技术支持的现代人力资源管理系统,既能提高企业人力资源管理的技术含量和企业的办事效率,也能使人力资源管理能够进入现代化、决策科学化的进程。现代人力资源管理系统采用了B/S模式,可以避免C/S模式的重用性差、维护难度高的缺点和不足。结合实际项目的功能需求,从系统分析、系统总体设计、系统详细设计、系统实现等方面进行了详细的论述。
系统开发主要是MVC设计思想的应用,主要采用Jsp+Servlet+JavaBean的开发方式。Jsp对应MVC设计思想的视图(View),主要是负责接收/响应客服端请求,以及动态生成Web现实页面。Servlet是对应MVC设计思想的控制(Controller),主要负责整个系统的核心业务控制。JavaBean对应的是MVC设计思想的模型(Model),主要负责整个系统的数据和业务规则。系统的实现过程中运用了一些开源项目,如Ajax技术、JfreeChart报表、fileupload技术。
本文运用了现代人力资源管理理论,结合企业的实际情况,比较国内外人力资源管理系统的现状,设计了一个基于Internet/ Intranet的人力资源管理系统。本文研究人力资源管理系统的主要内容有:招聘管理、人事管理、考勤管理、培训管理、薪资管理、系统设置。系统的开发目的是人力资源管理的业务逻辑实现高效化、智能化,从而能帮助企业的人力资源管理人员进行人力资源管理和数据分析。
关键词
人力资源管理;B/S模式;MVC模型:开源项目
第 3页 共 44页
西北工业大学毕业论文(设计)
ABSTRACT
Human resource management system is the core content of modern enterprise management. With the rapid development of the computer information technology and unprecedented prevalence of electronic commerce mode,the competition between enterprises is turning from visible economic markets to the network. Developing the human resource management system supported by computer technology,network technology and information technology can not only improve the skill of human resource management and the efficiency of the enterprises but also make human resource management modern and decision sciencefic,Modern human resource management uses B/S mode to avoid C/S modes short coming of difficult in maintdning and reusing.According to the functional requirements of the actual project,this article specificly state the analysis of system,the general desigin of the system,the detail design of system and the practice of the system.
The development of the system is the practice of MVC design ideas, maing using the Jsp+Servlet+JavaBean form of development.Jsp is the practice of MVC design ideas’view,in charge of receiving/responding the request of the customer.Servlet mainly responsible for the core business control of the whole system is the practice of the vontroller of MVC design idea to take charge of the statistics and rules of the whole system. In the practice of the system, somr open-source projrcts,such as the Ajax technique,JfreChart statements,fileupload technology,has been used.
Using the modern human resource management theropy and analysising the actual situation, comparing the current situation of human resource management system, a huaman resource management system basied on the Internet/Intranet has been designed. The main contents of the huaman resource management system includes recruitment management, personnel management,attendance management training management, salary management and system configuation.The development of the system aims at making the management business logic more efficient and intelligent to help people manage the human resource and analysis the statistics.
Keywords
human resource management; B/S mode; Open-source projects; MVC mode.
第 4页 共 44页
西北工业大学毕业论文(设计)
第1章绪论
1.1课题研究的背景
21世纪是一个日新月异的信息时代,随着电脑与网络技术的日益发达,电子商务空前的发展,企业之间的竞争已经从有形的市场经济转向了无形的网络领域。因此企业管理也进入了高效的信息化的时代,即人力资源管理系统也就应运而生,所谓人力资源管理系统,指人力资源管理电子信息化,是企业基于高速度、大容量的硬件和先进的IT软件的人力资源管理模式。通俗地说,就是人力资源管理信息化或自动化。
在一个现代化的公司中的企业管理主要涉及到招聘,人事、薪资、考勤、培训几大部分,本次系统开发主要是针对以上几大模块的工作逻辑来设计和实现人力资源管理系统。 1.2国内外发展现状
现在,中国国内的人力资源管理系统的现况是[1]:中国的软件系统大多是源自信息系统,从部门的业务需求方面出发设计。管理信息系统的设计是为了服务于企业内部大多数业务操作员,将业务操作人员的重复性劳动进行初步自动化,即从管理理论抽象出理想化的业务管理模式,在基于该业务模式的基础上实现低层次的数据处理或业务流程电子化。管理信息系统的设计,是根据中小型企业业务单元的需求来编写的,一般无法满足多体制、多元化、多重组织结构的大型企业数据处理需求。
在与国外同类应用系统及解决方案相比较,目前中国的人力资源管理软件还有一些不足:第一,大部分是由管理信息系统演变而来,从单一的人力资源管理或人事行政管理的业务需求角度出发设计,如人事管理、考勤管理,或薪资计算与发放管理等,服务对象是某一具体业务的自动化操作需求;第二,目前国内的人力资源管理软件虽然已将模块功能扩展至企业人力资源管理或人才资本管理相关的整个业务领域,但系统在完整性、前沿性和集成性方面仍有欠缺。国外人力资源管理系统相对于国内人力资源管理系统来说,优势主要体现为:具有雄厚的经济实力,在技术力量的培养、研发、市场推广等方面大力投入;具有一定实力的包括硬件厂商、数据库公司、咨询公司在内的合作伙伴,形成很强的实力联手格局。国外人力资源管理系统伴随着管理理论的发展,其设计思路蕴涵了先进的管理理念和先进的开发技术;国外人力资源管理系统起步较早,完整性和成熟度高,能开发出了适用于不同行业的解决方案。 1.3课题研究的目的和意义
人力资源管理系统(HRMS),包括人事日常事务、薪资、招聘、培训、考核,同时人
第 5页 共 44页
西北工业大学毕业论文(设计)
力资源的管理也指组织或社会团体运用系统学理论方法,对企业的人力资源管理各个方面进行分析、规划、实施、调整,提高企业人力资源管理水平,使人力资源更有效的服务于组织或团体目标。人力资源管理系统就不仅可以完成日常业务需求,而且可以准确及时地搜索各种人力资源信息以方便管理者进行决策。
本系统是一个建立在成熟的Internet/Intranet【2】之上的人力资源管理系统。在系统需求分析的设计过程中,我们通过网络了解人力资源管理系统的功能组成部分,并通过对公司的咨询进行分析,最后通过小组会议讨论的方法获得需求分析,根据用户需求设计开发思路,采用图形来建立业务逻辑,最终确定系统功能模块。根据需求分析过程获取具体实体对象,从而设计系统类图,确定类之间的关系,对系统进行详细设计并实现。
该系统可以对企业员工各种信息和企业的各种部门信息进行统一管理,公司相应权限的管理人员可以登录本系统,进行相应的企业人力管理。使人力资源管理人员从繁杂、重复的劳动中脱离出来,集中时间、精力进行人力资源的整体规划与决策,提高企业的市场竞争力。系统应用了成熟的Internet/Intranet技术到人力资源管理系统中,使企业员工在全国各地都可以随时了解企业相关信息。在人员招聘方面,企业通过Internet对外发布招聘信息,应聘人员可以根据自己的特点填报相关空缺职位;在内部管理方面,也能方便员工交流;在业绩考勤管理方面,能对公司员工的日常考勤、加班、出差、请假考勤进行相关的记录统计,得到相关的负责人的批准方能生效。
第2章相关知识的介绍
在系统的开发过程中,运用面向对象[3]的开发语言,系统采取B/S结构,使用J2EE开发框架,主要是MVC框架,Ajax技术(jQuery),JFreeChart报表.权限控制时采用的是角色对应权限,配置文件配置URL进行action过滤来实现。数据库采用SQL Server 2005. 2.1开发工具简介
本系统的开发环境是jdk6.0+Eclipse3.5+Tomcat6.0,使用的语言是java语言。 JDK(Java Development Kit)是Sun Microsystems公司为Java开发人员设计的的产品。从Java诞生以来,JDK已经成为使用最广泛Java SDK。JDK 是整个Java的核心内容,包括了Java运行环境,Java工具和Java基础的类库三部分。JDK是学好Java的前提。而专门运行在x86平台的Jrocket在服务端运行效率也要比Sun JDK好很多。从SUN的JDK5.0开始,提供了泛型等非常实用的功能,其版本也不断更新,运行效率得到了非常大的提高。现在最新版本是jdk6.0。
Eclipse 是一个开放源代码的、基于 Java 的可扩展开发平台。Eclipse它只是一个
第 6页 共 44页
西北工业大学毕业论文(设计)
框架和一组服务,用于通过插件组件构建开发环境,关键的是Eclipse 附带了一个标准的插件集,包括 Java 开发工具(Java Development Tools,JDT)。 Eclipse最先是由IBM公司开发的替代商业软件Visual Age for Java的下一代IDE开发环境,2001年11月贡献给开源社区,现在由非营利软件供应商联盟Eclipse基金会(Eclipse Foundation)管理。 2003年,Eclipse 3.0选择OSGi服务平台规范为运行时架构。 2007年6月,稳定版3.3发布。2008年6月发布代号为Ganymede的3.4版。2009年7月发布代号为GALILEO的3.5版。
Tomcat是Apache 软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache、Sun 和其他一些公司及个人共同开发研究而成。因为有了Sun 的参与和支持的原因,最新的Servlet 和JSP 规范总是能在Tomcat 中得到体现,Tomcat 5 支持最新的Servlet 2.4 和JSP 2.0 规范。因为Tomcat 技术先进、性能稳定,而且免费,因而深受Java 爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的Web 应用服务器。目前最新版本是7.0。 2.2 MVC框架简介
MVC架构是\"Model-View-Controller\"的缩写中文翻译为\"模型-视图-控制\"[4].MVC应用程序是由这三个部分组成。Event(事件)的变化导致Controller改变Model或View,或者同时改变两者。当Controller改变了Models的数据或者属性,所有依赖的View都会自动更新。对应地,当Controller改变了View,View会从潜在的Model中获取数据来刷新自己的变化。MVC架构最早研发者是smalltalk语言研究团,主要应用于用户交互应用程序中。smalltalk语言和java语言有很多相似性,都是面向对象语言,很自然的SUN在petstore(宠物店)事例应用程序中就推荐MVC架构作为开发Web应用的架构模式。MVC架构是一种架构,其实需要其他模式协作完成。在J2EE模式中,通常采用service to worker模式实现,而service to worker模式可由集中控制器模式,派遣器模式和Page Helper模式组成。
MVC架构是一个复杂的架构,其实现也显得非常复杂。由于我们已经总结出了很多可靠的设计模式,多种设计模式结合在一起,使MVC架构的实现变得相对简单易行。Views相当于一棵树,可以用Composite Pattern来实现。Views和Models之间的关系可以用Observer Pattern体现。Controller控制Views的显示,可以用Strategy Pattern实现。Model通常是一个调停者,可采用Mediator Pattern来实现。
MVC与J2EE架构的对应关系可以分析如下:View处于Web Tier或者说是Client Tier,
第 7页 共 44页
西北工业大学毕业论文(设计)
通常是JSP/Servlet,即页面显示部分。Controller也处于Web Tier,通常用Servlet来实现,即页面显示的逻辑部分实现。Model处于Middle Tier,通常用服务端的javaBean或者EJB实现,即业务逻辑部分的实现。 2.3系统运行配置
服务器操作系统:可运行Tomcat6.0的Windows或Linux操作系统 客户操作系统: 支持Fire fox浏览器的操作系统 测试浏览器:Fire fox浏览器
第3章 系统分析
系统分析主要是介绍在系统设计前的可行性分析和需求分析,为系统设计作必要的准备。可行性分析简单的对本系统的技术可行性、操作可行性、软硬件的选择的分析说明。需求分析,主要是对本系统大体要实现内容的总结,以便以后测试本系统是否达到设计标准。
3.1可行性分析 3.1.1技术可行性 本系统技术要求如下:
功能:对人事资料、人力资源、工资管理、考勤管理等进行综合管理。 输入/输出:输入查询条件,输出查询内容。
基本的数据流程和处理流程:先对人员信息进行录入,然后再对它们分类。可以对数据进行插入、删除、修改、查询。
用户与权限:此系统可以分为用户和管理员,用户可以设置自己的个人信息,管理员主要管理系统的各种信息。
以上系统技术要求使用Eclipse可以满足,它使用的是面向对象、高效率且能够实现b/s模式编程的java语言[5]开发,使用MVC思想把数据、视图、业务逻辑进行分开,使用SVN协同开发工具进行版本控制,因此,本系统的开发在技术上是可行的。 3.1.2操作可行性
该系统在操作上很简单的,使用者完全可以没有专业的计算机知识。启动系统后进入登陆用户界面,用户用自己登陆名和密码进入系统操作页面。不同的用户拥有不同的权限,也只能浏览和操作相应的模块。用户能对自己拥有权限的功能模块进行相应的操作。例如
第 8页 共 44页
西北工业大学毕业论文(设计)
人事主管进入系统:他就可以进入人事信息模块,对人事信息进行浏览,删除,修改,添加等操作。 3.2需求分析
该系统分为六个模块:人事管理、考勤管理、工资管理、招聘管理、培训管理、权限管理。
招聘管理:针对公司的人才需求发布招聘职位信息,对应聘职位的简历进行录入并管理;符合要求的简历通知其进行面试,对面试人员的面试结果进行档案维护。另外该模块还涉及到对应聘人员资料的统计分析。
人事管理:该模块是关于公司的人事信息维护,首先是对入职员工的基本信息的录入、修改、浏览等操作;其次是员工人事档案、合同档案等基本信息的管理和公司的部门管理;最后,并对公司的人事信息从工种,专业,学历等属性进行统计分析。
考勤管理:该模块主要涉及到公司员工的考勤统计。考勤主要是日常考勤,请假考勤、出差考勤、加班考勤几大内容;另外也通过各个部门的考勤进行报表分析。
工资管理:该模块主要是关于公司的薪资信息维护,相关人员能进入该模块给员工进行工资管理,员工的工资主要是工资方案计算得出,工资方案是由工资项目进行组合而成。另外还能对员工的工资信息能进行调整和数据统计。
培训管理:该模块主要是进行员工培训信息的维护,主要是对培训类型管理、培训档案管理和培训效果统计。
系统设置:该模块主要是用户的权限设计,不同的用户对应着不同的权限,也只能操作相应权限的模块,另外还有用户的创建和用户密码的修改等功能。
第4章 系统总体设计
系统总体设计是对系统的模块规划、系统功能结构及系统数据库的总体设计。 4.1系统模块规划
本系统是一个典型的数据库开发应用程序,主要由招聘管理、人事管理、考勤管理、薪资管理、培训管理和系统设置六大模块组成,规划系统功能模块如下:
招聘管理模块:该模块主要是由招聘信息管理、简历管理、面试档案管理、招聘职位、统计分析组成。
第 9页 共 44页
西北工业大学毕业论文(设计)
人事管理模块:该模块主要是由人事基本信息管理、部门设置、人事档案、人事变动、合同管理、工种类型、职位类型、员工状态、学历资料、专业资料、统计分析组成。
考勤管理模块:该模块主要由请假管理、出差管理、加班管理、出勤管理、请假报表、出差报表、加班报表、出勤报表组成。
工资管理模块:该模块主要是由工资项目设置、工资方案、工资调整、工资发放、统计分析组成。
培训管理模块:该模块主要由培训信息管理、培训档案管理、培训类别、统计分析组成。
系统设置模块:该模块主要由用户管理、角色管理、资源权限管理、密码修改组成。 4.2系统功能结构图 1.主要模块结构图如4-1:
图4-1系统结构功能图
2.模块结构图
1.招聘管理子模块结构图如4-2:
第 10页 共 44页
西北工业大学毕业论文(设计)
图4-2招聘管理子模块结构图
2.人事管理子模块结构图4-3:
图4-3人事管理子模块结构图
3.考勤管理子模块结构图4-4:
图4-4考勤管理
4.培训管理子模块结构设计图4-5:
第 11页 共 44页
西北工业大学毕业论文(设计)
图4-5培训管理模块设计
5.工资管理子模块设计图4-6:
图4-6工资管理模块设计
6系统设置子模块设计图4-7:
图4-7系统设置子模块设计
4.3系统数据库设计
数据库设计的好坏在一个信息管理系统中地位十分重要,数据库结构设计将直接关系到对应用系统的效率,实现的效果产生影响。数据库结构设计合理可以提高数据存储的效率,保证数据的完整性[6]。
第 12页 共 44页
西北工业大学毕业论文(设计)
4.3.1数据库需求分析
数据库系统应充分熟悉用户各方面的需求,对于本系统用户的需求具体体现在各种信息的提供、保存、更新和查询,这要求数据库的结构能充分满足各种信息的输入和输出,收集基本数据、数据结构及数据处理的流程,为后面的具体设计打下数据基础。
1.数据录入和处理的准确性和实时性:数据的准确输入是数据处理的前提,错误的输入会导致系统输出的异常和不正确,从而使系统的工作失去意义。数据的输入来源是手工输入。手工输入数据要考虑数据的长度和数据的属性。在系统中,数据的输入往往是大量的,因此系统要有一定的处理能力,以保证迅速的处理数据。
2.数据的一致性与完整性:由于系统的数据是共享的,在不同的部门中,信息是共享数据,所以如何保证这些数据的一致性,是系统必须解决的问题。要解决这一问题,要有一定的人员维护数据的一致性,在数据录入处控制数据的去向,并且要求对数据库的数据完整性进行严格的约束。对于输入的数据,要为其定义完整性规则,如果不能符合完整性约束,系统应该拒绝该数据。
根据系统功能分析和需求总结,考虑到将来功能上的扩展,设计出员工基本信息表、工种类型表、职位表、部门表等十八个表。 4.3.2数据库概念结构设计
得到上面的数据项和数据结构以后,就可以设计出能够满足用户需求的各种实体,以及它们之间的关系,为后面的逻辑结构设计打下基础。这些实体包含各种具体信息,通过相互之间的作用形成数据的流动。
本系统根据上面的设计规划出的实体有:员工基本信息表、工种类型表、职位表、部门表等十八个表。 4.3.3数据库逻辑结构设计
数据的概念结构设计完之后,可以将上面的数据库概念结构转化为某种数据库系统所支持的实际数据模型,也就是数据库的逻辑结构。比如系统数据库中各表的详细设计如表所示。
表4-1员工基本信息表(hr_jbxxb)
第 13页 共 44页
西北工业大学毕业论文(设计)
字段名 yggh ygxm ygxb csrq xl zy lxfs jzdz zw xz rzsj ssbm zzzt 数据类型` Varchar(30) Varchar(30) Varchar(10) Varchar(20) varchar(20) varchar(20) Varchar(30) Varchar(100) Varchar(30) Float(8) Varchar(20) varchar(30) Varchar(10) 描述 员工工号 员工姓名 员工性别 出生日期 学历 专业 联系方式 居住地址 职务 薪资 入职时间 所属部门 在职状态
是否主键 √ 外键 是否为空 √ √ √ √ √ √ √ √ √ √ √ 表4-2工种类型 (hr_gzlxb)
字段名 gzbh gzmc 数据类型` Varchar(30) Varchar(30) 描述 工种编号 工种名称
表4-3职位类型 (hr_zwlxb)
字段名 zwbh zwmc 数据类型 Varchar(30) Varchar(30) 描述 职位编号 职位名称
表4-4员工状态( hr_ygzt)
字段名 zzztbh zzztmc 字段名 bmbh bmmc 数据类型 Varchar(30) Varchar(30) 数据类型 Varchar(30) Varvhar(30) 描述 在职状态编号 在职状态名称 是否主键 √ 外键 是否为空 √ 是否为空 √ 是否主键 √ 外键 是否为空 √ 是否主键 √ 外键 是否为空 √ 表4-5部门分类 (hr_bmflb) 描述 是否主键 外键 部门编号 部门名称 √
表4-6人事变动 (hr_rsbdb)
字段名 bmbh 数据类型 Varchar(30) 描述 人事变动编号 是否主键 √ 外键 是否为空 第 14页 共 44页
西北工业大学毕业论文(设计)
yggh ygxm ygxb bdqzw bdqbm bdqxz bdhzw bdhbm bdhxz sxrq pzr pzrq Varvhar(30) Varvhar(30) Varvhar(10) Varvhar(30) Varvhar(30) Flaot(8) Varvhar(30) Varvhar(30) Float(8) Varvhar(20) Varvhar(30) Varvhar(20) 员工工号 员工性名 员工性别 变动前职务 变动前部门 变动前薪资 变动后职务 变动后部门 变动后薪资 生效日期 批准人 批准日期 √ √ √ √ √ √ √ √ √ √
表4-7人事档案 (hr_rsdab)
字段名 yggh ygxm ygxb sfzh hyzk csrq mz sg tz lxfs jzdz jg xl zy wy byyx bysj sm 数据类型` Varchar(30) Varchar(30) Varchar(10) Varchar(30) varchar(10) Varchar(20) Varchar(30) int Int Varchar(30) Varchar(100) Varchar(100) varchar(20) Varchar(20) Varchar(20) Varchar(100) Varchar(20) varchar(2000) 描述 员工工号 员工姓名 员工性别 身份证号 婚姻状况 出生日期 民族 身高 体重 联系方式 居住地址 籍贯 学历 专业 外语 毕业院校 毕业时间 说明 是否主键 √ 外键 是否为空 √ √ √ √ √ √ √ √ √ √ √ √ √ √ √ √
表4-8专业资料 (hr_zyzlb)
字段名 zybh zymc 数据类型 Varchar(30) Varchar(30) 描述 专业编号 专业名称 第 15页 共 44页
是否主键 √ 外键 是否为空 √ 西北工业大学毕业论文(设计)
表4-9学历类型 (hr_xllxb)
字段名 xlbh xlmc 数据类型 Varchar(30) Varchar(30) 描述 学历编号 学历名称 是否主键 √ 外键 是否为空 √ 表4-10合同管理 (hr_htglb)
字段名 htbh yggh ygxm htlx htsx sxrq zzrq htxz qsrq htnr 数据类型 Varchar(30) Varvhar(30) Varvhar(30) Varvhar(30) Varvhar(30) Varvhar(20) Varvhar(20) Flaot(8) Varvhar(20) Varvhar(3000) 描述 合同编号 员工工号 员工性名 合同类型 合同属性 生效日期 终止日期 合同薪资 签署日期 合同内容 是否主键 √ 外键 是否为空 √ √ √ √ √ √ √
表4-11请假信息表(hr_qjxxb)
列名 qjdh ygbh qjsy swjj qjts spr rq 数据类型 vchar(30) vchar(30) vchar(400) vchar(100) int vchar(30) vchar(30) 描述 假条单号 员工编号 请假事由 事务交接 请假天数 审批人 日期 是否主键 √ 外键 √ 是否为空 √ √ √ √ √
表4-12出差信息表(hr_ccxxb)
列名 ccdh rq ygbh ccsy swjj ccts spr 数据类型 vchar(30) vchar(30) vchar(30) vchar(400) vchar(100) int vchar(30) 描述 出差单号 日期 员工编号 出差事由 事务交接 出差天数 审批人 是否主键 √ 外键 √ 是否为空 √ √ √ √ 表4-13考勤日历表(hr_kqrlb)
第 16页 共 44页
西北工业大学毕业论文(设计)
列名 kqh rq ygbh swcd swzt swkg xwcd xwzt xwkg 数据类型 vchar(30) vchar(30) vchar(30) int int int int int int 描述 考勤号 日期 员工编号 上午迟到 上午早退 上午旷工 下午迟到 下午早退 下午旷工 是否主键 √ 外键 √ 是否为空 √ √ √ √ √ √
表4-14用户表(hr_yhb)
列名 yhm mm yhms 数据类型 varchar(30) varchar(30) varchar(100) 描述 用户名 密码 用户描述 是否主键 √ 外键 是否为空 √
表4-15角色表(hr_jsb)
列名 jsbh jsm Jsmm 数据类型 varchar(20) varchar(30) Varchar(100) 描述 角色编号 角色名 角色描述 是否主键 √ 外键 是否为空 √ 表4-16角色分配表(hr_jsfpb)
列名 fpbh yhm jsbh 数据类型 uniqueidentifier(16) varchar(30) varchar(20) 描述 分配编号 用户名 角色编号
表4-17权限表(hr_qxb)
列名 qxbh qxm zydz 数据类型 varchar(20) varchar(30) varchar(100) 描述 权限编号 权限名 资源地址 是否主键 √ 外键 是否为空 是否主键 √ 外键 √ √ 是否为空
表4-18权限分配表(hr_qxfpb)
列名
数据类型 描述 第 17页 共 44页
是否主键 外键 是否为空 西北工业大学毕业论文(设计)
fpbh jsbh qxbh uniqueidentifier(16) varchar(20) varchar(20) 分配编号 角色编号 权限编号 √ √ √
第5章 系统详细设计
系统详细设计是对每个模块功能的具体设计,包括界面、功能模块和设计要点等内容。本次系统开发是分小组三人协同开发,我在本次开发中主要负责人事管理模块、考勤管理模块和系统设置三部分。
5.1人事管理模块详细设计
人事管理模块由人事基本信息、工种类型、职位类型、员工状态、部门信息、人事档案、人事变动、专业资料、学历类型和统计分析等子模块组成。 5.1.1人事基本信息
1.界面
员工基本信息设计界面如图5-1:
图5-1 员工基本信息设计
2.功能模块
从表hr_jbxx中查询出公司所有员工信息,在页面中动态生成表格记录。如果是修改,则从数据库中检索出被修改人员的数据,删除则从数据库中删除当前记录的数据。 3.设计要点
员工信息查询可查出公司所有员工的信息,多条记录需要分页功能,数据与工种类型表,职位类型表,在职状态表相关联。在删除数据时需要弹出确认窗口,避免误删。
第 18页 共 44页
西北工业大学毕业论文(设计)
5.1.2工种类型
1.界面
职工工种类型设计界面为图5-2: 2.模块功能
从表hr_gzlx中查询出公司所有工种信息,在页面中动态生成表格记录。如果是修改,则从数据库中检索出被修改工种的数据,删除则从数据库中删除当前记录的数据。 3.设计要点
工种类型可以任意添加,修改,当删除时如果此工种类型下有员工所属此工种类型,则无法删除。如果可以删除,需要弹出确认窗口,避免误删。
图5-2职工工种类型设计界面
5.1.3职位类型
1.界面
职位类型页面设计如图5-3:
第 19页 共 44页
西北工业大学毕业论文(设计)
图5-3职位类型页面
2.模块功能
从表hr_zwlx中查询出公司所有职位类型信息,在页面中动态生成表格记录。如果是修改,则从数据库中检索出被修改工种的数据,删除则从数据库中删除当前记录的数据。 3.设计要点
职位类型可以任意添加,修改,当删除时如果有员工所属此职位类型,则无法删除。如果可以删除,需要弹出确认窗口,避免误删。 5.1.4员工状态
1.界面设计:
员工状态界面设计如图5-4:
图5-4 员工状态界面设计
2.模块功能
从表hr_zzzt中查询出公司所有在职状态信息,在页面中动态生成表格记录。如果是修改,则从数据库中检索出被修改工种的数据,删除则从数据库中删除当前记录的数据。 3.设计要点
在职状态可以任意添加,修改,当删除时如果有员工所属此在职状态,则无法删除。如果可以删除,需要弹出确认窗口,避免误删。 5.1.5部门信息
1.界面设计:
部门信息界面设计如图5-5:
第 20页 共 44页
西北工业大学毕业论文(设计)
图5-5部门信息界面设计
2.模块功能
从表hr_bmfl中查询出公司所有部门信息,在页面中动态生成表格记录。如果是修改,则从数据库中检索出被修改部门的数据,删除则从数据库中删除当前记录的数据。 3.设计要点
部门分类可以添加,修改,当删除时如果有员工所属此部门分类,则无法删除。如果可以删除,需要弹出确认窗口,避免误删。 5.1.6人事档案
1.界面设计:
人事档案管理界面设计如图5-6:
图5-6人事档案管理界面设计
2.功能模块
从表hr_dagl中查询出所有员工的档案信息,在页面中动态生成表格记录。如果是修
第 21页 共 44页
西北工业大学毕业论文(设计)
改,则从数据库中检索出被修改员工档案的数据信息,删除则从数据库中删除当前记录的数据。 3.设计要点
档案信息可以添加,修改,如果要删除,需要弹出确认窗口,避免误删。 5.1.7专业资料
1.界面设计
专业资料管理界面设计如图5-7: 2.模块功能
从表hr_zyzl中查询出公司所有工种信息,在页面中动态生成表格记录。如果是修改,则从数据库中检索出被修改工种的数据,删除则从数据库中删除当前记录的数据。 3.设计要点
专业资料可以任意添加,修改,当删除时如果有员工所属此专业资料,则无法删除。如果可以删除,需要弹出确认窗口,避免误删。
图5-7专业资料管理界面设计
5.1.8学历类型
1.界面设计
学历类型的界面设计图5-8:
第 22页 共 44页
西北工业大学毕业论文(设计)
图5-8 学历类型的界面设计
2.模块功能
从表hr_xllx中查询出所有学历类型信息,在页面中动态生成表格记录。如果是修改,则从数据库中检索出被修改学历类型的数据,删除则从数据库中删除当前记录的数据。 3.设计要点
学历类型可以任意添加,修改,当删除时如果有员工所属此学历类型,则无法删除。如果可以删除,需要弹出确认窗口,避免误删。 5.1.9人事变动
1.界面设计
人事变动界面设计为图5-9: 2.模块功能
从表hr_rsbd中查询出公司所有人事变动信息,在页面中动态生成表格记录。如果是修改,则从数据库中检索出被修改部门的数据,删除则从数据库中删除当前记录的数据。 3.设计要点
如果执行添加人事变动信息功能,保存成功则在表hr_rsbd中添加一条记录,同时更新员工基本信息表hr_jbxx中数据,保存按钮同时操作两个表的数据。
第 23页 共 44页
西北工业大学毕业论文(设计)
图5-9人事变动界面设计
5.1.10合同管理
1.界面
合同管理界面设计图5-10:
图5-10合同管理界面设计
2.模块功能
从表hr_htgl中查询员工合同信息,查看合同概要,并提供合同详细信息查询。 3.设计要点
合同管理只提供添加,删除功能,不提供修改功能 5.1.11统计分析
1.人事管理统计分析界面设计如图5-11: 2.
第 24页 共 44页
西北工业大学毕业论文(设计)
如图5-11人事管理统计分析界面设计
2.模块功能
分析人事管理的员工职位比例报表、员工的学历分布报表、员工状态比例报表和员工专业分布报表。 3.设计要点
统计分析要做到反映公司部门职位、专业、学历和员工职位状态结构。 5.2考勤管理模块详细设计
该模块主要涉及到请假管理、出差管理、加班管理、出勤管理及相应的统计分析。 5.2.1请假管理模块
1.用户界面
请假管理用户界面设计如图5-12:
图5-12请假管理用户界面
第 25页 共 44页
西北工业大学毕业论文(设计)
2.模块功能
实现请假信息的填加,修改,查询等.
用户点击写入请假信息按钮将请假信息写入数据库 用户可以按员工编号或者日期,或者部门查询请假信息, 也可以将查询出来的请假信息删除之. 3.设计要点
1. 用户输入日期,输入员工编号后,当焦点离开输入框后,使用dwr技术[7]到员工信息表用员工编号查询取得员工的相应信息,自动填充员工姓名,部门,职位等信息.
2. 请假天数用户输入的是字符型数据,写入数据库要转换成数字整形.
3. 请假事由,事务交接两项内容包含的字符串比较长,应该注意数据库中相应的字段数据类型的长度. 5.2.2出差管理模块 1.用户界面:
出差管理界面设计如图5-13:
第 26页 共 44页
西北工业大学毕业论文(设计)
图5-13出差管理界面设计
2.模块功能:
实现出差信息的填加,修改,查询等。
用户点击写入请假信息按钮将出差信息写入数据库。 用户可以按员工编号或者日期,或者部门查询出差信息。 也可以将查询出来的出差信息删除之。 3.设计要点:
1. 用户输入日期,输入员工编号后,当焦点离开输入框后,使用dwr技术到员工信息表用员工编号查询取得员工的相应信息,自动填充员工姓名,部门,职位等信息.
2. 请假天数用户输入的是字符型数据,写入数据库要转换成数字整形.
3. 请假事由,事务交接两项内容包含的字符串比较长,应该注意数据库中相应的字段数据类型的长度. 5.2.3日常考勤管理模块 1.界面设计
考勤管理界面设计如图5-14:
图5-14考勤管理界面设计
第 27页 共 44页
西北工业大学毕业论文(设计)
2.模块功能
实现考勤功能.并能将考勤信息保存到数据库中.并具备查询考勤情况的功能. 3.设计要点
考勤信息和工资的计算有一定的关系,所以考勤管理这里着一块的信息保存和查询比较重要,当每月发工资的时候,就需要通过循环语句从一个月的30天请假信息中查询该员工编号有无请假信息,有的话,每天扣多少工资,总共扣多少工资. 然后在查询该员工有无迟到早退或者矿工信息,用循环语句可以从考勤信息表中查出该员工一个月的考勤信息.根据公司的规定,指定相应的处理。 5.2.4 加班管理模块 1.界面设计
加班管理模块界面设计如图5-15:
图5-15加班管理界面设计
第 28页 共 44页
西北工业大学毕业论文(设计)
2.模块功能
实现员工的加班考勤功能,对员工的加班考勤记录进行保存、删除、修改,并能按一定条件进行查询。 3.设计要点
1. 用户输入日期,输入员工编号后,当焦点离开输入框后,使用dwr技术到员工信息表用员工编号查询取得员工的相应信息,自动填充员工姓名,部门,职位等信息.
2. 加班天数用户输入的是字符型数据,写入数据库要转换成数字整形.
3.加班事由,事务交接两项内容包含的字符串比较长,应该注意数据库中相应的字段数据类型的长度. 5.2.5考勤数据分析
考勤数据分析包括四部分:请假考勤报表、出差考勤报表、日常考勤报表、加班考勤报表。
四部分的内容大体相同,所有界面进行统一设计。 1.界面设计
报表设计界面如图5-16:
图5-16报表界面设计
3.模块功能
报表设计主要是对记录的考勤数据进行具体分析并以直观的视图给我们显示出来,方便进行统计分析。例如:出勤报表:可以统计某段时间里各个部门的迟到、早退和矿工次数比例。
第 29页 共 44页
西北工业大学毕业论文(设计)
4.设计要点
开始时间结束时间都是用JavaScript实现,通过单击时间触发可以选择自己要统计的时间段。报表实现技术是jfreechar报表技术实现。 5.3权限管理 5.3.1用户管理
1.界面设计
用户管理的界面设计如图5-17:
图5-17用户管理的界面设计
2.模块功能
本模块是用户管理的主界面,一般只有管理员才有权使用,可以对用户进行添加、选择,浏览,删除与修改操作。 3.设计要点
用户描述应为用户的员工号(如果有的话)、真实姓名、所在部门、职务为系统管理员分配角色和权限提供参考。
删除用户时需有出现提示框,防止管理员误删用户。 5.3.2密码修改
1. .界面设计
密码修改界面设计如图5-18
第 30页 共 44页
西北工业大学毕业论文(设计)
图5-18密码修改界面设计
2.模块功能
本模块用以修改单前用户自己的密码,本功能只有当前用户能使用,即使是系统管理员也不能修改其它用户的密码。 3.设计要点
用户权限管理与用户名和密码有关的模块都需要用到“字符合法性检测”和防止Sql注入漏洞。 5.3.3角色管理
1. .界面设计
角色管理界面设计如图5-19:
图5-19角色管理界面设计
2.模块功能
本模块用于对角色的综合管理包括:添加新角色、删除已有角色、为角色分配权限,浏览系统所有角色。 3.设计要点
成功添加角色后角色并没有权限,需要调用“权限分配”模块,为角色分配权限。
第 31页 共 44页
西北工业大学毕业论文(设计)
5.3.4资源权限管理
1.界面设计
资源权限管理界面设计如图5-20:
图5-20资源权限管理界面设计
2.模块功能
对“权限”进行增、删、改、查操作。 3.设计要点
权限编号为主键,但权限名称也不允许重复。
第6章 系统实现
本系统是一个典型的MVC框架的扩展应用,首先表示层用jsp+servlet来实现,包括视图和控制器。模型层包括业务逻辑层和数据库持久层。业务逻辑层主要是应用了Fileter技术[8]进行过滤Action事务,数据库持久层主要是用了数据访问对象(DAO)和Factory设计模式来实现。 6.1系统开发环境
本系统采用java开发环境JDKI.6,Web服务器使用Apache的tomcat6.0,数据库使用SqlServer2005,开发工具为Eclipse5.5.
向开发的Java Web项目加入数据库驱动包、dwr包、jstl包、xml解析的jdom包;项目用到的库文件如图6-1所示。
第 32页 共 44页
西北工业大学毕业论文(设计)
图6-1项目用到的库文件
6.2创建配置文件 (1)web.Xml
通常所有的MVC框架都需要Web应用加载一个核心控制器,对于本本系统而言,需要加载ActionServlet,它就是本系统的核心控制器,只要Web应用加载了ActionServlet,就可以获得整个MVC框架所提供的服务。Web.xml_里 第 33页 共 44页 西北工业大学毕业论文(设计) (2)action-config.xml 通过web.xml文件把action-config.xml文件进行加载,在MVC框架中对action-config.xml文件进行jdom解析并根据解析到的参数解析跳转。例如系统登陆Action如下: 以上配置信息表示如果在系统登陆的时候能够正确的得到Login对应的Action,返回为success则进入系统,返回为failure则跳转到login.jsp登陆页面。 6.3实现数据持久层 (1)创建db-config.xml的配置文件 db-config.xml配置文件用于配置数据库连接属性以及Hibernate运行时所需的各种属性,包括指定数据库的驱动程序、连接数据库的URL、连接数据库的户名和口令、数据库方言、数据库名等。要将底层数据库内的变动映射到整个应用,只需要修改该文件内的属性值。配置文件有XML和Java属性文件两种形式。URL指定连接数据库的URL。driverClassName指定数据库的驱动程序。Username为数据库用户名,password是数据库登陆密码。db-config.xml文件如下: 第 34页 共 44页 西北工业大学毕业论文(设计) 本系统实现一个DTO接口把数据库中的表映射到一个持久化类,通过这种映射,系统把所有对对数据库表的操作都转移到为对java类的操作。 持久化类是指其实例需要持久化到数据库中的类。持久化类通常都是域模型中的实体域类。持久化类符合JavaBean的规范,包含一些属性,以及与之对应的getter和setter方法。数据库中有几个表就有几个持久化类。 以下是角色分配表对应的一个持久化类: import com.softstone.model.DTO; public class Hr_jsfpbDTO implements DTO { private String fpbh; private String yhm; private String jsbh; public String getFpbh() { return fpbh; } public void setFpbh(String fpbh) { this.fpbh = fpbh; } public String getYhm() { return yhm; } public void setYhm(String yhm) { this.yhm = yhm; } public String getJsbh() { return jsbh; 第 35页 共 44页 西北工业大学毕业论文(设计) } } public void setJsbh(String jsbh) { this.jsbh = jsbh; } (3)通过DAO操作数据库。 DAO是一个对DTO持久化类操作的接口,其中定义了query(String pk)方法、update(DTO dto)方法、add(DTO dto)方法、delete(String pk)方法、List query(String pk)方法:查询数据库中PK用户信息; update(DTO dto)方法:更新数据库中域对象的状态; add(DTO dto)方法:增加数据库中域对象的状态; delete(String pk)方法:删除数据库域对象的状态; List public DTO query(String pk) { Hr_jsbDTO jsDTO = null; try { PreparedStatement pstmt = conn.prepareStatement(SQL_SELECT); pstmt.setString(1, pk); ResultSet rs = pstmt.executeQuery(); if (rs != null && rs.next()) { jsDTO = new Hr_jsbDTO(); jsDTO.setJsbh(rs.getString(\"jsbh\")); jsDTO.setJsm(rs.getString(\"jsm\")); jsDTO.setJsms(rs.getString(\"jsms\")); } rs.close(); pstmt.close(); } catch (SQLException e) { e.printStackTrace(); } return jsDTO; } update(DTO dto)方法代码如下: public int update(DTO dto) { Hr_jsbDTO jsDTO = (Hr_jsbDTO) dto; 第 36页 共 44页 西北工业大学毕业论文(设计) } } int flag = 0; try { PreparedStatement pstmt = conn.prepareStatement(SQL_UPDATE); pstmt.setString(1, jsDTO.getJsm()); pstmt.setString(2, jsDTO.getJsms()); pstmt.setString(3, jsDTO.getJsbh()); flag = pstmt.executeUpdate(); pstmt.close(); } catch (SQLException e) { flag = 0; e.printStackTrace(); } return flag; add(DTO dto)方法代码如下: public int add(DTO dto) { Hr_jsbDTO jsDTO = (Hr_jsbDTO) dto; int flag; try { PreparedStatement pstmt = conn.prepareStatement(SQL_ADD); pstmt.setString(1, jsDTO.getJsbh()); pstmt.setString(2, jsDTO.getJsm()); pstmt.setString(3, jsDTO.getJsms()); flag = pstmt.executeUpdate(); pstmt.close(); } catch (SQLException e) { flag = 0; e.printStackTrace(); } return flag; } delete(String pk)方法代码如下: public int delete(String pk) { int flag = 0; try { PreparedStatement pstmt = conn.prepareStatement(SQL_DELETE); pstmt.setString(1, pk); flag = pstmt.executeUpdate(); pstmt.close(); } catch (SQLException e) { e.printStackTrace(); } 第 37页 共 44页 西北工业大学毕业论文(设计) } return flag; List public List conn.prepareStatement(SQL_SELECT_ALL,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); ResultSet rs = pstmt.executeQuery(); this.setStartRow(rs); while (rs != null && rs.next()) { if(this.isPagination&&rs.getRow()>pagination.getEndRow())break; Hr_jsbDTO jsDTO = new Hr_jsbDTO(); jsDTO.setJsbh(rs.getString(\"jsbh\")); jsDTO.setJsm(rs.getString(\"jsm\")); jsDTO.setJsms(rs.getString(\"jsms\")); yhList.add(jsDTO); } rs.close(); pstmt.close(); } catch (SQLException e) { e.printStackTrace(); } return yhList; } 6.4控制层的实现 控制层负责接收用户请求、更新模型,以及选择合适的视图组件返回给用户,在本系统的实现中控制层是实现对一个抽象类Action的继承来实现,通过继承Action中的execute(HttpServletRequest request, HttpServletResponse response)的方法,另外还有一个ActionServlet类继承了HttpServlet并对action-config.xml文件进行加载并解析。Action负责处理一项具体的业务,它是用户请求和业务逻辑之间的桥梁,每个Action充当客户的一项业务代理。Action的主要功能是接收页面中的一些数据,然后根据action-config.xml实例包含的映射信息决定将当前的请求转发给哪个Action。Action的工作就是通过访问HTTP会话、HTTP请求和表单参数等调用业务逻辑,最后把响应映射到以持久化类形式存在的模型上,来完成特定的功能。最后,Action返回的结果会通过配置文件映射到JsP页面上,JSP会渲染视图并显示给用户,以下是Action类部分代码: public abstract class Action { protected final String SUCCESS=\"success\"; protected final String FAILURE=\"failure\"; 第 38页 共 44页 西北工业大学毕业论文(设计) protected ActionMessage message=new ActionMessage(); protected Connection con; public String process(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { request.setAttribute(\"message\ return execute(request, response); } public void setConn(Connection conn){ this.conn=conn; } 6.5系统WEB层实现 本系统的WEB层的实现主要是jsp技术结合JSTL标签来实现。Jsp技术主要是用于显示用户界面,发送Action请求和接收响应完成交互,做到了视图与业务逻辑层的解耦。JSTL标签库为表示层提供了大量丰富的标签库,有利于JSP项目迁移到别的项目中、扩展页面功能和易于维护的优势。本系统每个显示页面都是由两部分组成:头页面,主页面。头页面做成了一个jsp文件,在每一个显示页面中只要将这两个文件include进来就可以。这样使得系统页面的整体风格一致,同时也避免了代码重复编写,程序员只需为每个页面实现其中间的主体部分。本系统除index.jsp页面外所有的显示页面都由action转发过来,在action中将页面所需要的数据封装成对象,jsp页面直接从容器中获取数据,通过这种数据传递方式避免了在页面写入java代码,从而使得显示层和逻辑层耦合性大大降低。 6.6系统部署 本系统的系统部署如6-12图: 图6-1系统部署图 第 39页 共 44页 西北工业大学毕业论文(设计) 6.7系统界面介绍 登陆页面如图6-2,为本系统的入口,用户输入正确的用户名和密码才能进入系统主页: 图6-2登陆页面 系统主页页面如图6-3:系统主页主要是系统的功能结构,相应的权限用户可以双击进入相应的模块进行操作,中间左部分系统默认显示的是招聘管理内容。 第 40页 共 44页 西北工业大学毕业论文(设计) 图6-3系统主页 人事管理页面如图6-4: 图6-4人事管理页面 考勤管理页面如图6-5: 第 41页 共 44页 西北工业大学毕业论文(设计) 图6-5考勤管理页面 系统设置管理页面图6-6: 图6-6系统设置页面 第7章 总结 本系统的设计实现基本上满足了用户需求,性能需求,比较容易维护;开发框架松散耦合度高、可扩展且高效;代码重用性较高,利于调试和测试。 对本系统的开发大致总结如下: 1.人力资源管理系统用MVC框架扩展开发,使得层次之间达到一定的松散耦合。在开发过程中各个层与层之间的工作是相对独立的,不同的业务逻辑可以基于模块开发,有利于团队协同开发。业务规则、输入校验存在于中间控制层,因此当业务规则发生改变或增加时,只需要更改或增加相应业务处理逻辑,在很短的时间内就能完成系统开发和部署, 第 42页 共 44页 西北工业大学毕业论文(设计) 而客户端应用程序不需要做任何逻辑处理,能很好的满足了各个部门快速多变的业务需求,从而拥有了很好的可扩展性和可维护性。 2.系统利用DTO的对象持久化服务,更有效地进行数据库数据到业务对象的O/R映射,简化了客户端对数据库数据的操作过程。开发人员可以专心地实现业务逻辑而不用分心于烦琐的数据库方面的逻辑,减小了出错机会,同时能为开发小组提供更合理的模块划分方法,节约开发成本和时间,提高业务应用的性能,提供灵活的业务逻辑。 3.系统中存在业务逻辑过于烦琐、页面跳转结构复杂问题。控制层中的Action映射复杂,对象关系之间的映射操作工作量大,配置文件过多,当页面表单频繁变化时灵活性较差,jsp标签库jstl维护的成本较高,维护难度大。所以如果采用Struts2、Hibernate、Spring三层框架对系统进行有效整合,可以对本系统的层次和业务逻辑分析更加的清晰完善。 4.系统开发中的需求分析主要是通过从网络资料中提取,没有太多的与实际的公司人力资源管理的相关人员进行沟通,因此需求分析有些地方可能不太合理和健全。在系统实现的时候就会出现系统功能实现不是很优化、高效。 致谢(References) 在论文完成之际,首先我要感谢一直指导我直至论文完成的老师,在老师细致的指导下,这篇论文才得以完成! 我还要感谢学院的所有老师。作为一名学生,我有机会得到老师们的教导,学习计算机科学知识,这是我大学阶段一段难忘的经历。学院老师们渊博的专业知识,严谨的治学态度给我留下了深刻的影响。 同时也要感谢我的同学,在这次论文完成中,他们给予了我极大的帮助和鼓励,在开始写论文时,我曾因为对一些开发工具不熟而一度沮伤,他们给予了我鼓励并帮助我快速熟悉开发工具,这次论文才得以完成。 参考文献: [1].俞彩云、李士雨企业人力资源管理系统的分析与设计计算机应用与研究,2004,21(2):186—188 [2]. 王锋,张景,何文娟等基于Internet的人力资源管理系统微机发展,2003,13(9):95—97 [3].张海藩编著<<软件工程导论>>(第四版) 清华大学出版社 第 43页 共 44页 西北工业大学毕业论文(设计) [4].孙卫琴著<<精通Struts:基于MVC的Java Web设计与开发>>2007年03月电子工业出版社 [5].李刚编著<<疯狂Java讲义>>电子工业出版社 [6].程云志、张帆、崔翔编著<<数据库原理与SQL Server 2005应用教程>>机械工业出版社 [7].单东林、张晓菲、魏然著<<锋利的jQuery(前端开发系列) >>2009年06月人民邮电出版社 [8].李宁等编著< 第 44页 共 44页 因篇幅问题不能全部显示,请点此查看更多更全内容