BBS网上论坛 毕业论文.doc

上传人:小小飞 文档编号:3901486 上传时间:2019-10-09 格式:DOC 页数:37 大小:1.54MB
返回 下载 相关 举报
BBS网上论坛 毕业论文.doc_第1页
第1页 / 共37页
BBS网上论坛 毕业论文.doc_第2页
第2页 / 共37页
BBS网上论坛 毕业论文.doc_第3页
第3页 / 共37页
BBS网上论坛 毕业论文.doc_第4页
第4页 / 共37页
BBS网上论坛 毕业论文.doc_第5页
第5页 / 共37页
点击查看更多>>
资源描述

《BBS网上论坛 毕业论文.doc》由会员分享,可在线阅读,更多相关《BBS网上论坛 毕业论文.doc(37页珍藏版)》请在三一文库上搜索。

1、BBS网上论坛毕业论文摘 要当今社会是一个信息飞速发达的社会,人们通过互联网络可以进行信息的交流。论坛就是一种在Internet网上开放的信息服务系统,通过论坛用户可以方便的实现信息的交换和文件的共享。本文研究并实现了基于B/S模式的BBS论坛系统,该系统采用目前流行的JSP+JavaBean和后台数据库技术。本文从BBS系统的开发背景、相关技术、需求分析、详细设计、系统测试与维护等方面详细阐述了整个系统的开发过程。关键词: BBS 、JSP、MYSQL、JavaBeans AbstractNowadays is a flourishing society that information t

2、ravels fast, Through the Internet people can exchange information with each other. The forum is a service system that is open on Internet, through which, the forum customer can conveniently realizes the commutation of the information and the share of the documents. This text research and realizes on

3、line forum system (BBS) which based on the B/S model, The system used the popular Three-tier Model (JSP+JavaBean+Database).The text detailed description of the whole system development, which described from the background of system, related technologies, demand analysis, detailed design, system test

4、ing and maintenance. Keywords: BBS、JSP、MYSQL、JavaBeans 目录第一章 前言11.1 选题背景和意义11.2 系统要解决的问题1第二章 相关技术及运行环境简介22.1 JSP技术简介22.2 JAVABEAN简介22.3 JDBC技术简介32.4 TOMCAT简介4第三章 需求分析53.1 用户功能需求53.1.1游客的各项功能:53.1.2用户的各项功能:53.1.3管理员的各项功能:63.1.4超级管理员的各项功能:63.1.5版主的各项功能:63.2 数据需求6第四章 系统整体设计74.1 系统模块结构设计74.1.1 管理员管理:94.

5、1.2 版主管理:94.2 数据库设计94.2.2 数据表设计94.3系统流程图12第五章 详细设计145.1 用户登录模块145.2 用户注册模块设计165.3 帖子主题模块设计185.4 浏览帖子模块设计215.5 发表帖子模块设计225.6 其他模块设计245.6.1查询用户模块245.6.2后台管理:265.6.4板块的进行添加或修改:29第六章 系统运行和测试316.1 测试运行情况316.2 程序有待改进方面32结论33致谢34参考文献35III 第一章 前言1.1 选题背景和意义在二十一世纪,地球因为互联网的存在,早已变成一个村落。人们在互联网世界里尽情的遨游,享受着Intern

6、et带来的无限乐趣。我们习惯了上网看新闻、去论坛看帖、网上购物、撰写自己的网络日志等等。当然,最离不开的,还是各种搜索引擎,帮我们找到想要的信息。总之,互联网已经成为我们的一种生活方式,一个巨大的知识库。本篇设计论文,围绕如何构建网上论坛系统展开研究。网上论坛系统(BBS)是各种信息交流和传布的场所,它不同于电视报纸等传统的媒体,任何人都可以随便的在BBS上发表自己的言论,不受任何限制。除了可以发表文字信息外可以上传和转贴图片、音乐、Flash,可以选择字号、颜色,还可以选择有趣的表情图案。只要花几分种注册(甚至不需要)你就能畅游BBS,从中得到无穷的乐趣。本系统就是基于以上功能的一个BBS,

