基于java城市公交查询系统的设计与实现毕业论文.doc

上传人:仙人指路1688 文档编号:3938568 上传时间:2023-03-28 格式:DOC 页数:44 大小:605KB
返回 下载 相关 举报
基于java城市公交查询系统的设计与实现毕业论文.doc_第1页
第1页 / 共44页
基于java城市公交查询系统的设计与实现毕业论文.doc_第2页
第2页 / 共44页
基于java城市公交查询系统的设计与实现毕业论文.doc_第3页
第3页 / 共44页
基于java城市公交查询系统的设计与实现毕业论文.doc_第4页
第4页 / 共44页
基于java城市公交查询系统的设计与实现毕业论文.doc_第5页
第5页 / 共44页
点击查看更多>>
资源描述

《基于java城市公交查询系统的设计与实现毕业论文.doc》由会员分享,可在线阅读,更多相关《基于java城市公交查询系统的设计与实现毕业论文.doc(44页珍藏版)》请在三一办公上搜索。

1、太原公交查询系统的设计与实现学生姓名: 指导教师: 摘 要 公交查询系统是为了方便人们查询公交的信息,并且能够及时的做到信息更新,其主要是要做到方便人们的使用,信息的可维护性和程序的稳定性 。本系统采用了JSP编程语言,数据库使用Mysql。计算机技术不断发展,逐渐适应用于各领域,给人们的学习工作生活带来了便利,在公交查询系统也是这样。纸质的公交指南或繁杂的网络版公交指南,都在不同程度上限制了市民出行的方便性。本论文介绍的是一个城市的公交查询系统,方便市民用最简约的方式,查询到最实用的公交信息。本论文是在此系统经过测试并且所有功能都实现的基础上完成的,主要涉及软件,数据库与网络技术等。关键词

2、城市公交查询系统;数据库;JSP;SSHAbstract: This city buses inquiry system aims to make the resident inquire city buses information more convenient and must achieve the information not too lag, but its main idea is the system administrate user-friendly, the data processes reliability, the maintainability, as well

3、 as procedure toughness. The system uses the JSP programming language and MYSQL as database. Along with computer technologys unceasing development, the computer applies in each big domain, and has brought the enormous convenience to peoples life, the city buses referral system is also. The departed

4、paper city buses guide or the numerous and diverse online edition city buses guide, has limited the conveniences which in the different procedure when a resident goes on a journey. This thesis introduces a city buses referral system, by facilitates the resident with the briefest way and inquires the

5、 most useful city buses information. This thesis that is based on the system has been tested and functions all come true mainly involves software, database and networking and so on.Key words: City Buses inquiry system; Databases; JSP; SSH目录1 概述61.1 项目开发背景和现状的研究61.1.1 系统开发背景61.1.2 系统研究现状61.2 项目开发目的与意

6、义61.2.1 系统开发的目标61.2.2 系统开发的意义71.3 本论文研究的主要内容72 需求分析82.1 需求分析82.1.1 系统需求82.1.2 技术需求82.1.3 安全需求82.1.4 维护需求82.2 系统可行性分析82.2.1 技术可行性82.2.2 经济可行性92.3 功能分析92.3.1 查询功能分析92.3.2 数据的更新以及修改分析93 系统关键技术103.1 JSP技术103.2 Java Bean技术113.3 JDBC技术123.4 Struts2技术133.5 Hibernate技术133.6 JavaScript技术143.7 MVC设计模式143.7.1

7、模型(Model)143.7.2 试图(View)153.7.3 控制器(Controller)153.8 系统运行环境154 系统总体设计154.1 系统总体设计概述154.2 系统功能结构图164.3 系统流程图174.3.1 系统操作流程174.3.2 数据增加流程184.3.3 数据修改流程184.3.4 数据删除流程194.4 数据流分析194.5 业务流分析195 系统详细设计205.1 后台数据库设计205.2 系统模块设计235.2.1 注册与登录235.2.2 公交信息查询255.2.3 寻物启事和失物招领265.2.4 用户个人信息管理285.2.5 公交线路管理285.3

