基于Web的研究生学位信息管理系统开发关键技术

上传人:m****a 文档编号:237648747 上传时间:2022-01-10 格式:DOCX 页数:14 大小:29.35KB
返回 下载 相关 举报
基于Web的研究生学位信息管理系统开发关键技术_第1页
第1页 / 共14页
基于Web的研究生学位信息管理系统开发关键技术_第2页
第2页 / 共14页
基于Web的研究生学位信息管理系统开发关键技术_第3页
第3页 / 共14页
基于Web的研究生学位信息管理系统开发关键技术_第4页
第4页 / 共14页
亲,该文档总共14页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《基于Web的研究生学位信息管理系统开发关键技术》由会员分享,可在线阅读,更多相关《基于Web的研究生学位信息管理系统开发关键技术(14页珍藏版)》请在金锄头文库上搜索。

1、基于Web的研究生学位信息管理系统开发关键技术 摘 要 作者开发的基于Web的研究生学位信息管理系统具有数据录入、数据处理、信息查询、信息输出、数据导出等基本功能。介绍了系统体系结构以及开发的关键技术,包括基于窗体身份验证、基于角色的用户管理以及基于存储过程的分页显示技术等。关键词 学位信息管理系统;身份验证;用户管理;分页显示 1 引言研究生学位管理是研究生教育的一个重要环节,是一项涉及多学科知识,需多部门协调工作的管理系统工程。它主要完成数据录入、数据处理、信息输出和数据导出等工作。学位管理部门要求:可以从其它部门获取已有的学生信息,也可以手工录入学位信息;数据经过处理后以适当的形式输出相

2、关文件或表格,如学位申请表、授予学位文件、授予学位名单、学位证明等,同时将处理后的数据按一定格式上报教育部。针对上述需求,我们开发了基于Web的研究生学位管理信息系统。该系统采用ASP.NET2.0开发平台、C#语言、SQL Server 2000数据库管理系统,在基于Intranet/Intranet的校园网环境下运行。2 系统设计本系统采用三层B/S体系结构,如图1所示,其中:图1 系统体系结构图表示层:相当于用户界面,为客户端提供对整个应用程序的访问。在本系统中表示层由ASP.NET Web窗体和代码隐藏文件组成。在.aspx文件中只有html代码和服务器控件,在页面程序代码文件(.cs

3、文件)中调用.dll组件中的数据库操作方法,返回满足条件的结果。中间层:是整个系统的核心部分,担当主要的应用处理,包括处理表示层的HTTP请求以及对数据库的访问。在设计系统时,我们把应用程序中的业务逻辑放在中间层应用服务器上,这样业务逻辑和用户界面分开。如果要修改应用程序代码,只须对应用服务器进行修改,而不用修改成千上万的客户端应用程序。同时由于Asp.Net只支持面向对象,组件也可以看作类,因此可以在Web项目中添加对数据库操作的组件,并将其编译为.dll,这样就把数据库的操作过程封装起来,便于代码的安全管理和维护。因此,我们把中间层进一步分解为业务外观、业务规则、数据访问等层进行处理,并且

4、把它们封装在了独立的.dll组件中。其中,业务外观层用作隔离层,它将用户界面与各种业务功能的实现隔离开来,它除了为表示层提供服务,还可以访问业务规则和数据访问层,是系统的公共入口点。业务规则层包含了各种业务规则和逻辑的实现。数据访问层为业务外观层和业务规则层提供数据服务,其中包含了各种数据访问的类。数据层:位于底层,以ADO.NET为接口,SQL Server2000为后台,主要处理应用层对数据的请求。系统运行时,客户端浏览器发出对页面的访问请求,访问表示层各aspx文件,再将各请求事件发送到业务外观层,业务外观层根据需要访问业务规则层或数据访问层。而业务规则层只能访问数据访问层,数据访问层通

5、过ADO.NET访问数据层的存储过程以达到对数据库的操作。由于整个系统由相互交互的各层实现,因此可以实现系统的分布式部署,以达到分布式应用来减轻各层的压力。由于客户端向服务器请求页面时,其复杂的逻辑处理在服务器端进行,在客户端只能看到该网页的最终表现和HTML,而不能看到该网页的程序逻辑,这样可以有效地保护程序代码的安全。图1对应的研究生学位信息管理软件模块结构如图2所示。图2 学位系统功能模块图其中,各模块实现的功能如下:(1)数据导入:辅助学位办工作人员从其它部门(招生办、培养科)导入学生已有的基本信息,包括学籍信息和培养信息。(2)数据录入:辅助学位办工作人员通过研究生部局域网,以及研究

6、生通过互联网录入相关信息。(3)数据处理:实现学位证书号码自动生成、数据转存数据维护等操作。(4)用户管理:实现各种登录用户的角色、权限管理以及密码修改。(5)数据查询:实现从数据库查找相关学生记录,并按一定格式显示和打印。(6)数据输出:实现学位申请表的打印、学位信息导入、上报库dbf表等功能。3 系统实现1) ASP.NET中的安全机制学位系统采用ASP.NET安全架构中的表单验证方式实现用户登录。使用表单身份验证时,通过指定的登录页面收集用户的凭证信息,如果未验证身份的用户试图访问受保护的文件或资源(其中,URL授权拒绝用户访问)将被重新定向到该登录页面,用户在此处尝试通过身份验证。用户

