企业员工信息管理系统的设计与实现论文.docx
本科毕业设计说明书企业员工信息管理系统的设计与实现 学院(部):专业班级: 学生姓名: 指导教师: 2012年 5月25日企业员工信息管理系统的设计与实现摘要 现今互联网发展越来越迅速,给人们的工作和生活带来了极大的便利和高效,信息化,电子化已经成为节约运营成本,提高工作效率的首选。因此在信息化科技飞速发展的今天,借助于电脑,通过员工信息管理系统管理各部门职工,能为企业人力资源的管理者提供人性化的服务。同时也能为企业的员工提供一定的方便。本系统具有多方面特点:系统功能完备,用户使用方便简捷,人性化的用户界面,安全BaoMi设置齐全,大大减少了操作人员和用户的工作负担,提高了企业员工信息管理的工作效率和企业的信息化的水平。本论文从员工信息管理系统的初步调查开始,详细介绍员工信息管系统的需求分析和数据流程分析,并进行了系统总体结构设计、数据结构和数据库设计、输入输出设计等。 关键词:J2,2,企业员工信息管理 , , 's , , , , a . a , , , a , . , , , a , , , .2, 2 目录摘要I1 绪论11.1 课题来源11.2 研究目的11.3 研究意义22 方案论证32.1 可行性要求32.1.1 经济可行性32.1.2 技术可行性32.2 需求分析92.2.1 系统用户92.2.2 系统功能需求103 系统设计113.1 系统架构设计113.2 系统功能模块设计113.2.1 登录页面113.2.2 模块分析123.3 业务实体设计163.4 设计域模型163.5 设计数据模型174 网站前台的设计194.1 网站登录界面的设计194.2 员工信息管理界面设计204.3 部门管理页面设计224.4员工工资管理设计244.5 员工考勤管理设计244.6 用户密码修改模块的设计264.7 退出系统模块的设计265 网站模块功能的实现275.1 用户登录实现275.2 员工信息管理模块实现285.3 部门管理模块的实现315.4 工资管理模块的实现335.5 考情管理模块的实现335.6 系统管理模块的实现356 软件测试366.1 模块测试366.2 集成测试36结论38参考文献39致谢401 绪论随着计算机技术、网络技术和信息技术的发展,现在办公系统更趋于系统化、科学化和网络化。网络办公自动化系统是计算机技术和网络迅速发展的一个办公应用解决方案,它的主要目的是实现信息交流和信息共享,提供协同工作的手段,提高办公的效率,让人们从繁琐的有纸办公中解脱出来。现在许多的机关单位的员工信息管理水平还停留在纸介质的基础上,这样的机制已经不能适应时代的发展,因为它浪费了许多人力和物力,在信息时代这种传统的管理方法必然被计算机为基础的信息管理所取代。本系统就是基于本企业的员工信息管理而设计的,是对企业的员工信息资料进行管理,为人事管理人员提供了一套操作简单、使用可靠、界面友好、易于管理和使用的处理工具。本系统对人事各种数据进行统一处理,避免数据存取、数据处理的重复,提高工作效率,减少了系统数据处理的复杂性。本系统不仅使学院人事管理人员从繁重的工作中解脱出来,而且提高了人事管理的效率,提高了人事管理的科学性,方便了用户查询、管理人员进行管理。在已跨入21世纪的今天,各个大中型企业,乃至小型企业都趋向于电子化智能化管理,不在止步于账本和笔,通过各种各样的软件管理系统,加快了企业的人员信息管理,同时也减轻了人们的工作压力。1.1 课题来源随着科学技术的发展企业公司已经迈入智能化、网络化,越来越多的事件都是通过网络来处理,所以一个应用于企业员工信息管理的软件也是越来越重要。通过这个软件可以很简单的对企业的员工基本信息资料、部门信息和员工考勤来管理,很大程度的提高了企业的人事管理的办事效率,同时也减轻了企业的工作压力。近年来网络盛行,丰富的内容加上绚丽的页面,具有丰富的多媒体表现与互动特点,毋庸置疑, 网站已成为最吸引人的也最有效的信息传递手段和方式。1.2 研究目的为企业提供一个能够方便的管理员工信息的软件,可以实现公司对员工以及部门信息的操作,同时能够在此次的设计中有一个良好的锻炼过程。立志于为满足企业的需要,站在企业人事部门的角度考虑,完成此次设计。1.3 研究意义做一个企业员工信息管理系统,就是为了满足企业需求所定制的,所以他首先要做的是满足最基本得员工信息的增删改查,在此基础上进行功能的扩展,其次是部门管理,工资管理等等。一个正规性企业都希望自己的员工管理非常合理,如此复杂性的操作如果通过人手动的写,会非常的麻烦。基于这一点考虑到设计一个管理类型的软件,来解决这个繁琐的问题,方便与企业的工作管理以及一些制度的规定。在企业中,员工信息管理工作是非常重要的一项工作,它负责整个企业的日常人事安排,员工的人事管理等。高效的人事管理可以提高企业的市场竞争力,使企业具有更强的凝聚力和活力。为此,提高员工管理工作的效率,设计一套员工信息管理系统具有实际应用意义。2 方案论证2.1 可行性要求开发任何一个基于计算机的系统都会受到时间和资源的限制。因此在开发软件项目之前,必须根据可利用的时间和资源等条件进行可行性研究。可行性研究工作的主要任务不是研究如何解决问题,而是要用最小的代价在最短的时间内确定该项目是否具有开发的可行性。可行性研究主要包括经济可行性研究,技术可行性研究,运行、操作可行性研究,法律可行性研究和开发方案的选择。典型的可行性研究应从以下几步进行。(1)复查初步分析结果。对系统初步的分析结果和报告书进行复查,改正含糊或不确切的叙述,重新确定系统目标与规模,清晰地描述对系统的所有约束条件。(2)研究现有的条件。找出其基本功能和基本信息,指出其缺点或局限性。(3)导出新系统高层逻辑模型。用某种图形工具导出系统高层逻辑模型,并与现有系统进行比较。(4)导出新系统的高层物理解法,提出多个供选择的解决方案,并对每一个方案的经济可行性、技术可行性、运行和操作可行性等进行分析比较。(5)推荐建议的方案。如果系统分析员人为之得开发,则应指出开发的价值、推荐方案的理由,并为推荐的系统草拟一份开发计划,并提交可行性研究报告等全部文档。若分析员认为不值得开发,也应拿出充分的理由。(6)评审、复审和决策。可行性研究最后要通过技术评审和管理复审,开发方和客户方或使用部门负责人根据成本-效益分析等各项可行性研究的结论决策是否继续这项工程。而对于我的这次毕业设计来说可行性研究就是主要从两个方面考虑,一是经济可行性研究;二是自身的软件开发技术水平,即技术可行性研究。2.1.1 经济可行性开发一个本系统的开发可以解决企业人事管理遇到的耗费大量资金和人力,管理内容繁复,而且容易丢失的问题。本系统的开发周期为2个月,耗费资金较少,且实用价值很高,各类企事业单位及学校等部门都可以使用。2.1.2 技术可行性1、数据库是一个快速、多线程、多用户的数据库服务器, 其出现虽然只有短短的数年时间,但凭借着“开放源代码”的东风,它从众多数据库中脱颖而出,成为的首选数据库。相比较其他数据库而言,可以称得上是目前运行速度最快的语言数据库。除了具有其他数据库所不具备的功能和选择之外,数据库是一种完全免费的产品,用户可以直接从网上下载数据库,用于个人或商业用途,而不必支付任何费用,这也是我选择用数据库的主要原因,除此之外还具有以下主要特点:(1)的核心程序采用完全的多线程编程。线程是轻量级的进程,它可以灵活地为用户提供服务,而不过多地占用系统资源。用多线程和C语言实现的能容易充分利用。(2)可运行在不同的操作系统下。简单地说,可以支持95/982000以及、等多种操作平台。这意味着在一个操作系统中实现的应用可以很方便地移植到其他操作系统下。(3)有一个非常灵活而且安全的权限和口令系统。当客户与服务器连接时,他们之间的所有口令传送被加密,而且支持主机认证。(4)支持大型的数据库。虽然对于用编写的网页来说只要能够存放上百条以上的记录数据就足够了,但可以方便地支持上千条记录的数据库。作为一个开放源代码的数据库,可以针对不同的应用进行相应的修改。(5)拥有一个非常快速而且稳定的基于线程的内存分配系统,可以持续使用而不必担心其稳定性。事实上,的稳定性足以应付一个超大规模的数据库。2、开发技术的选择1)J2(1)简化结构J2平台支持简化的、基于组件开发模型,由于J2基于编程语言和J2平台,它提供了编写一次,随处运行的可移植性,遵循J2标准的所有服务器都支持该模型。组件使编写应用程序更为简单。尽管体系结构复杂,但应用程序开发人员一般都必再编写访问系统服务的代码,容器会实现系统级的服务,例如,事务、安全性等。另外,J2还支持异构环境。基于J2的应用程序不依赖任何特定操作系统、中间件或硬件,因此,设计合理的基于J2的程序只需开发一次就可以部署到各种平台,这在典型的异构企业算环境中是十分关键的。J2标准还允许客户订购与J2兼容的第三方的现成组件,把其部署到异构环境中,节省了由自己制订整个方案所需的费用。(2)提高开发效率由于组件技术的使用,可以按照开发人员的技能对应用程序开发进行分工,并行开发,提供整体开发效率。例如:图形设计师创建模板,商业逻辑由该领域的专家完成,页面和由工程师完成,应用程序的装配和部署由团队中其他的成员完成,其中许多工作可以同时进行,有助于加速应用程序的开发。(3)可移植性强除了语言固有的可移植性外,体系结构在和支持该的容器之间提供了一套标准化的应用程序编程接口,这使开发人员能够将从一种操作环境移植到另一种操作环境,而无需重新编写其源代码。(4)重用性好由于在模型中,各个软件组件都是严格分离的,因此,可以从现有的软件组件装配出服务器端应用程序,这与从现有的可以装配出客户端应用程序一样,使软件能够重用。(5)易于维护基于组件的设计简化了应用程序的维护。由于组件可以被独立地更新和替代,通过更新应用程序中特定的组件,新的功能可以被很容易地增加。(6)可伸缩性企业必须要选择一种服务器端平台,以便满足那些在它们系统上进行商业动作大批新客户。基于J2平台的应用程序可被部署到各种操作系统上,例如,可被部署到高端或其他的大型机系统上。J2领域的供应商提供了更为广泛的负载平衡策略,能消除系统中的瓶颈,允许多台服务器集成部署,实现可高度伸缩的系统,满足未来商业应用的需要。(7)被广泛接受主要的供应用商都采纳体系结构,不同供应商的产品只要符合体系结构,就都是可互操作的。(8)保护投资由于企业必须适应新的商业需求,充分利用现有的企业信息系统投资,而不是重新制定,全盘更新方案就变得尤为重要,这样,一个以渐进的(而不是激进的,全盘否定的)方式建立在现有系统之上的服务器平台是大多数公司所希望的。J2架构可以充分利用用户有的投资,通过允许将现有的信息系统和资产“包裹”在J2应用程序中,不要求客户更换现有技术。事实上,在关系数据库中存储数据的企业,已经有了一套已具雏形的实体,正等着通过外壳去访问。这之所以成为可能,主要是因为J2拥有广泛的业界支持和一些重要的“企业计算”领域供应商的参与,每一个供应商都对现有的客户提供了不用废弃自己已有投资的升级途径。由于基于J2平台的产品几乎能够在任何操作系统和硬件运行,现有的操作系统和硬件也能被保留使用。2)模式模型视图控制器()是 在八十年代为编程语言80发明的一种软件设计模式,至今已被广泛使用。最近几年被推荐为公司J2平台的设计模式,并且受到越来越多的使用 和 的开发者的欢迎。模式的好处各施其职,互不干涉。在模式中,三个层各施其职,所以如果一旦哪一层的需求发生了变化,就只需要更改相应的层中的代码而不会影响到其它层中的代码。网页设计人员可以进行开发视图层中的,对业务熟悉的开发人员可开发业务层,而其它开发人员可开发控制层。有利于组件的重用分层后更有利于组件的重用。如控制层可独立成一个能用的组件,视图层也可做成通用的操作界面。()应用程序结构被用来分析分布式应用程序的特征。这种抽象结构能有助于将应用程序分割成若干逻辑部件,使程序设计变得更加容易。结构提供了一种按功能对各种对象进行分割的方法(这些对象是用来维护和表现数据的),其目的是为了将各对象间的耦合程度减至最小。结构本来是为了将传统的输入()、处理()、输出()任务运用到图形化用户交互模型中而设计的。但是,将这些概念运用于基于的企业级多层应用领域也是很适合的。在结构中,模型()代表应用程序的数据()和用于控制访问和修改这些数据的业务规则( )。通常模型被用来作为对现实世界中一个处理过程的软件近似,当定义一个模型时,可以采用一般的简单的建模技术。当模型发生改变时,它会通知视图(),并且为视提供查询模型相关状态的能力。同时,它也为控制器()提供访问封装在模型内部的应用程序功能的能力。一个视图()用来组织模型的内容。它从模型那里获得数据并指定这些数据如何表现。当模型变化时,视负责维持数据表现的一致性。视同时将用户要求告知控制器()。控制器()定义了应用程序的行为;它负责对来自视的用户要求进行解释,并把这些要求映射成相应的行为,这些行为由模型负责实现。在独立运行的客户端,用户要求可能是一些鼠标单击或是菜单选择操作。在一个应用程序中,它们的表现形式可能是一些来自客户端的或的请求。模型所实现的行为包括处理业务和修改模型的状态。根据用户要求和模型行为的结果,控制器选择一个视作为对用户请求的应答。通常一组相关功能集对应一个控制器。(1)各施其职,互不干涉在模式中,三个层各施其职,所以如果一旦哪一层的需求发生了变化,就只需要更改相应的层中的代码而不会影响到其它层中的代码。假如业务发生了变化,如在取文章时可能把一些文章作了无效标志,不能直接把所有文章取出来,只能取出有效的文章,这时业务就发生了改变。再设想一下,如果这个业务逻辑在100个页面中都要用到,那么模式就体现了它的灵活性。我们可以不更改任何,只要更改层中的相应类中的语句即可。(2)有利于开发中的分工在模式中,由于按层把系统开,那么就能更好的实现开发中的分工。网页设计人员可以进行开发视图层中的,对业务熟悉的开发人员可开发业务层,而其它开发人员可开发控制层。(3)有利于组件的重用分层后更有利于组件的重用。如控制层可独立成一个能用的组件,视力层也可做成通用的操作界面。3)2框架的使用此次程序中主要的是引入了2和框架。传统的 应用程序是采用来实现的,这种模式实现了最基本的分层,使得程序结构分为几层,有负责显示的、负责流程逻辑控制的、负责数据封装的。但是这种结构仍然存在问题:如页面中需要使用符号嵌入很多的代码,造成页面结构混乱,和负责了大量的跳转和运算工作,耦合紧密,程序复用度低等等。于是便是首先出来了。而 2是的下一代产品,是在 和的技术基础上进行了合并的全新的 2框架。其全新的 2的体系结构与 1的体系结构的差别巨大。 2以为核心,采用拦截器的机制来处理用户的请求,这样的设计也使得业务逻辑控制器能够与 完全脱离开,所以 2可以理解为的更新产品。虽然从 1到 2有着太大的变化,但是相对于, 2只有很小的变化。2使用了的设计核心,而不是1的设计核心。2中大量使用拦截器来处理用户的请求,从而允许用户的业务逻辑控制器与 分离。2 框架由3个部分组成:核心控制器()、业务控制器和用户实现的业务逻辑组件。核心控制器()是2框架的核心控制器,该控制器作为一个运行在应用,它负责拦截所有的用户请求,当用户请求到达时,该会过滤用户请求;业务控制器组件就是用户实现类的实例;应用里的模型组件,通常指系统的业务逻辑组件,而隐藏在系统的业务逻辑组件下面的可能还包含、领域对象等组件,这也就是2的模型组件,同时2能使用、等作为视图技术。 2框架的大致处理流程如下:(1)浏览器发送请求,例如请求、等。(2) 中的核心控制器根据请求调用相应的业务逻辑控制器()。(3)回调中的()方法,并在方法体内调用业务逻辑组件来处理请求()。既可以是将数据保存到数据库,也可以从数据库中检索信息。实际上,因为只是一个控制器,它会调用业务逻辑组件来处理用户的请求。(4)返回响应,通过方法将信息返回到。(5)查找响应,根据配置查找响应的是什么信息如:、,将跳转到哪个页面。(6)响应用户(>客户浏览器端显示)。 4)的使用是一个开放源代码的对象关系映射框架,它对进行了非常轻量级的对象封装,使得程序员可以随心所欲的使用对象编程思维来操纵数据库。 可以应用在任何使用的场合,既可以在的客户端程序使用,也可以在的应用中使用,最具革命意义的是,可以在应用的J2架构中取代,完成数据持久化的重任。减低各个模块之间的耦合性。5)的使用是一个开源框架,它由 创建。它是为了解决企业应用开发的复杂性而创建的。使用基本的来完成以前只可能由完成的事情。然而,的用途不仅限于服务器端的开发。从简单性、可测试性和松耦合的角度而言,任何应用都可以从中受益。传统J2应用的开发效率低,应用服务器厂商对各种技术的支持并没有真正统一,导致J2的应用没有真正实现 及 的承诺。作为开源的中间件,独立于各种应用服务器,甚至无须应用服务器的支持,也能提供应用服务器的功能,如声明式事务、事务处理等。致力于J2应用的各层的解决方案,而不是仅仅专注于某一层的方案。可以说是企业应用开发的“一站式”选择,并贯穿表现层、业务层及持久层。然而,并不想取代那些已有的框架,而是与它们无缝地整合。3、 开发工具的选择 是一个( ),而这个是允许安装第三方开发的插件来使自身的功能得到扩展和增强的,而就是其中的一种有名的插件集之一,将开发者常用到的一些有用的插件都集合起来,但它是收费的。是一个开放源代码,基于的可扩张的开发平台,多数人都是将作为的集成开发环境使用,虽然使用开发:但不仅仅局限于开发,还可用于其它语言的开发,如;是一个框架和一组服务,它通过各种插件来构建开发环境,因此只要提供支持 插件便能进行相应语言的开发。为提供了一个大量私有和开源的工具的集合,这解决了各种开源工具的不一致和缺点。是一个繁杂而强大的加速 应用开发的工具,还包含了一个强大且能够编译所有和 应用的工具。这些工具解析和配置文件。的实际价值来自包含的发布包中的大量的工具。如的编辑器,帮助创建和项目的向导并产生项目的所有主要的组件如 等。还包含编辑配置文件和执行语句的工具。 2.2 需求分析从一个企业的角度来设计这个网站,首先要了解用户需要什么,从这一点出发来把这个软件的内容填充起来。在满足用户的基础上对网站功能的一个丰富化,每当做完一个功能就站在客户的立场对功能进行评测,如果有需要改善的地方,则在慢慢的进行完善。本软件主要是对企业的员工进行的一种管理,人员的工资,所属部门,考勤进行统一的管理。这里涉及到的不同的公司里面可能所需要的赏罚制度不一样所以就没有更多的进行。本系统就是一个架构原型,在此功能上可以更加的完善和美化。2.2.1 系统用户本系统有定义了两个用户,普通用户,管理员,不同用户能够执行的功能是不一样的,普通用户只能查看自己的信息,管理员可以对每个员工的信息,部门信息进行增删改查操作。2.2.2 系统功能需求(1)用户登录用户在登录系统的时候首先是进入系统的登录界面,前面接受的用户名,密码以及所属身份权限去后台进行验证,如果用户名不存在返回登录页面,如果存在用户名则就验证密码,如果密码也存在就成功跳转到菜单页面,如果密码错误则返回登录页面,并提示相应信息。(2) 系统功能分析本系统主要是考虑对公司人员的一个管理,从基本功能出发,首先是员工,其次是部门,再者是考勤,最后是工资。还有一个系统功能是用户来自己修改自己的登录密码。员工:满足添加一个员工,对员工的增删改查等操作。在这里也可以对员工的身份权限和职位进行管理。在这里当添加一个员工的时候就为其分配了身份权限,以及记录了所对应的职位。每个员工在建立的时候都默认的为其分配了一个相应的用户名和密码,用户名就是为其分配的员工编号,密码开始默认为6个0。员工添加了以后,员工可以去系统用户管理界面对自己的密码进行修改以防止有人冒用。部门:考虑到一个公司里面的部门可能是因为一些事情的原因,因而进行了某些变动,通过这里可以对部门进行修改。考勤:公司里面难免少不了员工的迟到,缺勤等诸多事情,在这个时候考虑人事部此时要了解信息,并且对人员在进行合理的分配要做出一定统筹安排。工资:不同的员工根据能力的不同因而给的报酬也相应的不同,从这里入手对员工工资进行一个管理。3 系统设计3.1 系统架构设计我把整个系统划分为四大块,视图层,控制层,业务层,持久化层。视图层主要负责向用户显示或者向后台传递数据,而控制层则是实现对前台数据传来的值进行判断和控制,通过与业务层之间的接口来实现数据的传入和传输,之间的通过单一接口来降低模块之间的耦合性。从而方便与代码的修改和后期的功能添加。3.2 系统功能模块设计 系统功能模块划分如图3-1所示,主要分为员工信息管理页面、部门管理页面、考勤页面、工资页面和系统管理页面。 企业员工信息查询系统系统管理 考 勤部门管理员工工资管理员工信息管理考勤查看考勤登记员工工资查询登陆密码修改部门添加部门查找员工添加员工查找图3-1 企业员工信息管理系统功能模块图3.2.1 登录页面登录成功后进入主菜单页面,失败则返回登录页面,并且提示错误信息。页面根据登录人员的权限进入不同主菜单页面,只有管理员才能进行更多的操作,而普通用户只能进行少部分的操作。具体流程如图3-2所示。 开 始 登 录 N 验 证 Y 根据不同的权限进入不同菜单页面图3-2 系统登录流程图3.2.2 模块分析1、员工信息管理设计管理员可以对员工进行增删改查的操作,而普通用户只能进行查询。如图3-3所示。全部员工信息查看 管理员用户 员工信息管理模块员工信息修改员工信息删除员工信息添加自身信息查看 普通用户图3-3 员工信息管理功能模块关系图(1)增加用户页面对员工的基本信息进行添加,员工的基本信息如图3-4所示。 职员编号职员姓名 民族 性别家庭地址文化程度婚姻状况 职工基本信息固定电话出生日期 手机部门号入职时间图3-4 员工基本信息图(2)员工信息查看可以查看员工的信息,对员工的信息作相应的修改,并且能删除员工信息。 具体流程如图3-5所示。员工查找 详细查看 员工查看 员工信息管理员工信息修改员工信息删除 图3-5 员工查看流程图2、部门管理设计只有管理员才能对部门进行进行增删改查的操作。具体的部门信息如图3-6所示。 部门编号部门电话部门名部门经理设立时间 部门信息图3-6 部门信息图部门的查看流程如图3-7所示。部门查找 部门查看部门信息修改 部门管理部门删除图3-7 部门查询流程图3、 系统用户信息这里不管管理员还是普通员工都可以修改自己的登录密码。密码修改流程如图3-8所示。 密码修改输入旧密码和新密码 修改成功 返回登录页面图3-8 用户密码修改流程图4、考勤页面设计只有管理员有对员工迟到,早退,缺勤考勤登记的权限,普通员工的只有请假的权限考勤进行增查改。如图3-9所示。员工考勤查询 管理员用户 考勤管理模块 员工考勤登记 自身考勤查看 普通用户 请 假 图3-9 考勤管理功能模块关系图5、 工资管理这个功能只有管理员才能够使用。本系统已经制定了赏罚制度,就是迟到扣除多少钱,早退扣除多少钱,等如此类的赏罚,本系统根据不同的职位设定的基础工资不同,在原有的基础工资上进行了进行赏罚。对赏罚制度设定了一个算法,用来计算每个员工的工资。3.3 业务实体设计业务实体在内存中表现为实体域对象,在数据库中表现为关系数据。实现业务实体包括以下内容:(1) 设计域模型,创建域模型实体对象。(2) 设计数据模型。3.4 设计域模型企业员工信息管理中用到的实体包括员工信息表()、登录信息()、部门信息()、职位()、员工职位()、考勤()。具体含义如下。员工信息表():是一个员工信息的实体,包含的属性主要有员工姓名()、员工编号()、民族()、电话()、家庭电话()、家庭住址()、文化程度()、婚姻状况()、出生年月()、性别()、部门编号()、入职时间()。登录()实体内容如下:员工登录账号(),员工姓名()、员工登录密码()、员工权限()。部门信息()实体的内容如下:部门编号()、部门名()、部门经理()、部门电话()、设立时间()。职位()实体如下:职位()、职位名()、薪水()。员工职位()实体如下:员工编号()、职位编号()。考勤()实体如下:()、员工编号()、员工姓名()、开始时间(1)、结束时间(2)、部门编号()、考勤状态()。3.5 设计数据模型员工信息表()、登录信息()、部门信息()、职位()、员工职位()、考勤()、在数据库中都有相对应的表。下面就详细说明各个表之间的关系,以及表所对应的属性。员工表()见表3-1。表3-1 员工表 字段说明列名字段属性键值员工编号(50)员工名(50)电话(50)手机(50)家庭住址(50)性别(50)民族(50)出身年月日(50)文化程度(50)婚姻状况(50)入职时间(50)部门编号(50)登录表()见表3-2,其中包括登录,员工帐号,员工密码。表3-2登录表 字段说明列名字段属性键值员工登录账号(50)员工姓名(50)员工登录密码 (50)员工权限(50)部门表()见表3-3,其中包括部门编号,部门名,部门电话,部门经理,设立时间。表3-3部门表字段说明列名字段属性 键值部门编号(50) 部门名(50)部门经理(50)部门电话(50)设立时间(50)考情表()见表3-4,包括、员工编号、开始时间、结束时间和考勤状态。表3-4考勤表 字段说明列名字段属性键值(100) 员工编号(50)员工姓名(50)开始时间1(50)结束时间2(50) 部门编号 (50)考勤状态(50)职位表()见表3-5,表中有职位,职位名。表3-5职位表字段说明列名字段属性键值职位(50) 职位(100) 薪水(50) 员工职位表()见表3-6,包含职工表号和职位。表3-6员工职位表 字段说明列名字段属性键值员工编号(50)职位(50)4 网站前台的设计4.1 网站登录界面的设计一个企业的员工信息管理系统不会像普通的网站一样什么人都可以访问,只有内部员工才能具有访问的权限,因此网站的登录页面是必不可少的。通过登录能够分析出访问者的权限,系统根据权限给予不同的反馈。网站登录界面如图4-1所示。 图4-1 登录页面登录页面里面有输入用户名和密码的框,有控制登录权限的单选按钮,管理员单选按钮值为0,员工单选按钮值为1,也就是对应表的的值。输入用户名和密码点击登录按钮,就会把前台的值传递给后台,后台去数据库里面进行验证。如果用户不存在,提示错误信息“用户不存在”,如图4-2所示。图4-2 登录用户不存在 如果输入的用户名存在但是密码不正确的话,就会返回页面并且提示错误信息“密码不正确,请重新输入”,如图4-3所示。图4-3 用户登录密码错误如果后台验证功,则直接跳转到相应菜单页面,如图4-4 ,4-5所示。图4-4 管理员登录正确跳转界面图4-5 员工登录正确跳转界面4.2 员工信息管理界面设计只有管理员成功登录以后,在菜单上才有员工信息管理,员工信息管理有两个二级菜单。如图4-6所示。图4-6 员工信息管理的二级菜单员工查找页面如图4-7所示。有按职工号查询、按部门号查询、详细查看、员工信息修改、删除功能。图4-7员工查看页面员工的检索通过选择不同的单选按钮可以选择不同的检索方式,根据判断单选按钮的值来调用不同的查询方法。两种查询都是精确查询,而不是模糊查询。当输入框的值为空时,检索所有员工的信息。点击详细按钮可以对对应员工的详细信息进行查看,详细页面如图4-8所示。图4-8员工信息详细页面点击删除按钮首先会弹出删除确认窗口,当点击确认时可删除该员工的所有信息,如图4-9所示。图4-9员工信息删除页面 点击更新按钮会跳转到更新页面,在更新页面除了员工工号不能修改外,其他信息都可以修改,修改后点击“更新”按钮,该用户信息将保存并返回到查看页面。更新页面如图4-10所示。图4-10 员工信息修改页面想添加新员工信息可在员工信息管理二级菜单处点击“员工添加”,跳转到员工信息添加页面。该页面一共对三个表进行了操作,当一个员工添加时,不仅在员工基本信息表添加了该员工的基本信息,同时在表也创建了该员工登录本系统的用户名,登录密码和登录权限,还在员工职位表添加了该员工所在职位的对应数据。员工添加页面如图4-11所示。图4-11 员工添加页面4.3 部门管理页面设计本系统的部门管理页面同样只有具有管理员权限的才能对公司的部门进行相应的操作。该模块中主要是设计对公司部门的添加,修改与删除。与员工信息管理模块一样,在部门管理的二级菜单下有部门查看和部门添加。如图4-12所示。图4-12 部门管理二级菜单页面部门查看页面有根据部门号和部门名查询两种检索方法,同时有对部门进行删除,更新的操作,如图4-一三所示。图4-一三 部门查看页面点击更新按钮就可以跳转到部门更新页面,除了部门号不能修改,部门的其他信息都可修改,然后保存。部门更新页面如图4-14所示。图4-14 部门信息更新页面4.4员工工资管理设计员工工资查询页面,在该页面中,用户可以查询员工的工资。从图中可以看出该页面分为查询全部、选择个人查询以及按照部门查询。系统可以根据不同的查询条件从数据库中查询出相应员工的工资,如图4-一五所示。图4-一五 员工工资查询页面4.5 员工考勤管理设计员工考勤管理主要是对员工的考勤信息管理,管理员和普通员工都有这部分的操作,不同在于两点,一是管理员可以查看所有员工的考勤情况,而普通员工只能查看自己的考勤情况;而是管理员可以对员工进行考勤登记,分别有登记员工迟到,早退,缺勤三种情况,普通员工只有请假的权力。菜单设计如图4-16,4-17所示。图4-16管理员的考勤管理图4-17 普通员工的考勤管理管理员在对考勤查看时,为了方便,设计了按部门号查询的功能,这里只是加了这功能作为演示,当然为了更方便查询,可以设计按时间段查询,员工号查询等。其实现原理跟按部门号查询类似,只是改变关键字就行。以下是管理员考勤查看页面,如图4-一八所示。图4-一八 管理员考勤信息查看页面普通用户考勤查看页面,只能查看自己的出勤状况,所以只是简单地用表格显示相关信息,如图4-19所示。图4-19 普通员工考勤信息查看页面 考勤登记页面如图4-20所示。图4-20 考勤登记页面普通员工的请假如图4-21所示。图4-21 考勤登记页面4.6 用户密码修改模块的设计不管是管理员还是普通员工都有用户登录密码的修改页面。在这个页面,用户通过旧密码的输入,后台通过与保存的登录密码相比对,如果不正确,会清空输入值,页面提示错误信息,新密码与确认密码之间也存在比对,不一致情况下也在页面提示错误信息,在这些比对都正确后才完成旧密码的更新,密码修改成功,这时跳转到成功页面。修改页面如图4-22所示。图4-22 用户密码修改页面4.7 退出系统模块的设计用户点击退出系统以后,清空当前用户的登录信息,清空里面的数据,然后跳转到登录页面。5 网站模块功能的实现5.1 用户登录实现用户登录的实现主要用了条件语句,不同条件下返回不同结果。条件是在中通过个()方法获取从页面传的对象u,与传参数到层通过数据库的查找到的对象1进行比对得到的型值。在层与层间,加了层来降低模块之间的耦合