8、 连接池配置295.4 SSH框架的整合296 系统调试与测试316.1 程序调试316.2 程序的测试316.2.1 测试的重要性及目的316.2.2 测试的步骤与内容336.2.3 单独对系统的测试336.3 测试分析34结束语35参考文献36附录37致谢431 概述1.1 项目开发背景和现状的研究1.1.1 开发背景随着城市建设的飞速发展,生活节奏的加快,公交系统对城市来说越来越重要。而政府在这方面的投入也是加大了力度,城市中的公交系统也是日益完善,公交系统的不断更新,却又导致了市民无法从原来的公交指南上看到现如今的信息,从而产生了很多不必要的麻烦。所以需要提供一个高效的公交查询系统,才

9、是问题的根本所在。现在,随着计算机技术和通信技术的发展,与网络相结合是现如今的重要发展方向,特别是在网络普及,上网极为方便的网络信息时代,通过上网来查询公交信息是公交查询系统的发展方向。1.1.2 研究现状公交查询系统是为了方便人们查询公交的一些信息,并且能够做到信息的及时更新,主要是要方便人们的使用,信息的可维护性和程序的稳定性 。本系统采用JSP,数据库使用的是Mysql。计算机技术的不断发展,逐渐适应用于各领域,给人们的学习工作生活带来了便利,在公交查询系统也是这样。纸质的公交指南或繁杂的网络版公交指南,都在不同程度上限制了市民出行的方便性。本论文介绍的是一个城市的公交查询系统,方便市民

10、用最简约的方式,查询到最实用的公交信息。1.2 项目开发目的与意义1.2.1 系统开发的目标本系统是基于J2EE的公交查询系统,其中包括了公交查询系统的基本功能,并提供了用户留言的功能,方便根据用户提供的留言信息或是提出的建议对系统进行修改和完善,并提供了管理员用户后台维护公交信息的功能,做到能够实时添加和删除公交车次站点。除主要功能以外本系统还附带发布寻物启示与失物招领模块,方便用户。 本系统目标是方便市民进行公交信息查询,并且要做到信息不滞后,其主要思想是做到系统管理的人性化,数据处理的可靠性,可维护性,以及程序的健壮性2。系统提供了用户留言的功能,根据用户提供的留言信息或提出的建议提高公

11、交公司的服务质量。基于J2EE的城市公交查询系统,它采用B/S模式。该系统不仅可以用于公交公司管理系统中,也可以单独作为公交管理系统的一个模块存在,并可以制作成城市公交信息系统查询网,放置于城市的主要场所3。这样不仅可以体现出一个城市的智能公交系统的水平,更显示出城市的数字化,信息化水平。1.2.2 系统开发的意义Internet 是城市公交信息查询系统得以实现的基础。在当今社会,网络大为普及,上网极为方便,通过网络查询公交信息更是城市公交信息查询系统的发展方向,与网络相结合是大势所趋4。城市公交信息查询系统旨在应用现代的信息网络化为广大乘客提供一种方便快捷的乘车线路服务,让网络惠及更多的人。

12、提高市民的出行效率,促进社会的和谐。本论文主要涉及软件,数据库与网络技术等。涵盖知识面广,可有效地提高学生综合运用所学知识分析解决问题的能力,增强学生对事物的理解与掌握能力,培养学生掌握科学的研究方法,正确的设计思想,独立思考,勇于进取,探索创新,为今后进一步学习与工作奠定了良好的基础。1.3 本论文研究的主要内容本论文采用软件工程思想来进行城市公交信息查询系统的设计与实现。首先,介绍当前形势下大多数城市公交路线查询系统存在的诸多问题。在此基础上提出本系统的现实意义以及必要性。对城市公交信息查询系统进行了可行性分析,确定了本系统的功能、性能、界面等。其次,对城市公交信息查询系统进行模块分解,确