7、旨在为广大网民提供了一个交流平台,能够在这里畅所欲言,发表自己的看法、观点,同时能够结交朋友为生活增添乐趣。1.2 系统要解决的问题 本系统要解决网上论坛(BBS)管理的基本功能:用户注册、用户登录、发表文章、阅读文章、回复文章、分页查找、作者查找、个人资料修改。版主可以添加版块,修改版块,查看版主信息,修改版主信息。管理员可以对帖子进行管理,修改管理员自己的信息。超级管理员可以添加新的管理员以及删除管理员,修改管理员资料,以及对帖子的管理,超级管理员还可以添加版主。在设计过程中要解决了JSP最常见的中文乱码问题,并针对不同平台总结出了处理乱码的方法,为今后系统的移植做了铺垫。在数据库连接方面

8、采用数据库连接池技术,数据库连接池负责分配、管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而再不是重新建立一个。第二章 相关技术及运行环境简介2.1 JSP技术简介JSP是服务器端的脚本语言,是以SERVLET为基础开发而成的动态网页生成技术,它的底层实现是JAVA SERVLET。JSP(JAVA SERVER PAGES)由HTML代码和潜入其中的JAVA代码所组成。服务器在页面被客户端请求以后对这些代码进行处理,然后将生产的HTML页面返回客户端的浏览器。按照脚本语言是服务于某一个子系统的语言这种论述,JSP应当被看作是一种脚本语言。然而,作为一种脚本语言,JSP又显

9、得过于强大了,在JSP中几乎可以使用全部的Java类。JSP的特点是面向对象、 跨平台、 和SERVLET一样稳定、 可以使用SERVLET提供的API,同时克服了SERVLET的缺点。在使用JSP时一般和JAVABEANS结合使用,从而将界面表现和业务逻辑分离。分开内容和显示逻辑的好处是,更新页面外观的人员不必懂得Java 代码,而更新JavaBean类的人员也不必是设计网页的行家里手,就可以用带JavaBeans 类的JSP 页面来定义Web 模板,以建立一个由具有相似的外观的页面组成的网站。JavaBeans 类完成数据提供,这样在模板中就没有Java 代码,这意味着这些模板可以由一个H

10、TML 编写人员来维护。当然,也可以利用Java Servlet来控制网站的逻辑,通过Java Servlet调用JSP文件的方式来将网站的逻辑和内容分离。2.2 JAVABEAN简介JAVABEAN是基于JAVA的组建模型,有点类似于MICROSOFT的COM组建。JavaBean 就是JAVA的可重用组件技术。ASP通过COM来扩充复杂的功能,如文件上载、发送email以及将业务处理或复杂计算分离出来成为独立可重复利用的模块。JSP通过JavaBean实现了同样的功能扩充。JSP 对于在Web 应用中集成JavaBean 组件提供了完善的支持。这种支持不仅能缩短开发时间(可以直接利用经测试

11、和可信任的已有组件,避免了重复开发),也为JSP 应用带来了更多的可伸缩性。JavaBean 组件可以用来执行复杂的计算任务,或负责与数据库的交互以及数据提取等。在JAVA平台中,可以无限扩充JAVA程序的功能,通过JAVABEAN的组合可以快速生产新的应用程序。JAVABEAN 通过JAVA虚拟机(JAVA VIRTUAL MACHINE)执行,运行JAVABEAN最小的需求是JDK1.1或者以上的版本。对于程序员来说,最好的一点就是JAVABEAN可以实现代码的重复利用,另外对于程序的易维护性等等也有很重大的意义。在实际的JSP开发过程中,读者将会发现,和传统的ASP或PHP页面相比,JS

12、P页面将会是非常简洁的,由于JavaBeans开发起来简单,又可以利用Java语言的强大功能,许多动态页面处理过程实际上被封装到了JavaBeans中。JAVABEAN传统的应用在于可视化的领域,如AWT下的应用。自从JSP诞生后,JAVABEAN更多的应用在了非可视化领域,在服务器端应用方面表现出了越来越强的生命力。2.3 JDBC技术简介JDBC是一组API,定义了用来访问数据库源的标准JAVA类库,使用这种类库可以使用一种标准的方法、方便地访问数据库资源。JDBC是用于执行SQL语句的Java应用程序接口,由一组用Java语言编写的类与接口组成,在JSP中将使用JDBC来访问数据库。JD

13、BC是一种规范,它让各数据库厂商为Java程序员提供标准的数据库访问类和接口,这样就使得独立于DBMS的Java应用程序的开发工具和产品成为可能。JDBC的目标是使应用程序开发人员使用JDBC可以连接任何提供了JDBC驱动程序的数据库系统,这样就使得程序员无须对特定的数据库的特点有过多的了解,从而大大简化了和加快了开发过程。一般的Java开发工具都带有JDBC - ODBC桥驱动程序,这样,只要是能够使用ODBC访问的数据库系统,也就能够使用JDBC访问了。有趣的是,不同于ODBC是Open Database Connectivity的简称,JDBC并不是Java Database Conne

