毕业设计选题管理系统_第1页
毕业设计选题管理系统_第2页
毕业设计选题管理系统_第3页
已阅读5页,还剩25页未读 继续免费阅读

下载本文档

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

文档简介

1、1. 前言每年毕业临近, 都有大量的毕业生需要进行毕业设计, 这其中的首要关节就是课题的 选择,以往指导老师都是采用人工手写方式给学生们提供相关的课题供学生选择,如果指 导老师带领的学生比较多,或者是当年毕业的学生比较多,这样就容易造成学生的课题选 择很混乱,指导教师难于统计学生的课题选择情况等一系列问题,基于这些传统问题,我 们需要一个能够自动统计、实时分配课题的一个管理平台来帮助学生、指导老师。此系统的开发,主要的目的是使老师能更好的管理课程设计,也能使学生能更好的把 自己想要选的课程正确无误的选出来。使处在选课时期的学生能有条不紊的进行。2. 系统的需求分析2.1 功能需求2.1.1 毕

2、业设计选题管理系统功能要求:1. 毕业设计题目维护和查询:毕业设计题目的添加、修改;按照项目类型、名称、编号 等查询;毕业设计选题查询、登记。2. 指导教师信息维护和查询:指导教师信息的添加、修改、删除,查询;3. 毕业生选题管理:学生选题登记;选题情况查询;4. 毕业生信息的维护和查询。根据以上各功能模块需求将系统的功能细化为以下几点:1)前台学生选题学生网上选题:学生登录管理系统进行选题 (2)前台教师出题教师网上出题:教师进入毕业选题出题。 教师管理出题:教师进入系统后对毕业设计题目进行修改和删除。 选题确认:学生选好题目后,教师可以确认该题由选择该题的学生做。(3)后台管理出题及选题情

3、况用户管理模块:管理员可以对用户进行用户管理,对已存在的用户进行修改,查看等。 角色管理模块:管理员可以对用户的角色进行管理,可以给用户分配角色,对角色分配权限。2.2 开发环境需求操作系统: window7 或更高版本因为毕业设计课题管理系统针对的用户是学生和教师,学生和教师普遍使用 windows 操作系统,所以选着 windows7 或更高版本的操作系统web 服务器: apache-tomcat6apache-tomcat6是开源的免费的 web服务器,节省开发成本数据库: MySQLMySQ是一款免费的数据库,节省成本开发工具: myeclipse8.5myeclipse8.5功能强

4、大的JavaEE开发工具,该管理系统选用 JavaEE开发3. 系统设计3.1基本设计概念和处理流程本系统采用结构化分析,设计顺序为自顶向下,层层逐步细化图13.2软件功能设计图23.2数据库设计3.2.1 E-R 图图3图4数据库表用户表(user)字段类型备注useridVarchar ( 20) primarykey用户IDPwdvarchar(32)用户密码roleldInt外键tn ameVarchar(20)姓名sexVarchar(5)性别AgeInt年龄表1课题表(task)字段类型备注taskIdInt primary key课题IDtask namevarchar(20)课

5、题名sflagint状态(是否被选)taskTextvarchar(50)课题内容表2选择课题(chosetask)字段类型备注ctIdint primary key学生选课题iduIdvarchar(10)外键taskldInt课题ID表3上传课题(puttask)字段类型备注ptIdint primary key教师上传课题iduIdvarchar(10)外键taskIdInt课题ID表4角色表(rolei nfo)字段类型备注roleIdInt primary key角色IDrole namevarchar(10)角色名表5权限表(right info)字段类型备注rightCodeva

6、rchar(20)primary key权限rightPare ntCodevarchar(30)父权限rightTypevarchar(20)rightTextvarchar(50)RightUrlvarchar(30)url地址RightTipvarchar(50)表6角色权限表(roleright )rr_idInt primary key主键rr_roleidInt外键role表rr_rightCodevarchar(20)外键righti nfo 表表74. 典型功能模块的详细设计和实现过程用户模块登录功能代码:public String doLogin()if (uu!= null

7、 )ServletActio nCon text.getRequest().getSessio n().setAttribute("USER"uu);int roleld=uu.getRoleinfo().getRoleld();Role info r=roleService .getRoleWithRights(roleld);Stri ng menu Stri ng=buildDTreeMe nu Stri ng(r);"MENU_STRING"ServletAct ionCon text.getRequest().getSessio n( ).se

8、tAttribute( men uStri ng);return "main"elsereturn "i nput"public Userinfo checkUser(Userinfo u) Userinfo uu= null ;String hql= "from Useri nfo where userid=? and pwd=?"Object args =new Objectu.getUserid(),u.getPwd();ListvUseri nfo> list =com mon Daost(hql, args);if (

9、list!= null && list.size()>0)uu = list.get(O);return uu;public List list(String hql, Object args) List list= this .getHibernateTemplate().find(hql,args);return list;查询信息功能代码:public String toList()SPageBea n spb = new SPageBea n();HttpServletRequest request = ServletActionCon text.getReque