13、定软件结构,模块功能和模块间的接口,以及数据库的设计。及根据需求分析中提出的思路来设计系统,对各个模块的设计进行了描述。然后给出了城市公交信息查询系统的整体结构图以及各个模块的实现流程图以及数据库设计时需要的表结构。再次,对本系统进行详细设计,在此基础上对各个模块的实现进行了介绍,给出了本系统的效果图,并且对重要功能给出了主要代码。最后,对系统进行了测试及分析。本文对软件测试的概念和方法进行了概要说明,并对系统的设计和实现进行了总结,提出了对城市公交信息查询系统的展望和具体的改进建议。2 需求分析2.1 需求分析2.1.1 系统需求由于本系统面向广大市民和公交公司管理本系统等非计算机专业人士的

14、需求,因此要求硬件配置不能太高,任何一个普通的计算机用户都能很快的熟悉整个软件的使用。本系统要做到所耗费的资源常小,任何用户只需要在一般的电脑上面,就能够通过浏览器使用这个软件。公交公司管理人员能够简单、方便、快捷、远程的实现对系统实时维护和管理。2.1.2 技术需求本系统是以互联网为基础,采用SSH框架MySQL数据库开发模式,服务器采用Tomcat 6.0。服务器由数据库服务器、Web服务器等服务器组成,通过客户端网络连接进行系统的管理和维护,数据库服务器中的数据要实现实时更新,数据库要可靠稳定。2.1.3 安全需求本系统面向社会,因此对系统的安全性有较高的要求。对数据库要设置不同的用户权

15、限,数据的操作需要用户身份验证,只有取得合法的身份才能进行操作,还应避免数据并发现象,防止数据库无法响应操作。2.1.4 维护需求本系统采用B/S结构,系统更新、升级只需要在服务器端实现。在进行系统维护时,只需远程登录服务器,减少了维护的成本和周期。2.2 系统可行性分析2.2.1 技术可行性现在,随着计算机技术和通信技术的发展,与网络相结合是以后的重要发展方向,特别是在网络大为普及,上网极为方便的网络信息时代,通过网络查询公交信息更是公交查询系统的发展方向。特别是在网络大为普及,上网极为方便的网络信息时代,通过网络查询公交信息更是查询系统的发展方向。基于Web的新型公交信息查询系统,数据信息

16、更新更为准确、及时,用户可以利用计算机、手机等平台通过有限或无线的网络连接方式对系统进行访问,得到快捷的服务5。SSH(Spring + Struts2 +Hibernate)框架中hibernate提供了多种常用的数据库应用程序,通过少量代码的编写,就能够实现数据库的访问6。系统采用MYSQL作为开发数据库。MYSQL是一种客户机/服务器结构的关系数据库管理系统7。在技术难度方面,有指导老师的指导、周围同学的热心帮助,加上对很多相关文献的参考,能够解决开发过程中所遇到的困难。因此,技术是可行的。2.2.2 经济可行性如今,随着计算机的大量普及,各种软件的开发成本越来越低,价格也越来越底。本系

17、统也是这样,开发成本较低,只是需要一台配置一般的计算机,该系统运行时占计算机的资源也不多,但并不会因为开发成本低而造成系统功能性能的下降。相反,随着计算机技术的发展,各种实用软件的性能日渐提高。任务管理系统廉价的开发成本,却能够为用户带来相当大的实惠和方便。主要表现在:1.本系统可以说是一个拥有多种实用功能的系统,它集成了多种功能,具有较强的实用性和方便性。2.本系统的运行可以大大提高查询信息的效率,减少不必要的人力和物力。2.3 功能分析要设计一个良好的公交查询系统,就必须首先明确该应用环境对系统的要求。公交查询系统的应用背景为:方便市民搭乘公交车出行;手动(目前)、自动(将来)、及时更新查