14、civity的简称,而是SUN的注册商标,至少官方说法是这样的。JDBC API 为访问不同的数据库提供了一种统一途径,像ODBC一样,JDBC为开发者屏蔽了一些细节问题。另外,JDBC对数据库的访问也具有平台无关性。2.4 TOMCAT简介在已JAVA技术为的WEB开发领域中,TAMCAT是许多JAVA程序员相当喜爱的开放源代码产品,它附属在APACHE SOFTWARE FOUNDATION 所主导的JAKART项目内。由于TAMCT是SERVLET与JSP技术的参考实现(REFERNCE IMPLEMENTATION),所以它不但可以当作独立的WEB服务器,也可以结合其它的WEB服务器,

15、只担任SERVLET容器或JSP容器的角色。第三章 需求分析软件的需求分析必须要有对原业务的一个深入了解、提取、抽象、升华的过程,管理软件需求分析尤其如此。软件的需求分析是从用户的业务中提取出软件系统能够帮助用户解决的业务问题,通过对用户业务问题的分析,规划出我们的软件产品。这个步骤是对用户业务需求的一个升华,是一个把用户业务管理流程优化,转化为软件产品,从而提升管理而实现的质的飞跃,这一步是否成功,直接关系到开发出来的软件产品能否得到用户认可,顺利交付给客户,客户能否真正运用我们的产品帮助他解决业务或管理问题。3.1 用户功能需求为了系统的各模块功能够正常使用、系统更加人性化,还为了满足系统

16、的实用性及安全性,本系统包含5个角色:游客,用户,管理员、超级管理员、版主。3.1.1游客的各项功能: 游客可以浏览本论坛,但是不可以发帖,不可以回帖,也不可以看帖,只有注册了以后成为本论坛的用户,才可以执行用户的功能。3.1.2用户的各项功能:一旦成为本论坛的用户后享有以下功能:1、用户注册2、用户登录3、发表文章4、阅读文章5、回复文章6、作者查找7、个人资料修改3.1.3管理员的各项功能:1、修改管理员自己的信息2、对帖子进行管理3、进入前台以及退出后台3.1.4超级管理员的各项功能:超级管理员可以添加新的管理员以及删除管理员,修改管理员资料,以及对帖子的管理,超级管理员还可以添加版主。

17、3.1.5版主的各项功能:版主可以具有的功能如下:1、添加版块2、修改版块3、查看版主信息4、修改版主信息3.2 数据需求用户必须先注册后再登录进入系统,系统用户的数据包括用户名、用户密码、用户类型。用户名在整个系统中是唯一的。用户浏览帖子时,数据应当包括用户名、帖子序号。用户根据某一主题可以发表帖子,发表帖子需要的数据包括用户名、版块编号、版块分类名、发表帖子标题、发表帖子内容、发表帖子类型。用户回复帖子的数据包括用户名、回复帖子序号、回复的内容、版块编号、版块分类名。管理员进入后台管理时,需要数据包括管理员ID、管理员密码、管理员的类型。管理员根据权限的不同分为普通管理员和超级管理员。版主

18、进去后台管理时,需要的数据包括版主名、版主密码、子版块名、版块编号。第四章 系统整体设计4.1 系统模块结构设计 BBS论坛系统(前台)的主要功能模块及其关系,如图4-1所示:图4-1 BBS论坛系统前台主要功能模块根据BBS论坛系统前台的模块图可以得到系统的具体功能: 用户登录管理功能:新用户注册成功之后,在登录界面输入正确用户名、密码和验证码之后便可以进入本系统。 用户注册管理功能:游客可以浏览论坛的主题话题但是不可以发表话题和回复帖子,只有当游客在本论坛注册成为论坛的用户后,才能进行相关操作。 用户信息资料管理功能:在用户登录成功之后,可以修改用户自己的信息,进一步完善用户资料和修改注册

19、时用户填写的资料。 主题帖子管理功能:为了方便信息交流,用户可以发表话题,更可以根据帖子主题浏览帖子内容和回复帖子。 查询管理功能:用户可以按作者id方便用户快速的找到自己想要的信息。根据BBS系统功能分析和论坛管理的特点,需要设计BBS论坛的后台管理系,其主要功能模块如图4-2所示。图 4-2 BBS论坛系统后台功能模块根据BBS论坛系统后台的模块图可以得到系统的具体功能:4.1.1 管理员管理: 管理员信息管理功能:管理员输入正确用户名、密码之后便可以进入到后台管理系统。管理员可以查看自己的信息,可以添加管理员,可以修改管理员的资料,还可以删除管理员。 主题帖子管理功能:管理员可以对用户发

