百度搜索引擎下的百度知道系统的设计毕业论文.doc-天下标王

百度搜索引擎下的百度知道系统的设计毕业论文.doc 37页

  • 内容提供方:2017meng
  • 大小397 KB
  • 字数约1.66万字
  • 发布时间2018-08-09发布于贵州
  • 浏览人气3
  • 下载次数仅上传者可见
  • 收藏次数0
  • 需要金币*** 金币 (10金币=人民币1元)

百度搜索引擎下的百度知道系统的设计毕业论文.doc

  • 关闭预览
百度搜索引擎下的百度知道系统的设计毕业论文.doc

想预览更多内容,点击免费在线预览全文

免费在线预览全文
百度搜索引擎下的百度知道系统的设计毕业论文
共5 页 第 PAGE V页 摘 要 本论文主要阐述“百度搜索引擎”下的“百度知道”系统的设计思想和实现的关键技术。论文针对互联网使用人员共享知识解决提问的需求,采用面向对象设计的方法和JSP,Struts等技术,分析、设计并实现了百度知道系统。 该系统具有用户登录、注册,发布、回答、查询以及处理问题等功能,测试表明该系统达到了预期的要求。 论文包括以下几个部分: 第一部分系统分析,通过对用户需求的分析,说明了************* ******** ******** ***********。 第二部分概要设计, 设计了********,************* ******** ******** ***********。 第三部分详细设计,设计了************* ******** ******** ***********。 第四部分系统实现,通过******完成了******系统的***模块。达到************。 关键字:JSP Struts 搜索引擎 Abstract The thesis is design of System that about Baidu Know System of Baidu Search-engine. On the other hand, it expounds the part of design of model and key technology of implementation. With the requirement of the person who uses Internet to share knowledge and to resolve problems,it adopts OOP(Object Oriented Programming) and JSP, Struts technology to analyze, design and implements this system. The system includes the functions that register and question, answer, select and handle the question of user. The test of whole system shows that it has come up the expectation. The thesis mainly includes the following parts: 1. Source of the Problem. 2. Requirement and Analysis. 3. System Design. 4. Detailed Design. 5. System Implementation. The system is WEB development application and is based on B/S model. So that I chose the popular WEB development technology which is based on MVC development model, that is JavaBean、JSP、Servlet and I also used Struts Framework for this application. The development tools are mainly included Dreamweaver 8,Eclipse3.2、MyEclipse5.1. JUDE is my UML tool. The database for server is SQL server 2000. The development of application includes three part: the databases of design、the design of web pages and the coding work. All coding of pages mainly used the JSP and Struts tags. For coding part is completely base on struts framework. Key words: JSP Struts Search engine 目录 TOC \o 1-3 \h \z \u HYPERLINK \l _Toc 第一章 系统分析 PAGEREF _Toc \h 1 HYPERLINK \l _Toc 1.1 问题来源 PAGEREF _Toc \h 1 HYPERLINK \l _Toc 1.2 选题背景 PAGEREF _Toc \h 2 HYPERLINK \l _Toc 1.2.1问题定义 PAGEREF _Toc \h 2 HYPERLINK \l _Toc 1.2.2选题意义 PAGEREF _Toc \h 2 HYPERLINK \l _Toc 1.3系统功能分析 PAGEREF _Toc \h 3 HYPERLINK \l _Toc 1.4数据流图 PAGEREF _Toc \h 4 HYPERLINK \l _Toc 第二章 基础理论知识 PAGEREF _Toc \h 6 HYPERLINK \l _Toc 2.1 MVC模式概述 PAGEREF _Toc \h 6 HYPERLINK \l _Toc 2.2 MVC如何工作 PAGEREF _Toc \h 7 HYPERLINK \l _Toc 2.3 Struts概述 PAGEREF _Toc \h 8 HYPERLINK \l _Toc 第三章 概要设计 PAGEREF _Toc \h 9 HYPERLINK \l _Toc 3.1 系统概述 PAGEREF _Toc \h 9 HYPERLINK \l _Toc 3.2 功能分析 PAGEREF _Toc \h 9 HYPERLINK \l _Toc 3.3 数据库分析 PAGEREF _Toc \h 11 HYPERLINK \l _Toc 3.3.1实体的分析 PAGEREF _Toc \h 11 HYPERLINK \l _Toc 3.3.2实体的属性 PAGEREF _Toc \h 11 HYPERLINK \l _Toc 3.3.3实体之间的联系 PAGEREF _Toc \h 12 HYPERLINK \l _Toc 3.4 数据库的概念设计 PAGEREF _Toc \h 13 HYPERLINK \l _Toc 3.5 数据库的逻辑结构设计 PAGEREF _Toc \h 14 HYPERLINK \l _Toc 3.6数据库的物理设计 PAGEREF _Toc \h 16 HYPERLINK \l _Toc 第四章 详细设计 PAGEREF _Toc \h 18 HYPERLINK \l _Toc 4.1 数据库连接模块的创建 PAGEREF _Toc \h 19 HYPERLINK \l _Toc 4.2 用户模块的详细设计 PAGEREF _Toc \h 20 HYPERLINK \l _Toc 4.3 问题模块的详细设计 PAGEREF _Toc \h 21 HYPERLINK \l _Toc 4.3.1百度知道的主要功能设计 PAGEREF _Toc \h 21 HYPERLINK \l _Toc 4.3.2百度知道的页面及主要核心算法设计 PAGEREF _Toc \h 22 HYPERLINK \l _Toc 4.4 开发工具及环境 PAGEREF _Toc \h 24 HYPERLINK \l _Toc 第五章 系统实现 PAGEREF _Toc \h 26 HYPERLINK \l _Toc 5.1 用户模块的实现 PAGEREF _Toc \h 26 HYPERLINK \l _Toc 5.2 问题模块的实现 PAGEREF _Toc \h 27 HYPERLINK \l _Toc 结束语 PAGEREF _Toc \h 30 HYPERLINK \l _Toc 参考文献 PAGEREF _Toc \h 31 共31 页 第 PAGE 31页 第一章 系统分析 1.1 问题来源 百度,2000年1月创立于北京中关村,是全球最大的中文网站 、最大的中文搜索引擎。百度每天响应来自138个国家超过数亿次的搜索请求。用户可以通过百度主页,在瞬间找到相关的搜索结果,这些结果来自于百度超过十数亿的中文网页数据库。同时,用户不必访问百度主页,也可以搜索信息。超过20万个搜索联盟会员,通过各种方式将百度搜索结合到自己的网站,使用户在上网的任何时候都能进行百度搜索。百度还提供WAP与PDA搜索服务,即使身边没有PC机,用户也可以通过手机或掌上电脑等无线平台进行百度搜索。 百度知道()是一个基于搜索的互动式知识问答分享平台,于2005年6月21日发布,并于2005年11月8日转为正式版。 和大家习惯使用的搜索服务有所不同,“百度知道”并非是直接查询那些已经存在于互联网上的内容,而是用户自己根据具体需求有针对性地提出问题,通过积分奖励机制发动其他用户,来创造该问题的答案。 同时,这些问题的答案又会进一步作为搜索结果,提供给其他有类似疑问的用户,达到分享知识的效果。百度知道的最大特点,就在于和搜索引擎的完美结合,让用户所拥有的隐性知识转化成显性知识,用户既是百度知道内容的使用者,同时又是百度知道的创造者,在这里累积的知识数据可以反映到搜索结果中。通过用户和搜索引擎的相互作用,实现搜索引擎的社区化。百度知道可以说是对过分依靠技术的搜索引擎的一种人性化完善。 1.2 选题背景 1.2.1问题定义 之所以搜索引擎这么火,大家这么依赖,是因为技术的进步,搜索引擎技术的进步非常的快。技术进步快,实际上是需求在推动。搜索最近两年来变得这么火,实际上是需求在推动搜索技术和产业推动。宽带越来越普及,上网越来越容易,上网的人越来越多,信息量越来越大。现在已经是非常繁荣的大路,这里面的内容很多很多,搜索一下初中的初恋情人,可能也会查找他的名字。 “用户提出任何一个问题,很快就会有人帮助回答,通过投票选出的最佳答案,往往又作为搜索结果被分享到更多用户”,这一简单、便捷的模式受到了网民的热烈欢迎,同时也改变着网民的日常生活习惯。网友表示,“生活上一遇到解决不了的问题,我第一个想到的就是上百度知道”,目前,百度知道每天解决超过5万个问题,也就意味着,通过用户的互动参与,两天时间即可编辑完成一本《十万个为什么》。 1.2.2选题意义 众所周知,百度知道已经是一套开发过并且比较成熟完善的正在互联网上广泛使用的系统了,而之所以我选择这个系统作为我的毕业设计主要是因为现实中的该系统是由PHP语言开发的,而在大学期间的所学使我对于Java,JSP语言有了浓厚兴趣,一方面可以利用自己所学的知识实现一套正规的系统,更加锻炼自己和提高自己的技术水平,另外实用JSP语言版本开发与真实的系统实现方式不同也大大的增加我开发的兴趣。所以我选择百度知道这个系统作为我的毕业设计。 1.3系统功能分析 要开发一个应用系统,首先要了解用户对整个系统的具体要求,确定系统应该实现的功能和系统应该具有的性能;设计应用软件时所使用的设计平台,所开发的应用软件的运行环境;通过调查分析去了解系统的业务流程,确定数据库设计中需要的数据结构;还要分析系统中的数据流和长期使用的数据存储等等,这些都是需求分析中应该完成的任务。本章采用软件工程的方法对“百度知道”模块进行了需求分析。 “百度知道”是一个基于搜索的互动式知识问答分享平台。它实现登录用户在线提问回答并解决问题共享知识的过程。该平台的维护为自动维护,由定义规则进行数据的维护,默认不设网站管理员角色。 1.用户角色: 普通用户(只有查询权限,无需登录)、信息发布用户(提问和回答问题的用户) 2.功能模块划分: (1)问题信息查询(普通用户) 1)按照问题的栏目进行问题信息查询 2)按照问题的标题内容进行问题信息的查询 3)按照问题的状态(解决,待解决)来进行问题信息的查询 4)查询全部信息 (2)问题信息的管理(注册用户) 1)提出问题 2)对自己提出的提问进行信息处理 3)回答待解决的问题 4)问题信息查询 每一个模块的功能详见总体设计。 1.4数据流图 根据该系统问题的需求进行分析,使用数据流图示描述数据处理过程。数据流图从数据传递和加工的角度,以图形的方式刻画数据流从输入到输出的传输变换过程。数据流图是结构化系统分析的主要工具,它表示了系统内部信息的流向,并表现系统的逻辑处理功能。 结果信息用户信息注册请求游客 结果信息 用户信息 注册请求 游客 用户 1 接收请求 用户表 D1 游客 用户 查询信息问题 信息登录请求回答 查询信息 问题 信息 登录 请求 回答 显示主页 修改信息 注册 用户 问题表 D2 提问 显示问题 问题列表 回答 问题 注册 用户 问题表 D2 回答表 D3 注册 用户 结果 结果 修改信息 问题编号 提问请求 图1-2 问题模块的数据流图 回答表 D3 显示问题列表 指定 问题 回答列表 结 果 结果 名字:问题列表别名:描述:问题列表=所有问题的分类统计列表,待解决10个,已解决和最佳问题各5个定义:待解决问题+以解决问题+最佳问题位置:百度知道首页 名字:问题列表 别名: 描述:问题列表=所有问题的分类统计列表,待解决10个,已解决和最佳问题各5个 定义:待解决问题+以解决问题+最佳问题 位置:百度知道首页 名字:回答列表 别名: 描述:针对某一问题的所有回答 定义:回答列表=回答编号+回答内容+回答者编号+问题编号+回答状态 位置:问题页面 名字:问题编号 别名:问题ID 描述:唯一标识问题的字段 定义:问题编号={数字} 位置:问题表 数据流图中的一些专业词汇在数据字典中解释如下: (请注意:数据字典是解释前面的数据流图中出现的容易产生歧义的词,没有数据流图只出现数据字典是毫无意义的。在数据流图中没有的词出现在数据字典中也是毫无意义的。) 第二章 基础理论知识 百度知道系统的设计采用了JSP,Struts框架来实现,因此从采用了MVC结构模式进行开发。整个开发的过程也是完全按照Struts框架结构进行的。下面了解一下MVC开发模式和Struts框架技术。 2.1 MVC模式概述 MVC本来是存在于Desktop程序中的,M是指数据模型,V是指用户界面,C则是控制器。使用MVC的目的是将M和V的实现代码分离,从而使同一个程序可以使用不同的表现形式。比如一批统计数据你可以分别用柱状图、饼图来表示。C存在的目的则是确保M和V的同步,一旦M改变,V应该同步更新。 模型-视图-控制器(MVC)是Xerox PARC在八十年代为编程语言Smalltalk-80发明的一种软件设计模式,至今已被广泛使用。最近几年被推荐为Sun公司J2EE平台的设计模式,并且受到越来越多的使用 ColdFusion 和 PHP 的开发者的欢迎。模型-视图-控制器模式是一个有用的工具箱,它有很多好处,但也有一些缺点。 MVC模式是“Model-View-Controller”的缩写,中文翻译为“模式-视图-控制器”。MVC应用程序总是由这三个部分组成。Event(事件)导致Controller改变Model或View,或者同时改变两者。只要Controller改变了Models的数据或者属性,所有依赖的View都会自动更新。类似的,只要Controller改变了View,View会从潜在的Model中获取数据来刷新自己。MVC模式最早是Smalltalk语言研究团提出的,应用于用户交互应用程序中。Smalltalk语言和java语言有很多相似性,都是面向对象语言,很自然的SUN在potstone(宠物店)事例应用程序中就推荐MVC模式作为开发Web应用的架构模式。MVC模式是一种架构模式,其实需要其他模式协作完成。在J2EE模式目录中,通常采用service to worker模式实现,而service to worker模式可由集中控制器模式,派遣器模式和Page Helper模式组成。 2.2 MVC如何工作 MVC是一个设计模式,它强制性的使应用程序的输入、处理和输出分开。使用MVC应用程序被分成三个核心部件:模型、视图、控制器。它们各自处理自己的任务。 1.视图 视图是用户看到并与之交互的界面。对老式的Web应用程序来说,视图就是由HTML元素组成的界面,在新式的Web应用程序中,HTML依旧在视图中扮演着重要的角色,但一些新的技术已层出不穷,它们包括Macromedia Flash和类XHTML,XML/XSL,WML等一些标识语言和Web services。 2.模型 模型表示企业数据和业务规则。在MVC的三个部件中,模型拥有最多的处理任务。例如它可能用像EJBs和ColdFusion Components这样的构件对象来处理数据库。被模型返回的数据是中立的,就是说模型与数据格式无关,这样一个模型能为多个视图提供数据。由于应用于模型的代码只需写一次就可以被多个视图重用,所以减少了代码的重复性。 3.控制器 控制器接受用户的输入并调用模型和视图去完成用户的需求。所以当单击Web页面中的超链接和发送HTML表单时,控制器本身不输出任何东西和做任何处理。它只是接收请求并决定调用哪个模型构件去处理请求,然后用确定用哪个视图来显示模型处理返回的数据。 现在我们总结MVC的处理过程,首先控制器接收用户的请求,并决定应该调用哪个模型来进行处理,然后模型用业务逻辑来处理用户的请求并返回数据,最后控制器用相应的视图格式化模型返回的数据,并通过表示层呈现给用户。 2.3 Struts概述 Struts最早是作为Apache Jakarta项目的组成部分问世运作。项目的创立者希望通过对该项目的研究,改进和提高Java Server Pages、Servlet、标签库以及面向对象的技术水准。 Struts这个名字来源于在建筑和旧式飞机中使用的支持金属架。它的目的是为了减少在运用MVC设计模型来开发Web应用的时间。你仍然需要学习和应用该架构,不过它将可以完成其中一些繁重的工作。 除此之外,Struts的优点主要集中体现在两个方面:Taglib和页面导航。Taglib是Struts的标记库,灵活动用,能大大提高开发效率。另外,就目前国内的JSP开发者而言,除了使用JSP自带的常用标记外,很少开发自己的标记,或许Struts是一个很好的起点。Struts 是MVC的一种实现,它将 Servlet和 JSP 标记(属于 J2EE 规范)用作实现的一部分。Struts继承了MVC的各项特性,并根据J2EE的特点,做了相应的变化与扩展。 第三章 概要设计 百度知道是一个基于搜索的互动式知识问答分享平台。和大家习惯使用的搜索服务有所不同,“百度知道”并非是直接查询那些已经存在于互联网上的内容,而是用户自己根据具体需求有针对性地提出问题,通过积分奖励机制发动其他用户,来创造该问题的答案。 同时,这些问题的答案又会进一步作为搜索结果,提供给其他有类似疑问的用户,达到分享知识的效果。 3.1 系统概述 该系统的最大特点,就在于和搜索引擎的完美结合,让用户所拥有的隐性知识转化成显性知识,用户既是本系统内容的使用者,同时又是该系统的创造者,在这里累积的知识数据可以反映到搜索结果中。通过用户和搜索引擎的相互作用,实现搜索引擎的社区化。 3.2 功能分析 下面我们着重介绍各个模块的具体功能以及设计要求。 根据需求分析,得到了本系统应该具有的功能,下面具体分析本系统的功能模块。经过分析,“百度知道”大致分为两大模块六大功能。即用户模块,用户处理问题模块。两个模块的功能分别为: 1.用户模块 用户注册。 用户登录。 2. 用户处理问题模块 问题发布。 问题查询。 回答问题。 解决问题。 百度知道系统用户模块用户操作问题模块用户登录用户注册问题发布回答问题解决问题 百度知道系统 用户模块 用户操作问题模块 用户登录 用户注册 问题发布 回答问题 解决问题 查询问题 图3-1 百度知道系统的层次图 (注意:层次图按照功能模块来划分) 系统各功能部分说明如下: 1.用户模块:主要包括对用户的注册以及登录的功能。 2.问题模块,主要包括以下几个功能的实现: 问题发布:已登录用户发布新的问题。 问题回答:其他用户对已存在问题的回答以及提问用户对自己问题的补充。 解决提问:提问用户将其他用户对于自己提出问题的某个回答设为最佳答案或者问题长时间未处理自动过期。 查询问题:注册用户登录或者游客用户访问系统时对问题的分类浏览以及对于单个问题的信息查询。 3.3 数据库分析 3.3.1实体的分析 根据百度知道的总体设计,我们定义了百度知道整个系统分为两大模块和六大功能。由此我们可以首先确定百度知道的两大实体:用户和问题,而由于用户可以根据提问来进行回答,所以问题答案也是实体。因此该系统共有三个实体。 1.用户实体。 2.问题实体。 3.问题答案实体。 3.3.2实体的属性 百度知道系统涉及到的实体分别为用户实体,问题实体,问题答案实体。根据系统需求,我们将以下实体的属性确定如下: 1.用户实体,包含所有百度知道的注册用户信息,其详细的属性如下: (1)客户编号。 (2)客户名称。 (3)客户密码。 (4)真实姓名。 (5)性别。 (6)身份证号。 (7)电子邮件。 (8)用户积分。 (9)用户权限。 2.问题实体,包含所有用户提出的问题的信息,其详细的属性如下: 问题编号。 问题标题。 问题内容。 提问者ID。 所在栏目号。 问题状态。 奖赏分数。 回答次数。 发布时间。 3.问题答案实体,包含所有问题回答的属性,其详细的属性如下: 回答编号。 问题编号。 回答标题。 回答内容。 回答状态。 回答者编号。 3.3.3实体之间的联系 通过对百度知道系统中所需实体以及属性的分析,我们已经对于百度知道的数据模型有了一定的了解,由此我们可以确定三大实体之间的联系。 1.每一位注册用户都可以提出若干问题,发布问题信息。但是每个问题只能由一个用户提出,即只能和一个用户关联。 2.每个用户都可以对某一问题发表若干回答。但是每一项回答 只能由一个用户发表,即只能和一个用户关联。 3.每个问题都会有零到多个回答,每个回答也可以发表到不同的问题上去。即多个问题有多个回答。 3.4 数据库的概念设计 通常使用实体-联系图来建立数据模型。可以把实体-联系图简称为ER图,相应的可把用ER图描绘的数据模型称为ER模型。 百度知道的实体-联系图如图3-2 百度知道的ER图所示: (注意:ER图描绘的是数据之间的关系,矩形代表实体;圆角矩形或椭圆代表属性;菱形代表实体和实体之间的关系;在实体关系的实线上要标出数字代表对应关系,1:1或1:N或M:N) 1N1用户问题回答编号真名 1 N 1 用户 问题 回答 编号 真名 密码 昵称 邮件 身份证 性别 积分 权限 提问 属于 N 编号 内容 提问者编号 时间 标题 悬赏分数 栏目号 回答数 标题 编号 时间 问题编号 状态 回答者编号 内容 问题状态 发表 N 1 3.5 数据库的逻辑结构设计 表3-1 用户表 作用 保存客户的信息 名称 User_Info 序号 英文字段名 中文字段名 数据类型 长度 是否关键字 备注 1 User_ID 用户编号 int 主键 自动编号 2 User_Name 用户名称 varchar 30 3 User_PWD 用户密码 varchar 30 4 User_RealName 真实姓名 varchar 30 5 User_Sex 性别 int 0:男 1:女 6 User_IDCard 身份证号 varchar 18 7 User_Email 电子邮件 varchar 50 8 User_Score 用户积分 int 9 User_Limit 用户权限 int 0:管理员 1:普通用户 表3-2 问题表 作用 保存客户提出的问题 名称 Question_Info 序号 英文字段名 中文字段名 数据类型 长度 是否关键字 备注 1 Ques_ID 问题编号 int 10 主键 自动编号 2 Ques_Title 问题标题 varchar 100 3 Ques_Context 问题内容 varchar 2000 4 User_ID 提问者ID int 外键 5 Item_ID 所在栏目号 int 外键 0:男 1:女 6 Ques_Status 问题状态 int 10: 最佳 1: 待解决 2: 已解决 7 Ques_Score 奖赏分数 int 8 Ques_Count 回答次数 int 9 Ques_date 发布时间 Date 表3-3 回答表 作用 保存问题答案 名称 Result_Info 序号 英文字段名 中文字段名 数据类型 长度 是否关键字 备注 1 Res_ID 回答编号 int 主键 自动编号 2 Ques_ID 问题编号 int 外键 3 Res_Title 回答标题 varchar 100 4 Res_Date 回答时间 Date 5 Res_Context 回答内容 varchar 2000 6 Res_Status 回答状态 int 1:最佳 0:普通 7 User_ID 回答者编号 int 表3-4 栏目表 作用 显示栏目 名称 Item_Info 序号 英文字段名 中文字段名 数据类型 长度 是否关键字 备注 1 Item_ID 栏目编号 int 主键 自动编号 2 Item_Name 栏目名称 varchar 200 3.6数据库的物理设计 1.创建用户表 create table User_Info(--用户表,保存客户的信息 User_ID int primary key identity(1,1),--客户编号 User_Name varchar(30),--客户名称 User_PWD varchar(30),--客户密码 User_RealName varchar(30),--真实姓名 User_Sex int,--性别 User_IDCard varchar(18),--身份证号 User_Email varchar(50),--电子邮件 User_Score int,--用户积分 User_Limit int--用户权限 ) 2.创建问题表 create table Question_Info(--问题表,保存客户提出的问题 Ques_ID int primary key identity(1,1),--问题编号 Ques_Title varchar(30),--问题标题 Ques_Context varchar(2000),--问题内容 User_ID int references User_Info,--提问者ID Item_ID int references Item_Info,--所在栏目号 Ques_Status int,--问题状态 Ques_Score int,--奖赏分数 Ques_Date datetime, --发布时间 Ques_Count int --回复数 ) 3.创建回答表 create table Result_Info(--回答表,保存问题答案 Res_ID int primary key identity(1,1),--答案编号 Ques_ID int references Question_Info,--问题编号 Res_Title varchar(200),--答案标题 Res_Context varchar(2000),--答案内容 Res_Date datetime,--答题时间 Res_Status int,--答案状态 User_ID int references User_Info--答题者编号 ) 4.创建栏目表 create table Item_Info(--栏目表,显示栏目 Item_ID int primary key identity(1,1),--栏目编号 Item_Name varchar(200),--栏目名称 Item_Type int,--栏目种类 ) 第四章 详细设计 通过系统分析和概要设计,对百度知道系统已经有了一个比较详细的了解。整个系统的设计完全依据基于Struts框架的MVC开发模式完成。其中包结构也是按照MVC模式进行分层。整体开发分五个包。分别是action,dao,form,util,model。其中Action可以看作Servlet控制层,Dao是数据库连接持久化层,form则是JavaBean与Model模式层的实体类共同构成视图层,Util是通用工具包。 (注意:类图代表各个类之间的关系,可以用现有工具画,但是一定要清晰) 图4-1 百度知道的类图 整个视图层主要是由jsp页面来完成,而为了更好的实现的百度知道的页面效果,本系统采用了Struts框架中的Tiles页面框架标签来设计页面。将主体页面拆分成上中下三部分。整个视图层主要包括一下几个jsp页面文件。 addquestion.jsp 提问页面的主体页面。 addquesstioncontent.jsp 发布问题的主题页面。 answer.jsp 回答问题框架页面。 answercontent.jsp 回答问题的主题页面。 footer.jsp Tiles框架。 header.jsp Tiles框架页面的头框架页面。 indexcontent.jsp 主页的主体页面。 layout.jsp Tiles页面框架布局设置。 login.jsp 登录页面。 main.jsp 主框架页面。 questionlist.jsp 问题列表框架页面。 questionlistcontent.jsp 问题列表主页主体页面。 register.jsp 注册页面。 result.jsp 发布问题后框架页面。 resultcontent.jsp 发布问题后主体页面。 staticJavascript.jsp 静态JavaScript加载页面。 4.1 数据库连接模块的创建 由于本系统是基于Struts结构开发而成,Struts1.1框架中集成了数据源配置和管理功能。即在Struts框架下的struts_config.xml文件中配置data-source标签来定义和配置数据源,使得启动Tomcat服务器的同时便由容器加载数据源以方便使用。当然,获得数据源之后的数据库操作的管理是用数据库连接对象DAO开发模式完成。在项目下的dao包里包含着数据库连接操作的实现。由于本模块是数据库连接以及持久化层操作模块所以不包含任何关联页面。 本模块所包含的类如下: DAO类 数据库连接对象的父类,包含操作数据库的公共方法和获取数据源的方法。 IndexDao类 继承了Dao父类,包含了主页index类显示问题列表的所有数据库查询操作方法。 UserDao类 继承了Dao父类,包含了对于用户的注册,存在判断,查询用户信息等方法。 QuestionDao类 继承了Dao父类,包含了对于问题以及问题回答等增删改查操作的方法。 4.2用户模块的详细设计 用户模块主要包括用户注册以及用户查询等功能,主要包括register.jsp,login.jsp。本模块主要包括UserDao类,UserAction类的设计以及Model包中User类的设计。而本模块主要包含的是用户注册和登录的功能。 1.用户注册的过程 用户在注册页面输入数据。 首先在页面用JavaScript对用户输入数据格式和有效性进行检查。 判断用户名是否存在。 向用户表插入用户信息。 全部正常,跳转到用户登录页面。 2.用户登录的过程 用户在登录页面输入登录信息。 在页面用JavaScript对用户输入数据格式和有效性进行检查。 在数据库中判断是否存在某一列满足用户名和密码为用户输入的数据,存在则通过。 将用户基本信息保存在session对象中。 (5)全部正常,跳转到百度知道首页。 4.3 问题模块的详细设计 问题模块是百度知道系统的核心模块,在这一模块中包含了百度知道系统的主要运行逻辑和所有的问题及搜索相关功能。主要设计的页面有主页问题列表显示页、问题发布页、问题查询页、问题回答页、问题补充及处理页面。本模块主要设计的功能也就是发布,查询,回答,处理问题的四个功能。 4.3.1百度知道的主要功能设计 百度知道系统实现的主要功能设计要点如下: 1.主页问题列表显示 问题状态1 待解决问题 10个。 问题状态2 已解决问题 5个。 问题状态10 最佳问题 5个。 2.用户发布问题 首先只有注册用户才能发布问题。 发布问题必须有标题。 发布问题必须设置问题的悬赏分数。 3.用户回答问题 (1)首先只有注册的用户才能回答问题。 (2)非注册问题只可以浏览问题。 (3)回答问题至少要有回答标题。 (4)回答问题用户必须是非提问用户。 4.用户查询问题 查询问题的用户可以是游客用户也可以是注册用户。 查询问题按照关键字进行问题检索,检索结果为问题列表。 查询问题的功能在百度知道主页实现。 5.补充及处理问题 补充和处理问题的用户必须是提问用户。 提问用户必须登录才能提问。 补充及处理问题不能超过问题未处理时限。 用户设为最佳答案以后即将奖赏分数加给最佳答案用户。 一切正常,结束问题。 4.3.2百度知道的页面及主要核心算法设计 1.answercontent.jsp问题浏览及回答页面 回答问题也就是问题浏览页面是问题模块的核心部分,也是算法集中的部分。其中在本页面有几个关键的标签属性完成了本算法的逻辑判断。 logic:equal 逻辑相等判断。 logic:empty 逻辑为空判断。 logic:notempty 逻辑不为空判断。 logic:iterate 逻辑迭代判断。 本算法主要涉及到的几个标志性对象为: FLAG1 用户是否为提问用户判断标签。 FLAG2 问题是否解决判断标签。 QUESTION 问题信息实体对象。 ANSWERLIST 回答列表。 USER 登录用户的用户信息实体对象。 pagerHeader 分页标签条,由Util包下的Pager类生成。 ANSWERSIZE 回答列表的大小,用来统计回答数。 2.问题浏览及回答页面整个算法的流程 判断FLAG2的值true则显示待解决,false则显示已解决。 QUESTION对象里取出问题标题,悬赏分,提问者并在页面上显示出来。 ANSWERLIST中取出回答列表显示答案信息。 根据ANSWERLIST中答案状态如果为1则显示最佳答案信息,并显示其他回答标签。 如果答案状态为0则将显示回答标签并且显示回答信息。 根据回答列表进行分页,显示pageHeader分页条。 判断FLAG1和FLAG2标签 如果同时为true则显示采纳为答案标签。 如果FLAG2为true且USER对象非空,则显示我也来回答标签。 每种问题处理后显示回答列表的统计数目。 3.Pager分页类算法的设计 分页算法是WEB页面设计中最常用的算法之一,Pager类中本算法的属性如下: offset 分页截取开始的位置。 size 所有数据列表的大小。 length 每页显示的数据项。 url 进行分页请求的路径。 pref 参数标志,或者?。 totalpage 总页数。 currentpage 当前页。 分页条生成的算法如下: 如果当前url存在则说明至少一个参数,需要将pref改为。 设置header的初始形式,字体,表单,表格等。 根据size和length计算总页数totalpage,如果可以整除totalpage等于size除以length,否则等于size
  • 下载文档
  • 收藏
  • 0