18、询数据。2.3.1 查询功能分析系统需要提供几种不同方式的查询手段,以实现灵活方便地管理整个系统。其中包括:线路查询:可以获得要查询公交所通过的所有站点。站点查询:通过输入指定站点查询经过该站点的公交车。公交换乘模块:主要体现那些不可直达需要转车的线路的所有换发。2.3.2 数据的更新以及修改分析更新:系统允许管理员级别的用户对数据进行更新、修改并且存盘操作。编辑:系统允许管理员级别的用户对数据进行编辑、删除的操作,保证数据的真实性与实时性。系统采用采用B/S(Browser/Server)结构。整个系统最关键的就是数据库系统,一个强大的数据库可以支持完善一个优秀的软件设计,通过软件系统与数据

19、库系统的连接来实现通过软件界面观察和处理操作数据8。通过软件系统与数据库系统的连接来实现通过软件界面观察和处理操作数据,如图2-1所示。图21系统模式图系统采用三层结构,在客户端用户通过浏览器完成数据下载与模拟操作,浏览器端的表现逻辑通过JSP网页完成9。而系统内部复杂的业务逻辑主要通过JavaBean的组件(Component)实现,JavaBean组件在WWW服务器上运行,通过JSP返回到客户浏览器。通过表现逻辑与业务逻辑的分离,使网页内容简洁,系统的可维护性和可扩充性增强。在服务器端,系统使用JDBC中间件访问数据库,数据库服务器定义了本系统所需要的事务逻辑和数据逻辑。本系统使用JSP技

20、术作为表现手段,服务器采用Tomcat6.0作为JSP引擎,系统业务逻辑由JavaBean 组件完成,使用JDBC 3.0 驱动程序访问数据库10。由于系统测试需要成熟的数据库支持,因此系统采用MySQL数据库作为数据库服务器。3 系统关键技术3.1 JSP技术JSP是由Sun微系统公司于1999年6月推出的一项技术,是基于JavaServlet以及整个Java体系的Web开发技术,利用这一技术可以建立先进、安全和跨平台的动态网页技术11。JSP技术在多个方面加速了动态Web页面的开发。与微软公司的ASP技术相比,JSP具有如下优点:1.开放的技术:JSP技术基于平台和服务器的相互独立,技术支

21、持来自广泛的、专门的、各种工具包,有服务器的组件和数据库产品开发商提供。相比之下,JSP技术主要依赖MICROSOFT支持。2.平台和服务器的独立性:JSP编写的代码可运行在任何符合JAVA语法结构的环境中。这样JSP就能够运行在多种WEB服务器上并支持来自多家开发商提供的各种工具包。3.开放的开发过程,开放的源码:自1995年以来,SUN用开放过程方法同国际JAVA组织合作开发和修改JAVA技术和规范。4.JSP标记可扩充性:JSP技术能够为开发者扩展JSP标记,充分利用与XML兼容的标记技术强大的功能,大大减少对脚本语言的依赖。5.JSP跨平台的可重用性:JSP组件(EJB,JavaBea

22、n或定制的JSP标记)都是跨平台可重用的。3.2 Java Bean技术JSP作为一个很好的动态网站开发语言得到了越来越广泛的应用,在各类JSP应用程序中,JSP + JavaBean的组合成为了一种事实上最常见的JSP程序的标准12。JavaBean是描述Java的软件组件模型,有点类似于Microsoft的COM组件概念。在Java模型中,通过JavaBean可以无限扩充Java程序的功能,通过JavaBean的组合可以快速的生成新的应用程序。对于程序员来说,最好的一点就是JavaBean可以实现代码的重复利用,另外对于程序的易维护性等等也有很重大的意义。JavaBean通过Java虚拟机

