基于JSP的企业员工管理软件的设计与实现.doc

上传人:精*** 文档编号:829390 上传时间:2023-09-06 格式:DOC 页数:38 大小:1.57MB
下载 相关 举报
基于JSP的企业员工管理软件的设计与实现.doc_第1页
第1页 / 共38页
基于JSP的企业员工管理软件的设计与实现.doc_第2页
第2页 / 共38页
基于JSP的企业员工管理软件的设计与实现.doc_第3页
第3页 / 共38页
基于JSP的企业员工管理软件的设计与实现.doc_第4页
第4页 / 共38页
基于JSP的企业员工管理软件的设计与实现.doc_第5页
第5页 / 共38页
点击查看更多>>
资源描述

1、XX大学本科毕业设计 目 录前 言11. 开发工具简介11.1 JSP简介11.2 DAO数据访库技术11.3 Mysql简介22. 系统的概要设计32.1 系统总体设计32.1.1 系统结构-32.1.2 系统功能简介-32.2 数据环境的设计42.2.1 数据库表结构-42.2.2 数据库表结构关系-72.2.3 确定数据库的连接方式-83. 系统功能模块的实现93.1 登录模块93.2 人事管理模块功能173.3 待遇管理模块功能213.4 系统维护管理模块功能283.5 其他功能的实现30结束语33摘 要企业员工管理系统是用于企业有效管理员工的管理系统。它有管理员的权限分配、部门的设置

2、、员工信息的详细记录、职位的设置、奖惩措施的记录与管理、考勤信息的记录与管理、帐套信息的管理与记录、培训信息的管理与记录八大功能,同时具有界面定制化细腻化、多重定时、工资帐套化、操作简单化等特色。一套好的员工管理系统可以提高公司企业运营的效率,进而提高公司的收益。本系统可以为他们提供快捷的服务,减少时间上的浪费,同时,本系统还具有较高的可靠性。作者在开发本系统时采用MVC设计模式、JSP设计语言、DAO数据库访问技术和Mysql数据库软件作为主要的开发工具。作者运用HTML、CSS+DIV、JavaScript设计样式,然后转换成JSP完成了程序的界面设计及主要功能的具体实现;用Mysql完成

3、了数据库的具体设计;然后用DAO数据库访问技术将二者连在一起。本系统设计使用的工具Tomcat(作为服务器)、Myeclipse、 MindManager(思维导图) 、 StarUML PowerDesigner 、 Navicat For MySql 、Dreamweaver(设计界面样式)、 PhotoShop(Logo设计,按钮图片设计,背景图片设计)。关键词:企业管理系统;帐套;员工管理;JSPAbstractThe Enterprise Employee Management System is a kind of management system , which is used

4、 for efficiently managing staff by the enterprises and used by the business groups for the operation of the functions of the statistics of staff information, the formulation of employee wages, the evaluation of employee and so on. It has eight functions of the distribution of administrator privilege

5、s, the establishment of departments, the detailed record of staff information, the establishment of the position, the record and management of rewards and punishments measures, the record and management of attendance information, the record and management of set of books information, the record and

6、management of training information and at the same time has the features of the customize and exquisiteness of the interface, multiple timing, wages set of books, operation simplification and so on.This system mainly aim at the staff management of small enterprises.A set of good staff management sys

7、tem may improve the operational efficiency of the enterprises and then improve company earnings. The system may provide convenient service for them and reduce the waste of time.At the same time the system also has a higher reliability. The author takes MVC design patterns, JSP design language, DAO d

8、ata base visit technology, MySql database software as the main development tools when developing the system. The author uses the design patterns of HTML, CSS+DIV, JavaScript and then converts to use JSP to complete the program interface design and the concrete realization of the main function, uses

9、the MySql complete the concrete design of database, and then uses ADO data base visit technology connect the two together. The tools used in designing this system, Tomcat ( as a server), Myeclipse, Mindmanager (mind mapping ), StarUML Powerdesigner, Navicat for MySql, Dreamweaver (design interface s

10、tyle), PhotoShop(the design of Logo, button images, background pictures).Key words: enterprise management system; set of books; staff management;JSP35基于JSP的企业员工管理软件的设计与实现前 言随着计算机的普及和计算机科学技术的飞速发展,人们开始越来越多地利用计算机解决实际问题。员工信息管理是企业信息管理的重要部分,面对大量的人事信息,采用人力处理即浪费时间、又浪费人力和物力,并且数据的准确性低。因此,开发一个界面友好,易于操作的员工信息管理软

