集团远程办公自动化之员工考勤系统_第1页
集团远程办公自动化之员工考勤系统_第2页
集团远程办公自动化之员工考勤系统_第3页
集团远程办公自动化之员工考勤系统_第4页
集团远程办公自动化之员工考勤系统_第5页
已阅读5页,还剩22页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、 目录第一章、    绪论11.1 论文研究的背景11.2 办公自动化系统发展概况及趋势11.3 论文的目标和意义2第二章、    办公自动化系统开发的理论和技术基础42.1 ASP.NET概述42.2 C#概述(本文程序采用C#编程)4第三章、    系统设计63.1 需求分析63.2 总体设计63.2.1 UML活动关系图63.3 功能设计73.3.1 项目管理73.3.2 项目角色管理73.3.3 项目进程日志管理73.3.4 项目统计报告8第四章、    数据库设计与实现94.1.数据库的需求分析

2、94.1.1 数据项和数据结构94.2.数据库的逻辑设计94.2.1.人员基本信息表(MrBaseInf)94.2.2.项目基本信息表94.2.3.项目成员信息表(PM_ProjectMembers)104.2.4.项目角色字典表(PM_Roles)104.2.5.项目进程表104.2.6.项目进程日志表114.3.数据库存储过程11第五章、    项目管理145.1.实现效果145.2.用户表示层145.2.1.项目列表页面ProjectList.aspx145.2.2.ProjectList.aspx的后台代码145.2.3.项目详细信息页面.195.2.4 日期选择页

3、面Calendar.aspx345.3 业务逻辑层355.4 数据访问层355.5项目角色管理365.5.1 实现效果365.5.2 权限判断365.6 项目进程日志管理375.6.2 身份验证375.7 项目统计报告385.7.1 实现效果385.7.2 权限判断38第六章、    总结39第七章、    参考文献45第八章、    致谢46   第1章 概 述1.1课题设计背景随着计算机及网络技术的飞速发展,Internet/Intranet应用在全球范围内日益普及,当今社会正快速向信息化社会前进,信

4、息系统的作用也越来越大。Web用超链接的方式使用户能非常方便地从Internet的一个站点访问另一个站点,从而获取丰富的信息。与此同时,越来越多的中小企业为了适应信息革命的要求,提高自身的竞争力,正打算或正在建立符合企业特色的办公自动化信息系统。但是,这些中小企业由于自身信息化基础比较薄弱,计算机软、硬件配置较差,而且员工的素质也参差不齐,同时,其经济实力并不雄厚,不可能像政府或大公司、大企业那样进行大量投资建设信息系统。  无论公司还是企业,都会涉及到对职工的考勤管理。考勤管理在生产管理过程中充当着一个十分重要角色,考勤管理的效率对生产的效果起着举足轻重的作用。随着现代科学技术的发

5、展,越来越多的公司和企业对职工的考勤管理都实行了信息化管理,使用计算机系统代替繁琐冗余的手工方式来管理考勤事务。传统的手工方式不仅效率低下,而且容易出错,采用计算机技术进行货物管理可以克服手工管理的缺点,将人们从烦杂的劳动中解放出来。基于此,开发了一套考勤管理系统,其主要目的是为了统计员工的迟到、早退、旷工、事病假、加班以及出差情况,这些信息将直接作为公司对员工的奖惩、提升以及培训的依据。1.2 办公自动化及员工考勤系统发展概况及趋势随着我国国民经济建设的蓬勃发展和具有中国特色的社会主义市场经济体制的迅速完善,各个行业都在积极使用现代化的手段,不断改善服务质量,提高工作效率,这些都在很大程度上

6、给企业提出越来越严峻的挑战,对企业体系无论是在行政职能、企业管理水平以及优质服务上都提出更高的要求。建设一个科学高效的信息管理系统是解决这一问题的必由之路。 办公自动化已经成为现代企事业单位实现管理现代化的一个重要途径。办公自动化(OA),是指利用计算机技术和网络技术,使办公室部分工作逐步物化于各种现代化设备中,由办公室人员与设备共同构成服务于某种目标的人机信息处理系统。目前办公自动化系统发展的状况是,大公司做平台,中小公司做产品,通过平台可进行二次开发,通过产品可以做业务定制。考勤管理作为企业内部的一种管理也是如此,由于企业职工人数较多,每一位职工的具体实际情况也不尽相同,日常的考勤工作,如