23、(Java Virtual Machine)可以得到正确的执行,具有平台无关性13。一个JavaBean有三个部分组成:1.属性(Property)Bean的属性就是对象的属性,但提供了属性读取和设置的接口支持。例如一个时钟Bean可以有时区和镇铃属性,日历Bean可以有年份和月份属性。每个属性通常遵守简单的方法命名规则。这样可以很方便的找出Bean提供的属性,然后查询属性值或改变属性值,对Bean进行操作。2.方法(Method)由于Bean本身是Java对象,调用这个对象的方法是与其交互作用的唯一途径。JavaBean严格遵守面向对象的类设计逻辑,不让外界访问其任何实例字段(没有Publi

24、c字段)。这样,方法调用的是接触Bean的唯一途径。3.事件(Event)Bean与其他软件组件交流信息的主要方式是发送和接收事件。这与对象之间通过消息通信类似。JavaBean传统的应用在于可视化的领域,如AWT下的应用。自从JSP诞生后,JavaBean更多的应用在非可视化领域,在服务器端应用方面表现出来了越来越强的生命力。利用非可视化JavaBean, 来封装事务逻辑、数据库操作等等,可以很好地实现业务逻辑和前台程序(如JSP)的分离,使得系统具有更好的健壮性和灵活性。3.3 JDBC技术JDBC是Java的开发者Sun的Java Soft公司制定的Java数据库连接Java Data

25、Base Connectivity技术的简称,是为各种常用数据库提供无缝联接的技术14。JDBC在Web和Internet应用程序中的作用和ODBC在Windows系列平台应用程序中的作用类似。JDBC有一个非常独特的动态连接结构,它使得系统模块化。使用JDBC来完成对数据库的访问包括以下四个主要组件:Java的应用程序、JDBC驱动器管理器、驱动器和数据源。简单地说,JDBC能完成下列三件事:1.同一个数据库建立连接;2.向数据库发送SQL语句;2.处理数据库返回的结果。JDBC是一种可用于执行SQL语句的Java API(Application Programming Interface,

26、应用程序设计接口)。它由一些Java语言写的类、界面组成。JDBC给数据库应用开发人员、数据库前台工具开发人员提供了一种标准的应用程序设计接口,使开发人员可以用纯Java语言编写完整的数据库应用程序。通过使用JDBC,开发人员可以很方便地将SQL语句传送给几乎任何一种数据库。也就是说,开发人员可以不必写一个程序访问MySQL,写另一个程序访问Oracle,再写一个程序访问Microsoft的SQLServer。用JDBC写的程序能够自动地将SQL语句传送给相应的数据库管理系统(DBMS)。不但如此,使用Java编写的应用程序可以在任何支持Java的平台上运行,不必在不同的平台上编写不同的应用。

27、Java和JDBC的结合可以让开发人员在开发数据库应用时真正实现“Write Once,Run Everywhere!15”。Java 具有健壮、安全、易用等特性,而且支持自动网上下载,是一种很好的与数据库线连接而使用的编程语言。它所需要的是Java应用如何同各种各样的数据库连接,JDBC正是实现这种连接的关键。JDBC扩展了Java的能力,如使用Java和JDBC API就可以公布一个Web页,页中带有能访问远端数据库的Applet。或者企业可以通过JDBC让全部的职工(他们可以使用不同的操作系统,如Windows, UNIX)在Internet上连接到几个全球数据库上,而这几个全球数据库可

28、以是不相同的。3.4 Struts2技术Struts2虽然是在Struts1的基础上发展起来的,但它实质上是以WebWork为核心的,其次它为传统的Struts1注入了WebWork的先进设计理念,是在Struts和WebWork的技术基础上进行合并后的一种全新框架。它全新的体系结构与Struts1的体系结构差别很大,Struts2以WebWork为核心,在Struts2中大量使用拦截器机制来处理用户请求,采用这种设计的优势表现在:业务逻辑控制器能够与Servlet API 完全分离,避免了Struts1与Servlet API的严重耦合。Struts2对Struts1进行了巨大的改进,主要表

29、现在以下几个方面:1.线程模型方面:Struts2的Action是一个请求对应一个实例,而Struts1用一个Action的实例处理所有的请求,它的Action工作在单例模式,存在线程安全问题。2.Action实现方面:Struts1要求统一扩展自Action类,而Struts2中可以是一个普通的POJO(Plain Old Java Objects)。POJO指简单的Java对象,实际就是普通Java Beans。3.Servlet依赖方面:Struts1的Action依赖于Servlet API,例如Action的execute方法的参数包括request和response对象,使得程序难