10、st();int offset = 0;if (request.getParameter( "pager.offset" ) = null ) offset = 0; else );null ) offset = Integer.parseInt (request.getParameter( "pager.offset"int maxPageItems; if (request.getAttribute( "maxPageltems")=maxPageItems = 5; else maxPageItems =Integer. par

11、seInt (request.getParameter( "maxPageItems");spb.setOffset(offset);spb.setPageSize(maxPageltems);in foService.getList(spb);request.setAttribute( "SPB", spb);return "list"public void getList(SPageBean spb) Stri ng hql= "from Useri nfo" ;com mon DaostByPage(hql,

12、 spb);public void listByPage(String hql, SPageBean spb) final String hql 仁 hql;finalSPageBea n spb仁spb;if (hql!= null )int total=(Integer)this .getHibernateTemplate().execute(newHibernateCallback() HibernateException,SQLException String qString= "" ;)!=-1)"from" );if (hql1.toLowe

13、rCase().indexOf( "select "int idx=hql1.toLowerCase().indexOf( qString= "select count(*)" +hql1.substring(idx,hql1.length();else qString= "select count(*) "+hql1;Query cQuery=sess.createQuery(qString);cQuery.setCacheable( true );long o= (Long)cQuery.uniqueResult();int ii

14、=( int )o;return ii;);spb.setTotal(total);newList data=(List) this .getHibernateTemplate().execute(HibernateCallback() public Object doInHibernate(Session sess)throwsHibernateExceptio n,SQLExcepti on Query query= sess.createQuery(hql1);query.setFirstResult(spb1.getOffset();query.setMaxResults(spb1.g

15、etPageSize();return query.list(););spb.setDatas(data);public class SPageBean privateintoffset ;privateintpageSize;privateinttotal ;privateListdatas;publicintgetTotal() return total ;public void setTotal( int total) this . total = total;public List getDatas() return datas;public void setDatas(List da

16、tas) this . datas = datas;public int getOffset() return offset ;public void setOffset( int offset) this . offset = offset;public int getPageSize() return pageSize ;public void setPageSize( int pageSize) this . pageSize = pageSize;上传课题功能代码:public String toadd()return "add"public String doad

17、d()if (taskService .doAdd( task )= true )SPageBea n spb = n ewSPageBea n();HttpServletRequest request = ServletActionCon text.getRequestO;int offset = 0;if (request.getParameter( "pager.offset" ) = null ) offset = 0; else offset = Integer. parseInt (request.getParameter( "pager.offset

18、");null ) maxPageltems = 5; else maxPageItems =Integer. parseInt (request.getParameter( "maxPageItems");spb.setOffset(offset);spb.setPageSize(maxPageltems);taskService .getTaskinfo(spb);ServletActio nCon text.getRequest().setAttribute("SPB1", spb);return "list"else

19、return "add"public boolean doAdd(Tasklnfo t) Serializable ret =com mon Daodd(t);return ret!= null ;管理员模块管理员对角色管理功能:public class RoleAction extends ActionSupportprivate IRoleService roleService ;private IRightService rightService ;private Role info role ;public void setRoleService(IRoleServ

20、ice roleService) this . roleService = roleService;public void setRightService(IRightService rightService) this . rightService = rightService;public Roleinfo getRole() return role ;public void setRole(Roleinfo role) this . role = role;public String toList()List<Role info> roles=roleService .get

21、ListO;ServletActio nCon text.getRequest().setAttribute( return "list"public String toAssign()"ROLES" roles);List<Righti nfo> rights=rightService .getAIIRights();Roleinfo r = roleService .getRoleWithRights( role .getRoleld();for (Rightinfo right:rights)if (r.getRights().con

22、tain s(right)right.setChecked( "checked");ServletActio nCon text.getRequest().setAttribute("ROLE: r);ServletActio nCon text.getRequest().setAttribute("RIGHTS:rights);return "assign"public String doAssign()throws ExceptionHttpServletRequest request=ServletActionCon text.

23、getRequest();roleService .updateRoleRights( role .getRoleld(),newRights);HttpServletResp onse resp on se=ServletActionCon text.getResp on se();response.sendRedirect( "role!toAssign.action?role.roldId="+role .getRoleId()+"&message=ok");return null ;public class RightServiceImp

24、l_Himplements IRightServiceprivate ICom mon DAOco mmon Daopublic void setCom mon Dao(ICom monDAO com mon Dao) this . com mon Dao com mon Dao;public List<Rightinfo> getAllRights() Stri ng hql= "from Right info" ;List<Righti nfo> list =com mon Daost(hql);return list;管理员对用户管理功能:(增

25、、删、改、查)public String delete()int uid ="userid");Integer. parseInt (ServletActionContext.getRequest().getParameter(boolean flag = userService .delete(uid);if (flag)return "list1"elsereturn "list"/编辑用户public String toedit()int"userid")uid=Integer. parseInt (Serv

26、letActionContext.getRequest().getParameter(Userinfo uu = userService .detail(uid);"USER2" uu);ServletActio nCon text.getRequest().setAttribute( return "edit"public String edit()boolean flag = userService .update( user);if (flag)return "list"elsereturn "edit_error&q

27、uot; ;public String detail()int"userid")uid=Integer. parseInt (ServletActionContext.getRequest().getParameter(Userinfo uu =userService .detail(uid);"USER1" uu);ServletActio nCon text.getRequest().setAttribute( return "detail"public String add()if (userService .addUser(

28、user)= true )ListvUserinfo> user = userServiceist();"USERS" user);ServletAct ionCon text.getRequest().setAttribute( return "list" elsereturn "add"public String toadd()return "add"public String doLogin()if (uu!= null )ServletActio nCon text.getRequest().getS

29、essio n().setAttribute("USER"uu);int roleld=uu.getRoleinfo().getRoleld();Role info r=roleService .getRoleWithRights(roleld);Stri ng menu Stri ng=buildDTreeMe nu Stri ng(r);"MENU_STRING"ServletAct ionCon text.getRequest().getSessio n( ).setAttribute( men uStri ng);return "mai

30、n"elsepublic boolean addUser(Userinfo u) Serializable ret =commonDa.oadd(u);return ret!= null ;public List list() String hql = "from Userinfo" ;List<Userinfo> list = commonDa.loist(hql);return list;public Userinfo detail( int userid) Userinfo uu= null ;String hql= "from Userinfo u left outer join fetch u.ro

温馨提示

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

评论

0/150

提交评论