20、表的帖子进行管理,管理员可以按主题帖子序号,主题名,发表的话题进行看帖,修改帖子和删除帖子等操作。 版主管理功能:管理员可以根据版块具体要求的不同,添加这一版块的版主负责管理此版块。来分担管理员的管理论坛的工作,可以更好的为广大用户服务。4.1.2 版主管理: 版块管理功能:只有版主输入正确用户名、密码之后便可以进入到版主后台管理。版主根据版块的分类,可以添加其版块下的子分类,或者修改原有版块下子分类的名称,子分类的描述介绍。 版主信息管理功能:可以查看版主自己的信息,可以修改版主的信息资料。4.2 数据库设计该系统采用MySQL作为后台数据库去存储所有与系统相关的数据。这些数据表包括用户表(

21、userinfo)、主题帖子表(topicinfo)、回复帖子表(replyinfo)、版块表(foruminfo)以及管理员表(admininfo)。数据模型的最终目的就是规划能够有效地处理事务,并且保持应用开发的简洁性的关系数据库,并在数据库的规范化、性能优化以及数据的简洁性之间达到平衡。4.2.2 数据表设计在这个数据库管理系统中要建立5张数据表,包括用户表(userinfo)、主题帖子表(topicinfo)、回复帖子表(replyinfo)、版块表(foruminfo)以及管理员表(admininfo)。这5张数据表的各个字段意义如下所示。 字段名数据类型字段大小说明idint11回

22、复编号(主键)topicidint11主题号(外键)replyuseridvarchar20回复者(外键)replytimedatetime0回复时间replycontentvarchar300回复内容表4-1 回复帖子表字段名数据类型字段大小说明topicidint11主题编号(主键)topictitlevarchar60标题topicuseridvarchar20发帖人(外键)topiccontentvarchar300发帖内容topictimedatetime0发帖时间replynumint10回复数forumidint10版块号(外键)groupidint2主题类型表4-2 主题帖子表

23、字段名数据类型字段大小说明midint10版块编号(主键)namevarchar80版块名isparentint2版块是否分类sortidint3子版块号adminauthorvarchar60版主totaltopicint10主题数totalpostint11文章数descriptionvarchar160版块描述表4-3 版块表字段名数据类型字段大小说明admnamevarchar20管理员ID(主键)admpwdvarchar20密码admemailvarchar50邮箱admstatevarchar50自述admtimedatetime0注册时间admsayvarchar150留言ad

24、mrightint10权限表4-4 管理员信息表字段名数据类型字段大小说明useridvarchar20用户名(主键)userpwdvarchar20密码usernamevarchar30昵称useremailvarchar50邮箱userlevelint20级别usersayvarchar150留言userstatevarchar20自述rightint10权限表4-5 用户信息表图 4-9 主要功能流程图4.3系统流程图各模块功能解释如下:用户登录模块:新用户注册成功之后,在登录界面输入注册时填写的正确用户名、密码之后,再输入出现的验证码之后便可以进入本系统。如果用户名和密码正确,但是输入

25、的验证码错误,则不允许进入本系统,跳转到登录界面重新输入。 用户注册模块:建立账号,如果游客以前没有建立账号,则只可以浏览论坛的主题话题但是不可以发表新话题和回复有关帖子,只有当游客在本论坛注册成为论坛的用户后,才能进行相关操作。同时在用户创建新账号的时候,必须输入用户名(系统会在提交时检查该用户名是否已存在) 。用户在建立新账号之后就可以具有合法登录系统的身份,可以进行相关的操作。用户信息资料管理模块:在用户登录成功之后,可以修改用户自己的信息,进一步完善用户自己的资料和修改注册时用户填写的资料。主题帖子模块:为了方便信息交流,首先帖子主题类型分为精华主题(红色)和普通主题(黑色),用户可以