30、以测试,而Struts2的Action不再依赖于Servlet API,便于测试。4.封装请求参数:在Struts1中强制使用ActionForm对象封装请求参数而在Struts2中可以直接使用Action的属性或者选择使用JavaBean来封装要请求的参数。5.在数据校验方面: Struts1中支持覆盖validate方法或者使用Validator框架,而在Struts2中支持重写validate方法或者使用XWork的验证框架。6.在Action执行控制方面:Struts1支持每一个模块对应一个请求处理,但是模块中的所有Action必须共享相同的生命周期,而Struts2支持通过拦截器堆栈

31、为每一个Action创建不同的生命周期。3.5 Hibernate技术Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得开发人员可以随意的使用对象编程思想来操纵数据库,最具特色的是它可以在应用EJB的J2EE架构中取代CMP,完成数据持久化的重任16。Hibernate核心接口简介:Hibernate核心接口:Hibernate 核心接口有Session、SessionFactory、Transaction、Query、Criteria和Configuration等6个。通过这六个核心接口,不仅可以对持久化对象进行存取,还能够进行事物控制。以下是

32、对这6个核心接口的介绍:Session接口:该接口负责执行持久化对象的CRUD(Create Read Update Delete)操作,需要特别指出的是Session对象时非线程安全的。SessionFactory接口:该接口负责初始化Hibernate。它的职能是负责创建Session对象,并充当数据存储的代理。这里用到了工厂模式,需要注意的是SessionFactory 并不是轻量级的,因为一般情况下,一个项目通常只需要一个SessionFactory 就够了,当需要操作多个数据库时,可以为每个数据库指定一个SessionFactory。Transaction接口:该接口负责事物相关的操

33、作。它是可选的,开发人员可以根据自己的需要来编写自己的底层事物处理代码。Query和Criteria接口:Query和Criteria接口负责各种数据库查询。它们可以使用SQL语句和HQL语言两种方式,本系统采用SQL语句。3.6 JavaScript技术JavaScript是适应动态网页制作的需要而诞生的一种脚本语言。它具有交互性,能够包含更多活跃的元素,如今已经广泛地应用于Internet网页制作17。JavaScript是由Netscape公司开发的一种脚本语言(Scripting Language)。在HTML基础上,使用JavaScript可以开发交互式网页。它的出现使得网页和用户之

34、间实现了一种实时性的、动态的、交互性的关系,使网页包含更多活跃的元素和更精彩的内容。JavaScript可以嵌入到HTML文件中,它的出现增强了网页的互动性,JavaScript简化了HTML文段中的有规律重复的部分,缩短了网页加载时间。3.7 MVC设计模式MVC模式是目前广泛流行的设计模式,包括三类对象。它强制性的使应用程序的输入、处理和输出分开。使用MVC应用程序被分成三个核心部件:模型、视图、控制器18。3.7.1 模型(Model)模型就是业务流程、状态的处理以及业务规则的制定,业务流程的处理过程对其它层来说就是黑箱操作,模型接受视图请求的数据,并返回最终的处理结果。业务模型的设计可

35、以说是MVC最主要的核心。目前流行的EJB模型就是一个典型的应用,它从应用技术实现的角度对模型做了进一步的划分,以便充分利用现有的组件。在MVC的三个部件中,模型处理的任务最多。模型的好处在于代码可以被多个视图重用,因此简化了代码。3.7.2 试图(View)视图代表用户交互界面,对于Web应用来说,可以概括为HTML界面。由于一个应用可能有很多不同的视图,MVC设计模式对于视图的处理仅限于视图上数据的采集和处理,以及用户的请求,而不包括在视图上业务流程的处理。业务流程的处理交予模型处理。3.7.3 控制器(Controller)控制器可以理解为从用户接收请求,将模型与视图匹配在一起,共同完成