文档评论(0)

  • 内容提供方:2017meng
  • 审核时间:2018-08-09
  • 审核编号:6155243114001211
  • 认证类型:实名认证
  • 能力类型:内容提供者
  • 领域认证:
  • 版权证书:
  • 区块链号:

相关文档

相关内容推荐

厦门网站优化中心深圳优化网站十堰工厂网站优化哪家好郑州靠谱网站优化公司地址优化网站的步骤沧州seo网站优化怎么优化网站排名靠前荆州品牌网站优化怎么做汝州网站优化黄石工厂网站优化公司合肥整站网站优化上饶县网站优化渠道顺德网站建设优化技术搜索引擎优化网站网站排名怎么优化网站排名优化圣搜好仙桃市网站关键词优化哪家好潜江工厂网站优化要多少钱汕尾资深的免费网站优化电商网站seo优化临沂济南网站优化公司价格多少坪山网站优化恩施产品网站优化公司排名岳阳网站优化收费建安区口碑好网站优化哪家强网站建设优化服务价位郑州瓷砖行业网站优化推广渠道泰兴网站优化招聘合肥网站优化排行榜崇明区企业网站优化价格费用秦淮区公司网站优化寿光优化网站代运营晋宁网站优化收费北京网站优化排名平台咨询网站优化方案设计新乡郑州智能网站优化益阳网站关键词排名优化什么样的网站利于优化口碑好的网站排名优化效果好张家港网站优化怎么快速优化网站排名网站优化与推广课程设计网站优化思路网站排名优化大师最低多少钱我的世界基岩版动作优化网站网站404页面优化太原五金行业网站优化推广价格上海品质网站优化产品介绍连云港企业网站优化营销网站优化的知识低成本网站优化怎么做清远网站的优化个人优化网站莆田市网站优化渠道江阴网站搜索优化企业南通网站优化人才招聘网站优化差距在哪里泰州网站优化工作室个人网站 收录 优化山西网站优化电商网站如何优化SEO优化网站百度技术许昌口碑好网站优化的用途和特点邢台商城网站优化福田百科网站优化在线推广刷网站优化快速排名软浦东新区公司网站优化哪家好观澜网站优化哪家好莆田网站优化去哪找大兴区互联网网站优化记录成都网站搜索优化成都专业的餐饮行业网站优化网站优化的思路营销网站推广优化网站性能优化重庆网站优化公司地址沁阳网站排名优化报价单济南网站长尾关键词优化龙城软件网站优化给一个网站哪些方式进行优化企业网站优化排名竞价和优化同一个网站家具网站优化价格表福建省给网站优化一站式服务高新外贸型网站优化软件巩义网站关键词优化公司多少钱怎么给网站做seo优化怀宁网站优化哪家合适蜘蛛屯郑州网站优化排名枣庄网站关键词优化怎么做的网站如何做优化推广关键词网站优化部门定位盐城网站优化有优惠吗四川网站优化哪家强个人网站建设优化南京网站优化发布稳定的网站优化服务西安网站关键词优化合肥网站优化 鹊起科技中山专业的佛山网站优化方案黄骅网站优化郑州优化网站哪家好韶关服务好的免费网站优化青州网站优化网站优化检测银川网站优化推广公司哪家好淄博多语言网站优化新乡网站优化哪家有实力诸城网站优化辽宁网站建设推广优化英文网站优化莆田网站优化必看孝感产品网站优化公司排名站内网站优化网站优化排名优化网拍服务网站河南优质网站优化淄博网站制作高端优化珠海网站关键词优化多少钱网站推广优化公司哪家好网站怎么关键字优化专业公司网站优化宿迁网站优化推广企业二七区网站优化排名软件怎样做好手机网站的优化淮安网站优化公司方案商丘企业网站优化排名多少钱恩施品牌网站优化哪家好热门网站优化系统加盟常德专业网站优化哪家好金山区公司网站优化价格费用温县营销网站搭建优化江门门窗网站优化效果怎么优化公司网站排名西安网站排名优化软件推广广州网站建设优化公司网站优化排名推广普陀区360网站优化公司哪家好优化网站关键词怎么做网站栏目页关键词优化代码三水百度网站优化公司山西网站关键词排名优化策略网站页面排版优化商丘网站自然优化哪家有实力坪山网站优化高端网站优化公司排名怀宁网站优化收费情况网站seo推广优化招聘东莞网站优化公司沧州网站搜索优化排名公司于网站排名在线优化网站优化方案的等级划分邯郸网站优化seo网站优化常见问题沈阳规模大的网站推广与优化如何写网站优化方案重庆网站优化公司地址如何优化网站推广邵阳网站优化优化seo网站西安福建省给网站优化具体做什么的安徽网站首页优化公司网站建站优化排名广元网站优化建设揭阳网站优化技巧河源正规的免费网站优化快速优化网站一年多少钱长宁区百度网站优化价格深圳信息类网站优化方式有哪些seo网站优化外包价格网站建设之优化标准电子商务网站的搜索引擎优化技巧南京seo网站优化公司滕州网站搜索引擎优化沁阳网站自然优化哪里的好铜陵教育培训公司网站优化中山集团网站优化方案上海网站关键词优化外包网站优化含义焦作郑州网站优化咨询深圳做网站推广优化南充网站整站优化服务中梁山网站推广优化网站优化六个关键seo网站优化软件网站核心词优化联系方式网站搜索优化公司网站的优化排名软件东莞网站建设优化方案seo网站优化公司网站优化应该怎么做网站建设优化公司茂名网站优化热线如何增加网站优化关键词南京专业网站优化公司自己的网站如何优化苏州市网站公告优化多少钱浦东新区专业网站优化公司淮安网站建设关键词优化优化网站需要做哪些

合作伙伴

天下标王

龙岗网络公司
深圳网站优化
龙岗网站建设
坪山网站建设
百度标王推广
天下网标王
SEO优化按天计费
SEO按天计费系统