26、根据需要游览自己感兴趣的帖子,获得所需信息。用户可以发表话题,还可以根据帖子主题浏览帖子内容和回复帖子。查询模块:用户只要输入想查询的用户ID,点击查询按钮,便可以查询出该用户发表的所有帖子以及该用户发表的帖子序号、标题、发帖的时间、发帖人等详细信息,方便用户快速的找到自己想要的信息。管理员信息管理模块:管理员输入正确用户名、密码之后便可以进入到后台管理系统。管理员可以查看自己的信息,可以添加管理员,可以修改管理员的资料,还可以删除管理员。主题帖子管理模块:管理员可以对用户发表的帖子进行管理,管理员可以按主题帖子序号,主题名,发表的话题进行看帖,修改帖子和删除帖子等操作。 版主管理模块:管理员

27、可以根据版块具体要求的不同,添加这一版块的版主负责管理此版块,来分担管理员的管理论坛的工作,可以更好的为广大用户服务。版主还可以修改自己的资料,添加本版块的子版块。第五章 详细设计5.1 用户登录模块当游客注册成为本BBS论坛系统的用户后,便跳转到系统登录界面,在系统登录界面(图5-1所示)输入正确用户名、密码和验证码之后便可以进入本系统。图5-1用户登录界面验证用户登陆的代码如下:private String userid,userpwd;public Connection con=null;public Statement stmt=null;public ResultSet rs=nul

28、l;public String getUserid() return userid;public void setUserid(String userid) this.userid = userid;public String getUserpwd() return userpwd;public void setUserpwd(String userpwd) this.userpwd = userpwd;public void close()tryif(rs!=null)rs.close();if(stmt!=null)stmt.close();if(con!=null)con.close()

29、;catch(Exception e)e.printStackTrace();public boolean checkUser(String id,String p)boolean b=false;try con=new ConnDb().getConn();stmt=con.createStatement();String sql=select * from userinfo where userid=+id+ and userpwd=+p+; System.out.println(sql);rs=stmt.executeQuery(sql);if(rs.next() b=true; Sys

30、tem.out.println(登录:+b); catch (Exception e) e.printStackTrace();finallythis.close();Return b;return b;5.2 用户注册模块设计游客如果要在本BBS论坛系统发表帖子和回复帖子,游客必须在本论坛注册成为论坛的用户后,才能进行相关操作。系统注册界面(图5-2所示);图 5-2 用户注册界面验证用户注册是否成功代码如下:public class Register private String userID;private String userName;private String userPwd;p

31、rivate String userEmail;private int userLevel=0;private String userSay;public Register()public String getUserID() return userID;public void setUserID(String userID) this.userID = userID;public String getUserName() return userName;public void setUserName(String userName) this.userName = userName;publ

32、ic String getUserPwd() return userPwd;public void setUserPwd(String userPwd) this.userPwd = userPwd;public String getUserEmail() return userEmail;public void setUserEmail(String userEmail) this.userEmail = userEmail;public String getUserSay() return userSay;public void setUserSay(String userSay) thi

33、s.userSay = userSay;public int userRegister()tryClass.forName(com.mysql.jdbc.Driver).newInstance(); String url =jdbc:mysql:/localhost/hello2?user=root&password=123; Connection con=null; Statement stmt=null; ResultSet rs=null; con=DriverManager.getConnection(url); stmt=con.createStatement(); rs=stmt.

34、executeQuery(select * from userinfo where userid=+userID+); int i=0; while(rs.next() i+; System.out.println(String.valueOf(i); if(i0) return -1; String insert=insert into userinfo values(+userID+,+userPwd+,+userName+,+userEmail+,+userLevel+,+userSay+,0,0); stmt.executeUpdate(insert); return 0;catch

35、(Exception e) System.out.println(e);return -2;5.3 帖子主题模块设计帖子主题界面(图5-3所示),帖子主题类型分为精华主题(红色)和普通主题(黑色),用户可以根据需要游览自己感兴趣的帖子,获得所需信息。用户可以发表话题,还可以根据帖子主题浏览帖子内容和回复帖子,以及根据用户ID查询主题帖子。图 5-3 帖子主题界面帖子精华主题代码如下: %while(rs.next()out.print();String topicid=rs.getString(topicid);% a href=kantie.jsp?userid=&topicid= img

36、src=images/topichot.gif a href=kantie.jsp?userid=&topicid= A class=a2 href=kantie.jsp?userid=&topicid= By:   a href=kantie.jsp?userid=&topicid= 看帖 a href=kantie.jsp?userid=&topicid= img src=images/topichot.gif a href=kantie.jsp?userid=&topicid= 无 By:无 a href=kantie.jsp?userid=&topicid= 看帖 alert(

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 其他


经营许可证编号:宁ICP备18001539号-1