36、用户的请求。所以当单击Web页面中的超链接和发送HTML表单时,控制器本身不输出任何东西和做任何处理。它只是接收请求并决定调用哪个模型构件去处理请求,然后用确定用哪个视图来显示模型处理返回的数据。3.8 系统运行环境服务器端的最低配置是由建立站点所需要的软件来决定的,在最底配置的情况下,服务器的性能往往不进人意,现在硬件性能已经相当出色,而且价格也很便宜,因此通常应给服务器端配置高性能硬件。本系统的配置要求如下:处理器:1.5GHZ以上内存:512MB硬件空间:160GB题目主要采用的开发环境及技术开发环境:Windows XP Professional(以上版本)Internet Explo

37、rer6.0(以上版本)开发工具包:JDK Version1.6脚本语言:JavaScript数据库工具:MYSQLJSP开发工具:MyEclipse8.54 系统总体设计4.1 系统总体设计概述本系统设计使用了面向对象技术和模块化技术。面向对象技术是一种软件开发和程序设计技术,其所开发的程序是面向对象程序,直接描述客观世界的对象及其相互关系。对象是封装了数据和操作的程序块。所谓封装是为这个程序块建立显示的界面,其它对象只能向这个界面发消息,不能访问内部的私有数据和操作。因此,内部的数据和实现操作的算法若有改动,对其它程序对象没有任何影响。封装使程序局部化、易修改、好维护,但许多对象有相同的功

38、能时免不了重复,所以面向对象技术有继承的机制。此外,由于对象自己操作自己的数据,对同一消息不同的对象均以自己的方式响应使得一种消息可有多种响应方式,这就是多态性。封装、继承、多态是面向对象程序的主要特征19。正是这些特征使程序安全、可靠、可重用、易维护。因而面向对象技术也成为当今计算机的新兴技术。4.2 系统功能结构图根据上述设计思想进行分析,确定了系统的基本框架,如图4-1所示。图 41系统功能模块图可以看出城市公交信息查询系统的相关功能,这为系统开发及功能模块化提供了清晰地设计思路与方向,基于系统需求分析,以下为该系统的详细功能:1.登录模块普通登陆成功后进入用户个人主界面并选择各种操作,

39、否则会返回到登录界面重新进行登录。管理员登录成功进入管理员主界面选择相应操作。2.公交系统查询模块无需登录,进入系统首页根据自己需要进行公交查询。有包括车次查询、站点查询和查询公交换乘方案等。车次查询即为根据车次号查询车次经过的站点,该车次开收车时间,等基本信息;站点查询为经过该站点的车次信息;公交换乘方案查询即分别输入起始站点和目的站点并查询公交乘车方案。3.公告管理模块普通用户登录系统后,进入公告管理模块,用户可以提出自己的一些看法意见和对本公交系统的建议,能查看以前的留言。除此之外系统还提供事物认领模块。4.用户个人信息管理模块用户登录成功后即可进入到用户的个人主界面,在个人主界面中,用

40、户可以查看个人详细信息,包括用户名账号,保护邮箱等信息,并可以自行修改密码等个人信息,最后注销登录返回到系统登录界面。5.站点信息管理模块管理员登录系统后进入相应管理员主界面,在管理员主界面中,可对公交站点信息进行添加和删除,实时更新公交变动信息。6.车次信息管理模块管理员登录系统后进入相应管理主界面,在管理员主界面中,可对公交车次信息进行添加和删除,实时更新公交变动信息。4.3 系统流程图4.3.1 系统操作流程系统操作流程图详细阐述了该系统的整体操作流程,如图4-2所示。图 42系统操作流程图用户进行登录,选择登录身份是普通用户或者管理员,如果用户名和密码正确则进入到相应的用户个人主界面,

41、否则返回登录界面重新进行登录。在用户个人主界面,用户可以进行各自需要的操作。若用户为普通用户,则可以进行查询公交信息,留言,注销和更改个人信息等操作;用户为管理员,可添加删除公交信息。最后,用户操作完毕,即可退出本系统,整个系统操作流程到此结束。 4.3.2 数据增加流程添加信息时,编号字段由系统自动生成,且不能修改,其他信息由用户输入,之后对数据进行合法判断, 合法则写入保存至数据库,不合法则重新输入数据。数据增加流程图如图4-3所示。图43数据增加流程图4.3.3 数据修改流程在修改信息时,先选中一条待修改的记录,然后直接输入数据,判断合法性,合法则保存至数据库,不合法重新输入。数据修改流