11、件进行自动化处理变得十分重要,这正是本系统开发的目的和意义。通过网络化(或公司内部局域网)的员工信息管理,大大的提高了企业人才的利用率,使之为企业创造了更大价值。人才利用率的提高,增强了企业的核心竟争力,全面提升了企业的管理能力,从而企业适应了信息时代的网络化管理要求。1. 开发工具简介1.1 JSP简介JSP技术使用Java编程语言编写类XML的tags和scriptlets,来封装产生动态网页的处理逻辑。网页还能通过tags和scriptlets访问存在于服务端的资源的应用逻辑。JSP将网页逻辑与网页设计和显示分离,支持可重用的基于组件的设计,使基于Web的应用程序的开发变得迅速和容易。

12、Web服务器在遇到访问JSP网页的请求时,首先执行其中的程序段,然后将执行结果连同JSP文件中的HTML代码一起返回给客户。插入的Java程序段可以操作数据库、重新定向网页等,以实现建立动态网页所需要的功能。 JSP与JavaServlet一样,是在服务器端执行的,通常返回给客户端的就是一个HTML文本,因此客户端只要有浏览器就能浏览。1.2 DAO数据访库技术DAO是Data Access Object数据访问接口。 在核心J2EE模式中是这样介绍DAO模式的:为了建立一个健壮的J2EE应用,应该将所有对数据源的访问操作抽象封装在一个公共API中。用程序设计的语言来说,就是建立一个接口,接口

13、中定义了此应用程序中将会用到的所有事务方法。在这个应用程序中,当需要和数据源进行交互的时候则使用这个接口,并且编写一个单独的类来实现这个接口在逻辑上对应这个特定的数据存储。DAO操作数据库的物理机制如图1.1所示。DAO数据库引擎数据库JSP的用户界面和程序代码图1.1 DAO操作数据库的物理机制1.3 Mysql简介MySQL是一个小型关系型数据库管理系统,开发者为瑞典MySQL AB公司。在2008年1月16号被Sun公司收购。而2009年,SUN又被Oracle收购。MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内。这样就增加了速度并

14、提高了灵活性。MySQL的SQL“结构化查询语言”。SQL是用于访问数据库的最常用标准化语言。MySQL软件采用了GPL(GNU通用公共许可证)。由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库。使用C和C+编写,并使用了多种编译器进行测试,保证源代码的可移植性。支持AIX、FreeBSD、HP-UX、Linux、Mac OS、NovellNetware、OpenBSD、OS/2 Wrap、Solaris、Windows等多种操作系统。为多种编程语言提供了API。这些编程语言包括C、C+、Python、Java

15、、Perl、PHP、Eiffel、Ruby和Tcl等。支持多线程,充分利用CPU资源,优化的SQL查询算法,有效地提高查询速度,既能够作为一个单独的应用程序应用在客户端服务器网络环境中,也能够作为一个库而嵌入到其他的软件中提供多语言支持,常见的编码如中文的GB 2312、BIG5,日文的Shift_JIS等都可以用作数据表名和数据列名,提供TCP/IP、ODBC和JDBC等多种数据库连接途径,提供用于管理、检查、优化数据库操作的管理工具,可以处理拥有上千万条记录的大型数据库,支持多种存储引擎。2. 系统的概要设计2.1 系统总体设计2.1.1 系统结构根据前面的系统分析和实际应用的需要,我们确

16、定了企业员工管理软件的功能结构图。图2.1 企业员工管理软件的功能结构图2.1.2 系统功能简介根据企业管理的主要工作内容,企业员工管理系统软件实现了管理员的权限分配、部门的设置、员工信息的详细记录、职位的设置、奖惩措施的记录与管理、考勤信息的记录与管理、帐套信息的管理与记录、培训信息的管理与记录八大功能,下面我们将各个功能做简单介绍:(1)管理员的权限分配:设置普通管理员与超级管理员,普通管理员可以维护人事管理、待遇管理、系统维护,超级管理员可以维护人事管理、待遇管理、系统维护、用户管理。(2)部门的设置:设置部门机构的组成,企业部门机构的查看、展示。(3)员工信息的详细记录:记录员工的详细

17、信息,对员工信息的修改、增加、删除、保存、修改。(4)职位的设置:对员工职位的设置,包括对员工职位的增加、删除、修改、查看。(5)奖惩措施的记录与管理:对员工的奖惩记录与管理。(6)考勤信息的记录与管理:对员工的考勤记录管理。(7)帐套信息的管理与记录:帐套信息的设置,包括帐套的增、删、改、查,对帐套的应用设置。(8)培训信息的管理与记录:培训信息的记录与修改。2.2 数据环境的设计本系统中需要设计一个新的基于Mysql的数据库。2.2.1 数据库表结构数据库CMS中包含八张表用户表(tb_manager)、部门表(tb_dept)、员工表(tb_staff)、职位表(tb_position)