7、提供凭据并提交该窗体,如果应用程序对请求进行身份验证,系统会发出一个Cookie,其中包含用于重新获取标识的凭据或密钥。随后发出的请求在请求头中具有该Cookie,ASP.NET事件处理程序使用应用程序开发人员指定的任何验证方法对这些请求进行身份验证和授权。其验证流程如图3所示。图3 基于窗体的身份验证流程基于窗体的身份验证开发步骤如下:(1) 将IIS配置为使用匿名访问。(2) 将 ASP.NET 配置为使用表单身份验证。在Web.config文件中配置authentication元素的属性,设置为身份验证模式。 (3) 检索数据存储验证用户,从自定义数据存储中检索角色列表(不是基于角色可不

8、用)。(4) 使用FormsAuthenticationTicket创建一个Cookie并回发到客户端,并存储角色到票中。 FormsAuthentication.SetAuthCookie(Username,true | false)HttpContext.Current.Response.CookiesFormsAuthentication.FormsCookieName.Expires=DateTime.Now.AddDays(1) /cookies保存时间如果需要存储角色,采用: FormsAuthenticationTicket authTicket = new Forms Auth

9、enticationTicket( 1, / 版本号,设置为1 txtUserName.Text, / 用户标示 DateTime.Now, / Cookie的发出时间, 设置为 DateTime.Now DateTime.Now.AddMinutes(20),/ Cookie的有效时间 false, / 是否持久性roles );/roles为存储的用逗号分割的角色串string encryptedTicket = FormsAuthentication. Encrypt (authTicket); /把身份验证票加密/设置验证票cookie,第一个参数为cookie的名字,第二个参数为co

10、okie的值也就是加密后的票 HttpCookie authCookie = new HttpCookie(FormsAuthentication.FormsCookieName,encryptedTicket);Response.Cookies.Add(authCookie); /把cookie加进Response对象发生到客户端(5)在Global.asax内的Application_AuthenticateRequest事件中处理程序中(Global.asax)中,使用票创建IPrincipal对象并存在HttpContext.User中。HttpCookie authCookie =

11、Context.Request.Cookies Forms Authentication.FormsCookieName; FormsAuthenticationTicket authTicket = Forms Authentication. Decrypt(authCookie.Value);/解密 string roles = authTicket.UserData.Split(new char,);/根据存入时的格式分解角色 Context.User = new GenericPrincipal(Context.User. Identi ty, Roles);/存入HttpContex

12、t.User 2) 基于角色的用户管理基于角色的访问控制已经相当成熟,作为策略中立的鉴别和授权机制,通过角色的继承和职责分离等控制约束条件可以实现多种控制策略。基于角色的访问控制引入角色这个中介,安全管理人员根据需要定义各种角色,并设置合适的访问权限,而用户根据其职责被指派为不同的角色。由于实现了用户与访问权限的逻辑分离,基于角色的策略极大地方便了权限管理,而且对实际应用环境的访问控制需求的描述更自然,而对一个组织来说,其行为特征和功能是比较稳定的,因此其角色是比较稳定的。由于角色/权限之间的变化比角色/用户关系之间的变化相对要慢得多。本学位管理系统包含了多种数据操作功能,并且拥有不同种类的多

13、个用户,从总体上考虑可以分为管理员、教师(普通教师、研究生秘书)和研究生(硕士、博士、专业硕士等)。不同类别的用户对系统功能的使用权限是不同的,因此要求系统提供一种对多用户的权限管理,以确保具有权限的用户能够获取或处理数据和信息,禁止所有未授权用户操作数据。针对系统的这一特点,我们在开发过程中,采用了两级控制机制分别对页面资源和数据进行控制。在用户成功登录系统后根据用户角色所具有的权限动态生成菜单页面,从而限制了用户对未授权页面的访问;在用户访问同一页面时,对于不同的用户所获取的数据信息是不一样的。例如,对于不同学院的研究生秘书进入系统后,他们只能操作所在学院的学生数据。在研究生学位管理系统中

14、,我们把所有系统用户的角色信息保存在数据库的用户表中。其次,将系统中所有的功能模块及其子功能访问接口的访问权限信息都存放在数据库中的访问权限表中。当用户登录学位管理系统时,权限管理的系统流程如图4所示。图4 权限管理的系统流程3) 基于存储过程分页显示技术显示数据查询的结果时,为了缩短页面数据的显示时间,我们利用分页的方法来显示查询结果。传统的数据分页方法是ADO 纪录集分页法,也就是利用ADO自带的分页功能(利用游标)来实现分页。但这种分页方法仅适用于较小数据量的情形,因为游标本身有缺点:游标是存放在内存中,很费内存。游标一经建立,就将相关的记录锁住,直到取消游标。对于数据量大的数据源而言,

15、分页检索时,如果按照传统的每次都加载整个数据源的方法是非常浪费资源的。因此在分页的时候可以检索当前页面所需数据,而非检索所有的数据,然后单步执行当前行,这就是我们所说的基于存储过程的分页显示技术。最早较好地实现这种根据页面大小和页码来提取数据的方法是“俄罗斯存储过程”。这个存储过程用了游标,由于游标的局限性,该方法没有得到很好的应用。事实上,在查询和提取超大容量的数据集时,影响数据库响应时间的最大因素不是数据查找,而是物理的I/0操作。例如我们取出学科名为计算机应用技术的前十名学生信息: select top 10 * from (select top 10000 Xh,Xm,Hsxwrq from XueWeiXinXi where Xkm=计算机应用技术order by Xh desc) as a order by Xh asc从理论上讲,整条查询语句的执行时间应该比子句的执行时间长,但事实相

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

当前位置:首页 > 学术论文 > 经济论文

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号