42、程图如图4-4所示。图44数据修改流程图4.3.4 数据删除流程当用户选定一条记录时,单击删除按钮,会提示用户是否确定删除,然后删除数据库相关内容。数据删除流程图如图4-5所示。图45数据删除流程图4.4 数据流分析管理员登录系统后,可进行车次管理、站点管理、线路管理、删除用户等操作。普通用户注册登录后,进入查询界面通过系统数据库,可进行公交信息查询、留言版留言。如图4-6所示。图46系统数据流分析4.5 业务流分析城市公交信息查询系统工作流程为:输入首页网址进入首页界面,游客只能查询公交信息,游客可以通过注册成为普通用户。普通用户除了具备游客权限外还可以管理个人资料以及发布信息。管理员拥有最

43、高权限,可以对系统信息增删改查,以及对普通管理员的管理,系统业务流程图如图4-7所示。图47业务流程图5 系统详细设计5.1 后台数据库设计数据库技术是信息资源管理最有效的手段。数据库设计是指对于一个给定的应用环境,构造最优的数据库模式,建立数据库及其应用系统,有效存储数据,满足用户信息要求和处理要求20。毕业设计城市公交信息查询系统需要对大量的数据完成搜集、分析、整理、存储、交换等工作,这就需要设计一个较为强大的数据库来对这些数据进行管理。在这里本着实用、方便、安全、可靠的原则,采用MySQL作为本系统数据库的支持。本系统主要数据表有:普通用户表、管理员表、车次信息表、站点信息表、中间站点关

44、联表、留言信息表等。为了满足系统存储数据需要,方便进行插入,更新,统计分析等操作,数据一共设计为两个部分,第一部分为满足插入,更新,删除较多的数据存储。第二部分为满足查询和统计分析。1.管理员信息表:该表主要保存管理员信息,包含管理员编号、管理员姓名、账户名、密码。管理员信息表结构如表5-1所示。表51管理员信息表列名数据类型字段大小可否为空说明idint否管理员编号(主键)adminNamevarchar50否管理员姓名loginNamevarchar50否账户名passWordVarchar50否密码2.公交线路信息表:该表主要保存公交线路信息,包含线路编号、正向途经站点、反向途经站点、公

45、交线路名称、始发时间与末班时间,如表5-2所示。表52公交线路信息表列名数据类型字段大小可否为空说明idint否线路编号(主键)contentvarchar255是正向途径站点content2varchar255是反向途径站点namevarchar50是线路名称titlevarchar255是始末发车时间3.失物信息表:该表主要保存用户发布的信息,包括启示编号、启示内容、发布时间、启示标题、启示类别,失物信息表结构如表5-3所示。表53失物信息表列名数据类型字段大小可否为空说明idint否启示编号(主键)contentsvarchar20是启示内容inputTimevarchar255是发布时

46、间titlevarchar255是启示标题typeint是启示类型4.找回密码表:该表主要保存找回密码所需信息,包括编号、问题答案内容、问题类型,找回密码表结构如表5-4所示。表54找回密码表列名数据类型字段大小可否为空说明idint否编号(主键)contentvarchar255是答案内容titleint是问题类型5.公告表:该表主要保存发布的公告信息,包括公告编号、公告内容、发布时间、公告标题,公告表结构如表5-5所示。表55公告表列名数据类型字段大小可否为空说明idint否公告编号(主键)contentsvarchar20是公告内容inputTimevarchar255是发布时间titlevarchar255是公告标题6.用户信息表:该表主要保存用户注册信息,包括编号、用户地址、用户邮箱、用户姓名、登录密码、用户名、用户电话、附加信息。用户信息表结构如表5-6所示。表56用户信息表列名数据类型字段大小可否为空说明idint否用户编号(主键)addressvarchar255是用户地址contentsvarchar255是附加信息emailvarchar50是

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

当前位置:首页 > 办公文档 > 其他范文


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号