18、、帐套表(tb_money)、奖惩表(tb_reward_punishment)、培训表(tb_train)、考勤表(tb_check)。 表2.1 tb_manager表字段表名tb_manager(用户表)注释索引别名列名数据类型空值缺省主键注释用户IDidIntNOKEY用户表的唯一标识用户名usernameVarchar(32)NO登录密码passwordVarchar(32)NO管理员权限managerrightVarchar(32)11:普通管理员;2超级管理员:录入时间lrsjVarchar(17)表2.2 tb_dept表字段表名tb_dept(部门表)注释索引别名列名数据类型

19、空值缺省主键注释部门IDdeptidIntNOKEY部门表的唯一标识部门名称deptNameVarchar(32)NO部门描述deptMessageVarchar(32)NO录入时间lrsjVarchar(17)表2.3 tb_staff表字段表名tb_staff(员工表)注释索引别名列名数据类型空值缺省主键注释员工IDS_id intNOKEY(员工的唯一标识)考勤信息c_idintNO外键帐套信息m_idint外键部门信息deptidint外键职位信息p_idint外键员工真实姓名name Varchar(32)NO员工性别sexVarchar(2)00:男;1:女员工生日birthday

20、 Varchar(32)员工相片photo Varchar(90)员工地址address Varchar(32)邮编postalcode Varchar(10)毕业学校schoolVarchar(32)接受教育时间school_time Varchar(32)联系电话telephone Number(19,6)QQ QQ Number(19,6)邮箱E_mail Varchar(2)是否入党isPartyVarchar(2)00:为入党;1:已入党入党时间Party_time Varchar(32)自我评价self-assessment Varchar(255)录入时间lrsjVarchar(

21、17)表2.4 tb_position表字段表名tb_position(职位表)注释索引别名列名数据类型空值缺省主键注释职位IDP_Id IntNOKEY职位的唯一标识职位名称P_name Varchar(32)NO职位描述P_message Varchar(32)录入时间lrsjVarchar(17)表2.5 tb_money表字段表名tb_money(帐套表)注释索引别名列名数据类型空值缺省主键注释帐套IDM_Id IntNOKEY帐套表的唯一标识帐套名称M_name Varchar(32)NO帐套内容M_content Varchar(32)录入时间lrsjVarchar(17)表2.6

22、 tb_reward_punishment表字段表名tb_reward_punishment(奖惩表)注释索引别名列名数据类型空值缺省主键注释奖惩IDRp_Id int()IntNOKEY奖惩的唯一标识奖惩原因Rp_reason Varchar(255)NO奖惩日期Rp_date date()NO录入时间lrsjVarchar(17)表2.7 tb_train表字段表名tb_train(培训表)注释索引别名列名数据类型空值缺省主键注释培训IDT_IdIntNOKEY培训的唯一标识培训名称T_name Varchar(32)NO培训内容T_content Varchar(255)起始时间T_st

23、artTime date()结束时间T_endTime date()录入时间lrsjVarchar(17)表2.8 tb_check表字段表名tb_check(考勤表)注释索引别名列名数据类型空值缺省主键注释培训IDC_IdIntNOKEY考勤的唯一标识时间C_time date()NO考勤结果及内容C_content Varchar(255)录入时间lrsjVarchar(17)2.2.2 数据库表结构关系数据库CMS中八张表的结构关系如图所示。 图2.2数据库表结构关系(概念模型)如上图概念模型所示八张表格的结构关系为:1.一个职位包含多个员工。2.一个次奖惩包含多个员工。3.一个部门包含

24、多个员工。4.一次培训包含多个员工,一个员工可以参加多次培训。5.一次考勤包含多个员工,一个员工参与多次考勤。6.一个帐套适用于多个员工。图2.3数据库表结构关系(物理模型)2.2.3 确定数据库的连接方式数据库连接是非常宝贵的系统资源,连接一次数据库,底层程序需要经过很多步骤,花费比较多的时间,如果每次要操作数据库的时候才开始建立数据库连接,用完之后再关闭连接,势必造成程序的效率问题。连接池的基本原理是,先初始化一定的数据库连接对象,并且把这些连接保存在连接池中。当程序需要访问数据库的时候,从连接池中取出一个连接,数据库操作结束后,再把这个用完的连接重新放回连接池。因此考虑到连接的效率,此处

