还剩15页未读,继续阅读
本资源只提供10页预览,全部文档请下载后查看!喜欢就下载吧,查找使用更方便
文本内容:
武汉理工大学华夏学院大作业报告书课程名称JSP程序设计题目用户管理系统的__与设计系名信息工程系专业班级计算机姓名学号指导教师:苏永红2014年5月23日1目标
1.1实现用户登录检测,__修改;
1.2用户信息管理2软件__环境
2.1__工具介绍MyEclipse是一个十分优秀的用于__J__aJ2EE的Eclipse插件__,MyEclipse的功能非常强大,支持也十分广泛,尤其是对各种开源产品的支持十分不错MyEclipse目前支持J__aServletAJAXJSPJSFStrutsSpringHibernateEJB3JDBC数据库链接工具等多项功能SQLyog是业界著名的Webyog公司出品的一款简洁高效、功能强大的图形化MySQL数据库管理工具使用SQLyog可以快速直观地让您从世界的任何角落通过网络来维护远端的MySQL数据库
2.2数据库系统数据库是一种工作环境,它存储了一个“表”的__,在表之间可以建立关系,对于数据字段可以设置属性和触发规则,从而保证表之间数据的完整性3系统需求分析
1.系统应建立友好的界面,既要操作简单、直观、,又要易于学习掌握__用户管理系统的目的是为了方便___对于用户信息的管理,包括修改、删除、输入等
2.系统在对于不同用户名__时,将给出不同权限功能,比如,普通用户只能查看、修改自己的信息,而对于___,则包括用户信息输入;信息查询,可根据不同关键字进行条件查询;用户信息修改,可以修改,删除普通用户
3.该系统主要是面对系统___,故操作应该简单易懂,对于每一步的操作,都有不同的选择性,更显得系统的人性化4系统总体设计
4.1系统功能简介
4.2系统功能模块规划图
14.3系统数据库设计首先创建数据库,然后在数据库中创建一个tb_userd的表,再表中建立用户的基本信息,包括姓名,性别,年龄,__,地址等等的基本信息再创建一个admin的表,再表中建立用户的基本信息,包括姓名,性别,年龄,__,地址等等的基本信息Admin为超级用户,可增、删、查、改普通用户信息图2普通用户的数据库界面创建一个admin的表,再表中建立用户的基本信息,包括姓名,性别,年龄,__,地址等等的基本信息Admin为超级用户,可增、删、查、改普通用户信息图3___的数据库界面
4.4数据库的连接技术数据库连接代码publicclassUserDAO{//注册publicbooleanaddStringusernameStringupassString___intageStringe__ilStringtelString__Stringdescr{booleanflag=false;//将数据存放到db中去try{//加载驱动Class.forName;//建立连接Connectionconn=Driver__nager.getConnectionjdbc:mysql://localhost:3306/wbroot123456;//准备语句Stringsql=insertintotb_userusernameupass___agee__iltel__descrvalues+username++upass++___++age++e__il++tel++__++descr+;//准备对象Statementst=conn.createStatement;//执行flag=!st.executesql;}catchClassNotFoundEx__ptione{e.printStackTra__;}catchSQLEx__ptione{e.printStackTra__;}returnflag;}5系统详细设计
5.1登录模块在该模块中,用户选择登陆权限后,对于用户输入的信息进行判断该用户是否有权利进入系统,用户通过在该页面中输入的用户名和__,__确定的同时系统到数据库中自动核对用户的信息,核对无误后可以成功进入系统
5.2输入信息模块在该模块中,普通用户只能在其中修改自己的信息,包括__等,同时可以检测自己信息的正误对于___,则可以在数据库中修改,删除所有用户的基本信息,而且还可以进行用户信息的输入,还可以查询基本信息
5.3数据库模块该模块是用来存储___以及普通用户6系统测试与运行
6.1运行截图图4登陆界面选中___的下拉框,输入___账号和__图5___登入界面___在这一界面可查看普通用户图6___查看用户界面___在这一界面可修改和删除普通用户图7___修改用户界面___在这一界面可修改普通用户的信息图8___修改用户界面___在这一界面可增加普通用户图9普通用户登录界面普通用户在这一界面可查看自己的信息7总结经过不断的努力,用户管理系统终于做完了,经过这次实习系统设计,自己总结了这个用户信息管理系统的一些问题,不过收获还是颇为丰富的,再有理论知识上结合实践,使我学到了更多首先,更进一步的了解了数据库的基本操作,在这之前,数据库的学习仅仅刚开了个头,我们只是在了解一些概念性的东西在做这个系统之前,我连基本的连接数据库,配文件DSN,数据库查询语句等这些东西都不熟练现在对于数据库的增删改查操作比较熟练了,对于初学者来说,比较头疼的就是对于单引号的处理我的建议是如果不理解先把按照课本上正确的语句敲,然后在多次进行数据库的链接,增删改查操作中不断总结规律这次设计的用户信息管理系统,全在自己所掌握的知识下,进行编程设计,完全体现了自己在数据库语言和程序设计课程学习状况,充分地为自己以后更深入了数据库语言奠下深厚的基础纵观此学生信息管理系统的整体概况,目前,自我认为设计良好,相关功能都能够实现,功能强大,条理清晰,界面可观性比较好并且特色在于,所设计的表单都在一个表单系统桌面中运行,比较符合系统的观念在系统设计的过程中,我从中发现,学习数据库要细心和有耐性,并且要不断地从外界学习更多的技术才能设计出一套__的系统参考文献
[1]王建华ASPNET
2.0动态____技术与实践北京电子工业出版社2007年2月
[2]张建伟数据库技术与应用——SQLSever2005人民邮政出版社2009年2月
[3]JamesFoxallVisualC#2008人民邮政出版社2009年6月附录系统核心代码//登录publicbooleanloginStringusernameStringupass{booleanflag=false;try{//加载驱动Class.forName;//建立连接Connectionconn=Driver__nager.getConnectionjdbc:mysql://localhost:3306/wbroot123456;//准备语句Stringsql=select*fromtb_userwhereusername=+username+andupass=+upass+;//准备对象Statementst=conn.createStatement;//执行//CUD写booleana=executesql、inta=executeUpdatesql//Rselect读--ResultSetr=executeQuerysql;ResultSetrs=st.executeQuerysql;//如何取出rs中的数据进行判断intid=0;//判断rs中是否有数据whilers.next{//有数据,则取出数据id=rs.getIntuid;}ifid0{flag=true;}}catchSQLEx__ptione{e.printStackTra__;}catchClassNotFoundEx__ptione{e.printStackTra__;}returnflag;}//登陆___publicbooleanloginadminStringadnameStringadpass{booleanflag=false;try{//加载驱动Class.forName;//建立连接Connectionconn=Driver__nager.getConnectionjdbc:mysql://localhost:3306/wbroot123456;//准备语句Stringsql=select*fromadminwhereadname=+adname+andadpass=+adpass+;//准备对象Statementst=conn.createStatement;//执行//CUD写booleana=executesql、inta=executeUpdatesql//Rselect读--ResultSetr=executeQuerysql;ResultSetrs=st.executeQuerysql;//如何取出rs中的数据进行判断intid=0;//判断rs中是否有数据whilers.next{//有数据,则取出数据id=rs.getIntid;}ifid0{flag=true;}}catchSQLEx__ptione{e.printStackTra__;}catchClassNotFoundEx__ptione{e.printStackTra__;}returnflag;}//查询所有tb_user信息//List泛型publicListUserfindAll{//创建一个可变长度的链表ListUserlist=newArrayListUser;//我需要去吧数据库中的信息查询出来try{//加载驱动Class.forName;//建立连接Connectionconn=Driver__nager.getConnectionjdbc:mysql://localhost:3306/wbroot123456;//准备语句Stringsql=select*fromtb_user;//准备对象Statementst=conn.createStatement;//执行//C-insertU-updateD-delete写booleana=executesql、inta=executeUpdatesql//Rselect读--ResultSetr=executeQuerysql;ResultSetrs=st.executeQuerysql;//判断rs中是否有数据whilers.next{//有数据,则取出数据intuid=rs.getIntuid;Stringusername=rs.getStringusername;Stringupass=rs.getStringupass;String___=rs.getString___;Stringage=rs.getStringage;String__=rs.getString__;Stringe__il=rs.getStringe__il;Stringtel=rs.getStringtel;Stringdescr=rs.getStringdescr;uid:+uid+;username:+username;//封装Useru=newUser;u.setUiduid;u.setUsernameusername;u.setUpassupass;u.setAgeage;u.set______;u.setTeltel;u.setE__ile__il;u.set____;u.setDescrdescr;//将user放入listlist.addu;}}catchSQLEx__ptione{e.printStackTra__;}catchClassNotFoundEx__ptione{e.printStackTra__;}returnlist;}//查询学生自己信息publicListUserfindselfinfoStringusername1Stringupass1{ListUserlist=newArrayListUser;//我需要去吧数据库中的信息查询出来try{//加载驱动Class.forName;//建立连接Connectionconn=Driver__nager.getConnectionjdbc:mysql://localhost:3306/wbroot123456;//准备语句Stringsql=select*fromtb_userwhereusername=+username1+andupass=+upass1+;//准备对象Statementst=conn.createStatement;//执行//C-insertU-updateD-delete写booleana=executesql、inta=executeUpdatesql//Rselect读--ResultSetr=executeQuerysql;ResultSetrs=st.executeQuerysql;//判断rs中是否有数据whilers.next{//有数据,则取出数据intuid=rs.getIntuid;Stringusername=rs.getStringusername;Stringupass=rs.getStringupass;String___=rs.getString___;Stringage=rs.getStringage;String__=rs.getString__;Stringe__il=rs.getStringe__il;Stringtel=rs.getStringtel;Stringdescr=rs.getStringdescr;uid:+uid+;username:+username;//封装Useru=newUser;u.setUiduid;u.setUsernameusername;u.setUpassupass;u.setAgeage;u.set______;u.setTeltel;u.setE__ile__il;u.set____;u.setDescrdescr;//将user放入listlist.addu;}}catchSQLEx__ptione{e.printStackTra__;}catchClassNotFoundEx__ptione{e.printStackTra__;}returnlist;}//根据id删除publicbooleandeleteByIdintuid{booleanflag=false;//将数据存放到db中去try{//加载驱动Class.forName;//建立连接Connectionconn=Driver__nager.getConnectionjdbc:mysql://localhost:3306/wbroot123456;//准备语句Stringsql=deletefromtb_userwhereuid=+uid;//准备对象Statementst=conn.createStatement;//执行inti=st.executeUpdatesql;//如果有数据受影响,那么返回影响的行数值//如果行数值大于0,那么有数据被影响ifi0{flag=true;}}catchClassNotFoundEx__ptione{e.printStackTra__;}catchSQLEx__ptione{e.printStackTra__;}returnflag;}//根据id查出信息publicUserfindByIdintuid{Useru=newUser;//我需要去吧数据库中的信息查询出来try{//加载驱动Class.forName;//建立连接Connectionconn=Driver__nager.getConnectionjdbc:mysql://localhost:3306/wbroot123456;//准备语句Stringsql=select*fromtb_userwhereuid=+uid;//准备对象Statementst=conn.createStatement;//执行//C-insertU-updateD-delete写booleana=executesql、inta=executeUpdatesql//Rselect读--ResultSetr=executeQuerysql;ResultSetrs=st.executeQuerysql;//判断rs中是否有数据whilers.next{//有数据,则取出数据Stringusername=rs.getStringusername;Stringupass=rs.getStringupass;String___=rs.getString___;Stringage=rs.getStringage;String__=rs.getString__;Stringe__il=rs.getStringe__il;Stringtel=rs.getStringtel;Stringdescr=rs.getStringdescr;u.setUiduid;u.setUsernameusername;u.setUpassupass;u.setAgeage;u.set______;u.setTeltel;u.setE__ile__il;u.set____;u.setDescrdescr;}}catchSQLEx__ptione{e.printStackTra__;}catchClassNotFoundEx__ptione{e.printStackTra__;}returnu;//根据id修改publicbooleanupdateByIdStringusernameStringupassString___intageStringe__ilStringtelString__Stringdescrintuid{booleanflag=false;//将数据存放到db中去try{//加载驱动Class.forName;//建立连接Connectionconn=Driver__nager.getConnectionjdbc:mysql://localhost:3306/wbroot123456;//准备语句Stringsql=updatetb_usersetusername=+username+upass=+upass+___=+___+age=+age+e__il=+e__il+tel=+tel+__=+__+descr=+descr+whereuid=+uid;//准备对象Statementst=conn.createStatement;//执行flag=!st.executesql;}catchClassNotFoundEx__ptione{e.printStackTra__;}catchSQLEx__ptione{e.printStackTra__;}returnflag;}publicbooleanupdateBookByIdStringbkidStringbknameStringwriterStringbkinintid{booleanflag=false;//将数据存放到db中去try{//加载驱动Class.forName;//建立连接Connectionconn=Driver__nager.getConnectionjdbc:mysql://localhost:3306/wbroot123456;//准备语句Stringsql=updatebooksetbkname=+bkname+bkid=+bkid+bkin=+bkin+writer=+writer+whereid=+id;//准备对象Statementst=conn.createStatement;//执行flag=!st.executesql;}catchClassNotFoundEx__ptione{e.printStackTra__;}catchSQLEx__ptione{e.printStackTra__;}returnflag;}}___登陆欢迎界面选择普通用户或___登陆选择___的功能按键普通用户欢迎界面对普通用户进行增、删、查、改查看自己的信息以及修改__返回登陆界面返回登陆界面。