7、果没有一个完整的管理,后果将不堪设想。我国中小企业信息化水平一直处在比较初级的阶段,有关统计表明,真正具备计算机信息化比较高应用水平的企业在全国1000多万中小企业中所占的比例还不足10%。然而,随着我国市场经济的不断成熟,企业的竞争也在不断的加剧,同时企业组织管理观念的变革以及业务流程标准化也在不断完善,中小企业信息化建设的热情近几年来有了显著的提高。因此开发一个高质量的考勤工资系统进行企业管理尤为重要。1.3方法概要本考勤管理系统是采用面向对象的程序设计思想进行编制的,整个系统由若干个表、类、报表以及一个主菜单组成,由工程管理器统一管理全部程序的编写和调试。用户可以通过主菜单调用系统的各项

8、功能。  1. 面向对象设计不再是单纯的从代码的第一行一直编到最后一行,而是考虑如何创建类和对象,利用类和对象来简化程序设计,并提供代码的封装和可重用性,便于程序的维护与扩展。  2. 所谓的对象是一种抽象的名称,用来对应实现世界存在的“东西”。一个窗口、一个按钮、一个菜单都可视为一个对象,而按钮对象、菜单对象、又会出现在窗口对象中,因此按钮对象、菜单对象便是窗口的组件之一。对象内部的数据是不能随意更改的,必须由外部向其传递信息,再由对象按其方法加以处理。用户无需知道其任何细节,操作是封闭的,对象之间能通过函数调用相互通信。  3. 类可视为一个产品模具、一个模块

9、。在面向对象设计中,类是对象的原型,是对象的制作器。类的概念是面向对象程序设计最重要的特征。所谓类,是指由数据结构及其相关操作所形成的集合,描述该类任一对象的共同的行为特征,是对一组性质相同的对象的程序描述,概括了对象的共同性质和数据。1.4 系统开发的意义和条件本系统开发的目的是紧密结合当前企事业单位和中小型公司办公业务流程和管理特点,开发一套综合的、完整的、水平较高的、能在局域网和广域网运行的办公自动化系统。通过该系统的使用,可以有效的提高企事业单位和公司的工作效率,提高单位信息化管理水平,减少工作人数,降低成本。特别是在员工考勤中,可以节约人力,实现从人力资源上提高效率和减少投入。以面向

10、对象技术为基础,美国微软公司推出的.NET为开发平台,采用B/S结构,以微软公司的SglServer2000为后台数据管理系统,结合INTERNET和INTRANET技术,开发一套先进的、综合的、完整的、可直接应用于实际使用单位的,办公自动化系统。                        第2章     

11、;          数据库的设计与实现现在的办公自动化系统以及大多数的管理应用软件,都是以数据库为中心的应用。一个结构良好的,考虑周全的数据库设计,是项目成功的关键。本系统采用的数据库为Microsoft的SQL Server。2.1 SQL Server的优点SQL Server正受到越来越广泛地欢迎,其原因在于:它是一个拥有众多令人无法抗拒的优点的数据库。数据完整性是任何一个好的数据库都要具备的最重要的一个特性。SQL Server最大的优点就在于它极为可靠地实施了ACID特性;它的安全性保证关键数据的安全。

12、它的速度非常快,并具有高度的可调性。                   第三章:需求分析办公自动化系统的建立,需要进行用户需求调查与分析,以确定系统目标,这是系统建设的重要环节。中小企业需要规模相对较小,但其在功能上对系统的需求却是全面的。大体可分为:一方面是通过收发电子邮件为主的方式,与其它员工交流各种信息,基于工作流的方式实现诸如请假申请、物品申领审批过程;员工管理个人日程安排,各种图书资料的查阅等日

13、常办公功能。另一方面则是面向公司办公业务方面的业务管理功能。即完全采用计算机技术处理办公业务,使企业内部人员能够方便快捷地共享信息、交流信息,高效地协同工作,既兼顾个人办公效率的提高,又可以实现群体协同工作。综合、大型的办公自动化软件系统,没有通用的产品,需要由办公自动化方案提供商,在确定的平台上,按用户的具体情况度身开发。而现在,市面上已经逐渐出现了通用的商品化办公自动化软件产品,用户只需要购买回来就可以着手实施了。节省大量的时间及开发资金,并避免开发风险。根据企业具体需求,下面列出大体的,细节需求在此不做详述:(1)权限管理:只有经过授权的人员才可以进入本系统。本系统的使用者又分多种角色:

14、管理人、审核人、审批人、归档人。每个角色在本模块中都只能进行相应的操作,而不能越权操作。(2记录分类。每一种记录类别对应着不同的记录项目,不同的记录报告。(3)记录项目。每种记录类别,都含有多种记录项目,每次具体的记录项目可都要填写固定格式的Word文档。(4)系统需要记录所有模块的基本资料,又叫原始资料。(5)报告流程。每次记录之前,系统需根据不同的记录对象,不同的记录种类,确定不同的报告项目和内容,生成“原始记录报告”。(6)系统可以根据需要,实时的生成“原始记录报告”和“记录报告”的Word文档。(7)加分页。在每个报告项目文档中,可能会因为测定数据的不定性而动态的增加页码的长度。

15、60;   第4章 用户考勤及设置 个人考勤登记出差 登记请假登记外出登记上下班 登录统计考勤记录查询考勤记录审批审批出差审批外出审批请假一般员工Manager具有一定管理权限的人员,如:经理,管理员等inciudeinciude 考勤管理用例图用例图说明了考勤管理的功能需要。其中使用了“包含”用例,考勤管理中的每一个步骤都会先登录进行权限验证,然后才能进行下一步的操作。下面的功能都根据在工作流中己经设计好的对应的审批流程来进行审批的流程的自动化处理过程。 出差登记:发出出差申请,在填入出差地点、出差日期、出差事由、审批人后,发出申请。另外包含

16、出差历史记录和出差销假。 外出登记:发出外出申请,在申请单中填入外出原因,外出起止时间,审批人后,发出申请,另外还包括外出回转销假。 请假登记:发出请假申请,填入请假类型、请假详细原因、请假起tFII期,审批人后,发出申请。另外包含请假历史记录和销假。 上下班登记:根据上下班登记时间限制进行上班签到与下班签退的登记。如果在时间限制之内,则允许登记,否则给出提示。另外还包括上下班登记历史记录 审批出差、审批外出、审批请假:如果同意则批准,否则填入不同意的理山,然后发出不批准指令。 考勤记录查询:可以根据日期来进行考勤记录的查询。 考勤记录统计:根据起止日期、部门、排班类型进行统计,结果以报表的形

17、式给出。(3)考核管理是用于每个员工在考核时使用,在员工的培训中会有很多的考核,要确定考核的指标,考核的项目,发信息给考核人,然后由考核人进行考核。具体功能模块如下: 考核项目设定:填入考核指标集合名称和指标的注释,然后建立个考核指标。 指标详细设定:对指标进行详细的设定,包括考核项目名称,分值范围设定。 考核任务管理:对已经设定生成的考核任务进行管理,功能有:修正、过期失效、任务删除,己经失效的任务的恢复有效。 进行考核:有设定的考核人进行给出考核的成绩。发消息给系统。 考核查询:根据考核人、考核项目、考核日期、被考核人,有效性来进行考核用户考勤功能模块是办公自动化系统中很重要的一个模块,它

18、能够实现用户(员工)的上下班考勤功能,同时系统还提供了公司的上下班考勤的设置,以及查看公司所有用户的考勤详细情况。下面是设计的详细功能模块。4.1 用户考勤用户考勤功能由页面Attendance.aspx实现,它的代码隐藏文件为Attendance.aspx.cs,主要实现用户的上下班考勤登记功能。4.1.1界面设计 在页面Attendance.aspx添加多个Label控件1个TextBox控件和1个Button控件,它们的名称分别为AttendanceDesn和CheckAttendance(没有包括Label控件的名称)。控件AttendanceDesn用来输入用户迟到或早退的理由或原因

19、;控件CheckAttendance提交用户的考勤。页面Attendance.aspx的设置界面如图4.1所示。  页面Attendance.aspx的部分HTML设计代码如下:<asp:Label id=”lblDutyMessage”runat=”server”>考勤信息< /asp:Label >< asp:TextBox id=” AttendanceDesn” runat=”server”TextMode=”MultiLine”Height=”150px”Width=”500px”Visible=”False”></asp

20、: TextBox >< asp:Button id=”CheckAttendance”CommandArgument=”runat=”server”CssClass=”buttoncss”Width=”80px”></asp:Button> 4.1.2 页面初始化页面Attendance.aspx调用函数Page_Load(object sender,System.EventArgs e)初始化,该函数首先从Session变量中获取用户的ID, 然后根据用户的实际情况处理考勤。如果为上班时间,则程序检查该用户是否迟到;如果为下班时间,则程序检查用户是否

21、早退等。如果为非正常情况,还需要用户填写迟到或早退的理由。之得注意的是,该页面还定义了一个全局的变量nStaffld,用来保存用户的ID。两个全局变量和函数Page_Load(object sender,System.EventArgs e)的程序代码如下:/定义两个全局变量private int nStaffld;private static bool DutyStatus= True;private void page_load(object sender,System.EventArgs e) /判断用户是否登录,否则跳到登录页面if(Session“userID”=null)Respo

22、nse.Redirect(“/Default.aspx”);if(Session“userID”=null) /获取用户的ID nSta ffID = lnt32.parse(/session“userID”.ToString();if(CheckOnDuty(nStaffID)= false) /检查用户是否考勤,如果没有考勤。则进行考勤 SetOnDuty(nStaffID);CheckAttendance.Attributes.Add(“onclick”,“returm confirm(你确定要现在下班吗?);”);函数CheckOnDuty(int nStaffID)和SetOnDut

23、y(int nStaffID)分别实现检查用户是否考勤和对用户进行考勤。函数CheckOnDuty(int nStaffID)调用类Attendance中的函数从数据库的考勤表Attendance中获取该用户的当天考勤数据,如果数据为空,则用户没有考勤,此时调用函数SetOnDuty(int nStaffID)对用户进行考勤。函数CheckOnDuty(int nStaffID)和CheckOnDuty(int nStaffID)的程序代码如下:private bool CheckOnDuty(int nStaffID)bool onDuty=fasle;/获取用户当天的考勤数据OfficeA

24、uto.Components.Attendance atten=new OfficeAuto. Components.Attendance ();SqlDataReader reca = atten.GetAttendanceByUserDay(nStaffID);If(reca.Read() /已经上班if(reca“OnDuty”.ToString().Length>0onDuty = True;reca.Close();return(onDuty);private void SetOnDuty(inr nStaffID) /如果用户没有考勤if(CheckOnDuty(nStaff

25、ID) = = false) /获取公司的考勤制度DutyTime duty = new DutyTime();SqlDataReader recd = Duty.GetDutyTimeByType(“Company”);DataTime dtOnDuty = DataTime.now;If(recd.Read() /读取考勤时间dtOnDuty = Convert.ToDataTime(recd“OnDutyTime”.ToString();recd.Close();OfficeAuto.Components.Attentance atten = New OfficeAuto.Compone

26、nts.Attendance();/正常上班if (TimeSpan)DataTime.now.Subtract(dtOnDuty).Hours<0)atten.AddAttendanceOnDuty(nStaffID,1);Response.Write(“<script language=javascript>alert( 上班考勤成功!);</script>”);else /上班迟到atten.AddAttendanceOnDuty(nStaffID,0);Response.Write(“<script language=javascript>al

27、ert( 上班迟到,请填写迟到理由!);</script>”); )应用程序运行后,查看页面Attendance.aspx,它的初始页面如图4.2所示,此时用户考勤,并显示下班考勤状态。  4.1.3 用户考勤功能单击页面Attendance.aspx中的【下班】按钮触发事件CheckAttendance_Click(object sender,System.EventArgs e),该事件实现用户的下班考勤功能。它首先检查用户当天是否考勤,如果用户没有考勤,则检查用户是否早退,并把考勤的数据添加到数据库中。事件CheckAttendance_Click(obj

28、ect sender,System.EventArgs e)的程序代码如下:protected void Check Attendance_ Click(objectsender,System.EventArgse)if(CheckOffDuty(nStaffID) = = false) /下班考勤SetOffDuty(nStaffID);private bool CheckOffDuty(int nStaffID)bool offDuty = false;/获取用户当天的考勤数据OffceAuto.Components.Attendce atten = new OfficeAuto. Com

29、ponents.Attendce ();SplDataReader reca = atten.GetAttendanceByUserDay(nStaffID);If(reca.Read() /已经下班 if(reca“OffDuty”.ToString().Length>0)offDuty = True;reca.Close();return(offDuty);private void SetOffDuty(int nStaffID) /如果用户没有考勤if(CheckOffDuty(nStaffID) = = false) /获取公司的考勤制度DutyATime duty = new

30、DutyATime ();SplDataReader recd = duty.GerDutyTimebyType(“company”);DataTine dtOffDuty = Data Time.Now;If(recd.Read()dtOffDuty = Convert.ToDataTime(recd“OffDutyTime”.ToString();)recd.Close();OfficeAuto.Components.Attendance();/正常下班if(TimeSpan)Data.now.Subtract(dtOffDuty).Hours>0)atten.AddAttendas

31、nceOffDuty(nStaffID,1);Response.Write(“<script language=javascript>alert(下班考勤成功!);</script>”);else /下班早退atten.AddAttendasnceOffDuty(nStaffID,0);Response.Write(“<script language=javascript>alert(下班早退,请填写早退理由!);</script>”); 4.2 考勤设置考勤设置功能由页面Set.aspx实现,它的代码隐藏文件为Set.aspx,主要实现设置公司

32、的考勤制度,如上班、下班的具体时间,同时还可以设置不同的的时间段使用不同的考勤制度。4.2.1 界面设计在页面Set.aspx 上添加4个textBox控件、2个Radiobutton控件、2个非空验证控件、2个正则表达式验证控件、2个比较验证控件和1个Button控件,它们的名称分别为Begintime、EndTime、OnDutyTime、OffDutyTime、rbtnthisweek、rbtnthismonth、rfOn、rfOff、rgOn、rgOff、vdate、cvOnOff和SerTime。控件Begintime和EndTime分别用来输入考勤日期的开始时间和节省时间;控件On

33、DutyTime和OffDutyTime分别用来输入每天考勤的上下班时间;控件rbtnthisweek和rbtnthismonth分别用来显示本周时间和本月时间;控件rfOn和rfOff分别对上下班时间的输入控件进行非空验证;控件rgOn和rgOff人分别对上下班时间的输入控件进行格式验证;控件vdate验证考勤日期的时间段的开始时间小于结束时间;控件cvOnOff验证每天的上班时间小于下班时间;控件SerTime用来保存用户的设置。页面Set.aspx 的设计界面如图4.3所示:  页面Set.aspx的HTML设计代码如下:<asp:textbox id=”beg

34、intime”onfocus=”setday(day);”runat=”server”ReadOnly=”True”Columns=”10”CssClass=”inputcss”></asp:textbox><asp:textbox id=”endtime”onfocus=”setday(day);”runat=”server”ReadOnly=”True”Columns=”10”CssClass=”inputcss”></asp:textbox>< asp:comparevalidator id=”cvdate”runat=” server”C

35、ontrolToCompare=”begintime”Operator=”GreaterThabEqual”ErrorMessage =”结束时间应该大于开始时间”ControlToValidate=”Endtime”Display=”none”></asp:comparevalidator>&nbsp<asp:radiobutton id=” rbtnthisweek”onclick=”quickseldateweek);”Runat=” server”GroupName=”quickdate”text=”本周”></asp:radiabutton

36、><asp:radiobutton id=” rbtnthismonth”onclick=”quickseldatemonth);”Runat=” server”GroupName=”quickdate”text=”本月”></asp:radiabutton><asp:textbox id=” OnDutyTime”runat=”server”CssClass=”inputcss”Width=”81px”></asp:textbox><asp:requiredfieldvalidator id=”rfOn”runat=” server

37、” ErrorMessage=”上班时间不能为空” ControlToValidate=”OnDutyTime”Display=”Dynamic”></asp:requiredfieldvalidator><asp:regularexpressionvalidator id=”rfOn”runat=” server” ErrorMessage=”时间格式错误” ControlToValidate=”OnDutyTime”Display=”Dynamic”ValidationExpression=”(0|1)0-9)|(20-3)|(0-9):(0-50-9)”>&

38、lt;/asp: regularexpressionvalidator ><asp:textbox id=” OffDutyTime”runat=”server”CssClass=”inputcss”Width=”79px”></asp:textbox><asp:requiredfieldvalidator id=”rfOff”runat=” server” ErrorMessage=”下班时间不能为空” ControlToValidate=”OffDutyTime”Display=”Dynamic”></asp:requiredfieldval

39、idator><asp:regularexpressionvalidator id=”rgOn”runat=” server” ErrorMessage=”时间格式错误” ControlToValidate=”OffDutyTime”Display=”Dynamic”ValidationExpression=”(0|1)0-9)|(20-3)|(0-9):(0-50-9)”></asp: regularexpressionvalidator ><asp:customvalidator id=”cvOnOff”runat=” server” ErrorMess

40、age=”下班时间不能早于上班时间” Display=”Dynamic”ClientValidationFuntion=”checkdutytime”></asp: customvalidator > (时间格式采用09:00或9:00) <asp:button id=”SetTime”runat=”server”CssClass=”buttoncss”Text=” 保 存”></asp:button>     页面初始化页面初始 Set.aspx调用函数page_Load(object sender,Syste

41、m.EventArgs e)初始化,改函数调用函数SetDutyTime()设置当前时间使用的考勤制度中的上班、下班时间。函数SetDutyTime() 从数据库中获取当前时间使用的考勤制度中的上班、下班时间,并以DataReader 对象返回。函数page_ Load(object sender,System.EventArgs e)和SetDutyTime(的程序代码如下:Private void page_Load(object sender,System.EventArgs e)If(!page.IsPostBack) /设置上下班时间SetDutyTime();Public void

42、 SetDutyTime() /从数据库中获取上下班时间DutyTime duty = new DutyTime();SqldataREAder dr = duty.GetDutyTime();While(dr.Read() /读取上班时间OnDutyTime.text = DataTime.parse(dr“OnDutyTime”.ToString().ToShortTimeString();/读取下班时间OffDutyTime.Text=DataTime.parse(dr“OffDutyTime”.ToString().ToShortTimeString();/关闭数据读取器dr.Clos

43、e();函数SetDutyTime()调用类DutyTime中的函数GetDutyTime()从函数库中获取当前时间使用的考勤制度中的上、下班时间,它调用存储过程Pr_ GetDutyTimes实现这一功能。函数GetDutyTime()的程序代码如下:Public SqlDataREader GetDutyTime() /从数据库获取上下班时间Database db = new Database();SqlDataREader dr = null;Db.RunProc(“Pr_ GetDutyTimes”,out dr); /强行存储过程Pr_ GetDutyTimesReturn(dr);

44、 /返回数据应用程序运行后,查看页面Set.aspx,并选中【本周】单选按钮,如图4.4所示。此时当前时间使用的考勤制度中的上班、下班时间分别为“9:00”和“17:00”.  4.2.3 考勤设置单击页面Set.aspx中的【保存】按钮触发设置保存事件SetTime_Click(object sender,System.EventArgs e),该事件调用类DutyTime中的函数UpdataDutyTime()保存用户的修改,其中函数UpdataDutyTime()带有参数dOnDutyTime和dOffDutyTime,它们分别表示上班时间和下班时间。事件SetTim

45、e_Click()和函数UpdataDutyTime()的程序代码如下:Private void SetTime_Click (object sender,System.EventArgs e)DutyTime duty = new DutyTime();Try /保存用户的修改duty.UpdateDuty Time(DateTime.Parse(OnDutyTime.Text.Terim(),DateTime.Parse(OffDutyTime.Text.Terim();Response.Write(“<ript”widow.alert(您的修改已保存!)</script>

46、;”);Catch()Exception ex /错误处理SystemError.SystemLog(ex.Message);Server.Transfer(“./ErrorPage.aspx”);public void UpdateDutyTime(DateTime dOnDutyTime, DateTime dOffDutyTime)Database db = new Database();/添加上班时间和下班时间参数SplParameter prams = Db.CreatlnParam(“Ondutytine”,SqlDbType.DataTime,8,dOnDutyTime),Db.

47、CreatlnParam(“Offdutytine”,SqlDbType.DataTime,8,dOffDutyTime );/运行存储过程 Pr_UpdateDutyTimedb.RunProc(“Pr_UpdateDutyTime”,prams);单击页面Set.aspx中的【保存】按钮保存用户的修改,并弹出提示对话框,如图4.5所示。  4.3 查看用户考勤查看用户考勤功能是由页面CheckAttendance.aspx实现,文件为它的代码隐藏文件,啊在该页面上可以直接查看用户的详细考勤情况。4.3.1 界面设计在页面CheckAttendance.aspx上添加2个

48、TextBox控件、2个非空验证控件、1个比较验证控件、2个Radiobutton控件、1个DropdownList控件、1个ListBox控件、1个Button控件和1个数据网格控件,它们的名称分别为Begintime、EndTime、rfB、rfE、cvdate、rbtnthisweek、rbtnthismonth、BoundList、StaffList、Search和AttendanceList。控件Begintime和EndTime分别用来输入考勤日期的时间段的开始时间和结束时间;控件rfB和rfE分别对时间段的开始时间和结束时间的输入控件进行非空验证;控件cvdate验证考勤日期的时

49、间段的开始时间小于结束时间;控件rbtnthisweek和rbtnthismonth分别用来显示本周时间和本月时间;控件BoundList和StaffList分别显示查找范围和在指定范围下的所有用户;控件SearchBth查询指定用户的考勤记录;控件AttendanceList显示用户的考勤记录。页面CheckAttendance.aspx的设计界面如图4.6所示。 页面CheckAttendance.aspx的HTML设计代码如下:<asp:textbox id=”Begintime”onfocus=”setday(this);”runat=”server”ReadOnly=

50、”True”Columns=”10”CssClass=”inputcss”></asp:textbox><asp:requiredfieldvalidator id=”rfB”runat=” server” ErrorMessage=”开始时间不能为空” ControlToValidate=”BeginTime”Display=”None”></asp:requiredfieldvalidator>-结束时间<asp:textbox id=”Endtime”onfocus=”setday(this);”runat=”server”ReadOnly

51、=”True”Columns=”10”CssClass=”inputcss”></asp:textbox><asp:requiredfieldvalidator id=”rfE”runat=” server” ErrorMessage=”结束时间不能为空” ControlToValidate=”EndTime”Display=”None”></asp:requiredfieldvalidator>&nbsp< asp:comparevalidator id=”cvdate”runat=” server”ErrorMessage =”结束时

52、间应该大于开始时间”ControlToValidate=”Endtime”Display=”None” ControlToCompare=”begintime” Operator=”GreaterThabEqual”></asp:comparevalidator>&nbsp<asp:radiobutton id=” rbtnthisweek”onclick=”quickseldateweek);”Runat=” server”GroupName=”quickdate”text=”本周”></asp:radiabutton><asp:rad

53、iobutton id=” rbtnthismonth”onclick=”quickseldatemonth);”Runat=” server”GroupName=”quickdate”text=”本月”></asp:radiabutton><asp:dropdownlist id =”BoundList”runat=”serverAutoPostBack=”True” Width=”300px”> <asp:Listltem Value=”0”Selected=”True”>个人</asp: Listltem ></asp :dro

54、pdownlist><asp:listbox id=”Stafflist”runat=”server”CssClass=”buttoncss”Width=”150px” Height=”141px”SelectionMode=”Multple”></asp:listbox ><asp:validationsummary id=”vsMessage”runat=”server”></asp:validationsummary ><asp:button id=”SearchBtn”runat=”server” CssClass=”butt

55、oncss”Text=” 查 询 ”>< /asp:button>.<asp:datagrid id=”AttendanceList” runat=”server” Width=”100%”AutoGenerateColumns=”false”EnableViewState=” false”DatakeyFied=”staff_id”borderCoror=”#93BEE2”BorderWidth=”1px”CellPadding=”3”><HeaderStyle Font-Size=”X-Small”BackColor=”#E8F4FF”></

56、HeaderStyle><Columns> <asp:Boundcolmn headerText=”正常天数”><ltemTemplata> <asp.HyperLink Text =,%#> GetGridData(DataRowView)Container.Dataltem)“Staff_ID”.ToString(),0)NavigataUri=<%#“tmpStaffData.aspx?staffid=”+(DataRowView)Container.Datalem)“Staff_ID”.ToString()+”&beg

57、intime=”+Begintime.Text+”&endtime=”+Endtime.Text+”&type=1”%>Argel=_blank Runat=server ID=”Hyperlink1”> </asp: Hyperlink></Columns> </asp: datagrid>4.3.2 页面初始化页面CheckAttendance.aspx调用函数page_ Load(object sender,System.EventArgs e)初始化,该函数调用函数DataBindObject(object sender)绑定用户列表控件Stafflist的数据。函数DataBulidObject(objectsender)调用类StaffDB中的函数GetStaffByOStatus(1)从数据库获取所有在职用户的数据并显示,如用户真实姓名等。函数page_ Load

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论