25、我们使用连接池来连接数据库。1.需要修改tomcat 下D:学习软件安装apache-tomcat-7.0.23conf 的 context.xml文件在文件中添加如下代码: /定义地址 、数据库名称数据库。 2.在 tomcat D:学习软件安装apache-tomcat-7.0.23lib 的lib 目录下添加驱动文件mysql-connector-java-5.0.8-bin.jar 3.设置方法 getQueryRunner() public QueryRunner getQueryRunner() DataSource ds = null;/通过在context.xml文件,设定的数

26、据源对象的名字,获取数据源对象try Context context = new InitialContext(); ds = (DataSource) context.lookup(java:/comp/env/jdbc/mysqlds); catch (Exception e) System.out.println(获取数据源时出错); / *DButils中核心类,生成对象时传递数据源对象* QueryRunner qr = new QueryRunner(ds);return qr;3. 系统功能模块的实现3.1 登录模块登录模块设计时采用的是普通管理员、超级管理员共用一个登录界面的方

27、式,普通管理员与超级管理员凭借独自的账户密码进行系统登录,系统会自动判定其权限级别,根据权限级别显示其权限范围内的功能。登陆界面如图3.1所示。图3.1.1企业员工管理系统登陆界面登陆界面的JSP前台代码如下:登陆页面/* 定义全局样式 */body font-family: Verdana, Geneva, sans-serif; font-size: 16px; background: url(/CMS/images/login_bg.jpg) repeat-x; /* 定义container样式 */#container height: 360px; width: 720px; marg

28、in-top: 200px; margin-left: 280px; background: url(/CMS/images/login_main.jpg) no-repeat; text-align: left; /* 定义main样式 */#main height: 200px; width: 350px; position: fixed; margin-top: 60px; margin-left: 180px; background: #FFF; .sub background: url(/CMS/images/sub.jpg); height: 32px; width: 83px;

29、.res background: url(/CMS/images/res.jpg); height: 32px; width: 83px; .text width: 120px; height: 20px; #position margin-top: 20px; position: fixed; margin-left: 60px; XX企业员工管理系统1.0登录 用户名: 密 码: %String message=(String)request.getAttribute(messageLogin); if(message!=null) out.print(+message+); % &nbs

30、p;      登陆界面的JSP后台代码如下:package com.flyingpig.servlet;import java.io.IOException;import java.util.List;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import

31、 javax.servlet.http.HttpSession;import com.flyingpig.dao.Dao;import com.flyingpig.dao.DaoJdbc;import com.flyingpig.entity.Manager;public class ManagerServlet extends HttpServlet /* * 管理员Servlet * 2012年5月10日19:59:40 */public void doGet(HttpServletRequest request, HttpServletResponse response)throws S

32、ervletException, IOException doPost(request, response);public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException request.setCharacterEncoding(UTF-8);String method=request.getParameter(method);if(method.equals(login)login(request,response);else i

33、f(method.equals(logout)logout(request,response);else if(method.equals(add)add(request,response);else if(method.equals(getList)getList(request,response);else if(method.equals(delete)delete(request,response);else if(method.equals(updateRight)updateRight(request,response);else if(method.equals(update)u

34、pdate(request,response);private void update(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException String managerId=request.getParameter(managerId);String managerRight=request.getParameter(managerright);Dao dao =new DaoJdbc();boolean isSuccess=dao.updateManage

35、r(managerId, managerRight);if(isSuccess)request.getRequestDispatcher(/servlet/ManagerServlet?method=getList).forward(request,response);elserequest.setAttribute(message, 用户信息修改不成功,请重新操作);request.getRequestDispatcher(/index.files/error.jsp).forward(request,response);private void updateRight(HttpServle

36、tRequest request, HttpServletResponse response) String managerId=request.getParameter(managerId);int id=Integer.parseInt(managerId);Dao dao=new DaoJdbc();Manager manager=dao.getManager(id);request.setAttribute(manager2, manager);try request.getRequestDispatcher(/index.files/updateManager.jsp).forward(request, response); catch (Exception e) e.printStackTrace(); private void delete(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException String managerId=request.getParameter(managerId);Dao dao=new

展开阅读全文
相关资源
相关搜索
资源标签

当前位置:首页 > 学术论文 > 毕业设计

版权声明:以上文章中所选用的图片及文字来源于网络以及用户投稿,由于未联系到知识产权人或未发现有关知识产权的登记,如有知识产权人并不愿意我们使用,如有侵权请立即联系:2622162128@qq.com ,我们立即下架或删除。

Copyright© 2022-2024 www.wodocx.com ,All Rights Reserved |陕ICP备19002583号-1 

陕公网安备 61072602000132号     违法和不良信息举报:0916-4228922