毕业论文-基于Android的网上订餐系统和原代码.doc_第1页
毕业论文-基于Android的网上订餐系统和原代码.doc_第2页
毕业论文-基于Android的网上订餐系统和原代码.doc_第3页
毕业论文-基于Android的网上订餐系统和原代码.doc_第4页
毕业论文-基于Android的网上订餐系统和原代码.doc_第5页
已阅读5页,还剩44页未读 继续免费阅读

下载本文档

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

文档简介

毕毕 业业 设设 计(计( 论论 文文 ) 题目题目 基于 Android 的网上订餐系统 作者作者 学院学院 专业专业 学号学号 指导教师指导教师 二一二 年 五月 十六日 摘摘 要要 随着科技的发展,二十一世纪成为了以网络化,信息化为核心的社会。网络商业 化也成为了时下最热门的词汇。随着信息技术的不断更新,特别是 07 年谷歌公司推出 了 Android 开放源码,让 Android 操作系统成为了移动平台的宠儿,本系统主要分析了 中小型餐饮店管理与发展的现状所面临的问题,发现传统的服务模式已经不能适应市 场发展的需求,方便、快捷、个性化的网上订餐服务正在进入人们的生活。针对这类 问题,结合当代科技发展的新成果,本文构思规划了一套最贴切的服务模式,为中小 型餐饮店外送服务提供了一套系统。 本设计是一个基于 Android 手机的网上订餐系统,采用 C/S 模式,能为客户提供 网上选择浏览菜品介绍,点菜订餐服务,并为管理员提供一个服务平台实现用户信息 与顾客订单的管理,从而提高了服务的质量,本文从系统需求、系统实际、代码实现 几个方面介绍了整个软件的开发过程,这个系统采用 JAVA、SQL Server 数据库,并利 用 MyEclipse、TOMCAT、Android SDK、ADT、AVD、DDMS 等开发环境或者开发工 具。 关键词关键词:Android;Java;MyEclipse;SQLite;SQL Server 2005 湖南科技大学本科生毕业设计(论文) ABSTRACT With the development of science and technology,the 21st century has become a society centred on information and network.Hence commercialization of network has become one of the hottest topics in recent years. Android operating system is gradually going to be the darling of the mobile platform, which results from the constantly updating of information technology, especially the appearance of Android open source carried out by Google company in 2007. The system mentioned in this article mainly focus on the problems faced by the middle and small reataurants in their management and development, and finds that the traditional service mode can not adapt to the needs of the development of the market any more.A more convenient, quicker,and personalized service enters peoples lifeonline reservations. In view of the existing problems and combining the latest achievements of the development of modern technology, I have conceived a set of the most appropriate pattern of dilivery service for the restaurant industry. This design is a online reservations system based on the Android mobile phones, which adopts C/S mode. It can provide services for clients to choose dishes introduction freely ,and to order meal actively.Besides, it can also offer a service platform for manager to regulate the user informations and customer orders, so as to improve the quality of their services.In this article, Id like to introduce the whole development process of this software in details from the system requirements, system realization,code implementation and some other aspects.This system uses JAVA,SQL Server database,in addition, MyEclipse、TOMCAT、Android SDK、ADT、AVD、DDMS and other development environments or development tools are also used in it. Keywords: Android;Java;MyEclipse;SQLite;SQL Server 2005 湖南科技大学本科生毕业设计(论文) - i - 目目 录录 第一章第一章 引引 言言.1 1.1 项目背景1 1.2 项目目的1 1.3 主要内容2 第二章第二章 系统理论与技术系统理论与技术.3 2.1 Android 3 2.1.1 Android 简介 .3 2.1.2 Android Features 特性.3 2.1.3 Android 基本框架(Android Architecture).4 2.1.4 Android 系统的四大组件 .4 2.2 Java.5 2.3 SQL Server 2005 和 SQLite 数据库.5 2.4 C/S 模式.6 第三章第三章 系统分析与设计系统分析与设计.8 3.1 功能需求.8 3.2 模块结构与流程.9 3.2.1 客户端.9 3.2.2 服务端.10 3.3 数据库设计.11 3.3.1 数据库表及其结构.11 3.3.2 数据.12 3.3.3 客户端数据库的连接.13 3.3.4 服务器数据库的连接.14 3.4 系统结构.15 3.4.1 部署图.15 3.4.2 类图.15 3.5 执行概念.16 第第四四章章 系统实现系统实现.18 4.1 Android 环境搭建 .18 4.2 客户端.19 4.2.1 系统登录.19 4.2.2 系统注册.21 4.2.3 浏览菜品.23 湖南科技大学本科生毕业设计(论文) - ii - 4.2.4 搜索菜品.25 4.2.5 订餐.26 4.2.6 结账.28 4.3 服务端.29 4.3.1 系统登录.29 4.3.2 订单管理.30 4.3.3 菜品管理.32 4.3.4 会员管理.35 第第五五章章 结束语结束语.37 参参 考考 文文 献献.38 致致 谢谢.39 湖南科技大学本科生毕业设计(论文) - 1 - 第一章第一章 引引 言言 1.1 项目背景项目背景 伴随着我国市场经济的高度发展,企业越来越依赖于市场和客户,这种依赖关系 已经开始逐步提升到关乎企业生存的高度。如何获得更多客流量,如何通过小的代价 而使商家获得更大的知名度,这是使企业得以生存、发展、壮大的关键。年销售过亿 的众多电子商务案例让人们看到了更多的商机。与应用场景相当有限的 PC (个人电 脑)相比,生而具备便携属性的手机给了电商们更大的想象空间。移动电子商务由此 产生了。移动电子商务就是利用手机、PDA 及掌上电脑等无线终端进行的 B2B、B2C 或 C2C 的电子商务。它将因特网、移动通信技术、短距离通信技术及其它信息处理技 术完美的结合,使人们可以在任何时间、任何地点进行各种商贸活动,实现随时随地、 线上线下的购物与交易、在线电子支付以及各种交易活动、商务活动、金融活动和相 关的综合服务活动等。 而 Android 操作系统凭借着自己开放的平台允许任何移动终端厂商加入到 Android 联盟中,从而使得越来越多的用户倾向于选择操作系统为 Android 的手机品牌。选择 设计基于 Android 平台的软件,毫无疑问能覆盖更多的群众, 餐饮业在电子商务中还 处于形成的初期,传统的餐饮业中,大都是以实际门面形式来进行宣传和交流。作为 网络普及化的社会,这还缺少了一些更为现代化的元素。餐饮业是一个个性化、多样 化的服务业,而电子商务则最能体现个性化、多样化服务的方式。而且现在大部分电 子商务都体现为向大企业服务,结合餐饮这个行业的特点,最终还发展为同小区小店 服务的模式。以最贴切的方式,最灵便的服务进入个个网络社区,进入人们的生活。 1.21.2 项目目的项目目的 如今宅男宅女日益增加,很多餐饮店都提供外卖服务,传统的外卖服务需要客户 给商家打电话并报出地址,商家那边也需要记录下客户的信息,才能将外卖准确的送 达,但在这之间都是人在操作,难免会出现偏差和遗漏为客户或者商家带来损失。如 今 3G 网络覆盖范围越来越广,Android 手机也占领了手机行业的大头,那么我们可以 考虑做一个 Android 的应用来方便商家和客户,让出错率达到最低。用户要点餐的时 候只需手机上网点一下菜单就能吃到自己喜欢吃的菜品,这里面蕴含了很大的商机, 完全能够有效的提高商家的营业额,基于以上因素,所以提出了这样一个基于 Android 的网上订餐系统。 本项目的目的是开发一个可以让用户在手机上操作的客户端,然后与服务器连接 进行数据交互,来实现网上订餐的流程。客户端需要实现浏览菜品,点菜,下订单, 搜索等功能。服务器端需实现添加、删除、修改菜品、对订单的处理,以及对会员的 管理等功能。 湖南科技大学本科生毕业设计(论文) - 2 - 本项目是一款基于 Android 手机平台的订餐系统,使拥有 Android 手机的用户生活 更加方便快捷,使得手机显得更生动灵活化,与人们更为接近,让手机主人随时随地 都能吃到自己喜欢的菜品。使人们的生活更加多样化。也使设计者更加熟练 Android 的技术和其他在市场上的特点。 1.31.3 主要内容主要内容 通过对实际情况的调研,本系统大致可分为三个部分,即手机客户端、电脑服务 器端和图形化界面工具。系统采用 HTTP 协议来进行数据传输。采用 C/S 结构,客户 端为基于 Android 操作系统平台的智能手机,主要的业务逻辑则服务器端来实现,数 据存储在数据库服务器。客户端主要实现位置服务,商品展示,会员注册及登录,购 物车,商品搜索和个人信息等功能,服务器端主要是完成数据交互和数据逻辑处理, 而图形界面化工具则是负责商品、订单等的增删改查。 为了一步步实现确定的功能,本论文主要内容安排如下: 第一章:引言(介绍课题研究的背景和目的) 第二章:系统理论与技术(在本项目中设计到的技术简介) 第三章:系统分析与设计(需求分析,数据库的分析与设计以及系统结构的设计) 第四章:系统实现(根据需求分析来实现系统的各个模块功能,使客户端与服务 器,服务器与数据库能正常数据交互。这部分主要搭建开发环境,编写代码,测试, 运行) 第五章:结束语(对本项目做一个项目总结) 湖南科技大学本科生毕业设计(论文) - 3 - 第二章第二章 系统理论与技术系统理论与技术 2.1 Android 2.1.1 Android 简介简介 Android 一词的本义指“机器人” ,同时也是 Google 于 2007 年 11 月 5 日宣布的 基于 Linux 平台的开源手机操作系统的名称,该平台由操作系统、中间件、用户界面 和应用软件组成,号称是首个为移动终端打造的真正开放和完整的移动软件。 Android 是基于 Linux 内核的软件平台和操作系统,早期由 Google 开发(在华注 册商标名为“安致” ) ,后由开放手机联盟(Open Handset Alliance)开发。它采用了软 件堆层(software stack,又名以软件叠层)的架构,主要分为三部分。低层以 Linux 内 核工作为基础,只提供基本功能;其他的应用软件则由各公司自行开发,以 Java 作为 编写程序的一部分。另外,为了推广此技术,Google 和其它几十个手机公司建立了开 放手机联盟。Android 在未公开之前常被传闻为 Google 电话或 gPhone。大多传闻认为 Google 开发的是自己的手机电话产品,而不是一套软件平台。到了 2010 年 1 月, Google 开始发表自家品牌手机电话的 Nexus One,目前最新 SDK 版本为 Android 4.0.3。 2.1.2 Android Features 特性特性 Android 系统有如下的几大特性1: 应用程序框架 支持组件的重用与替换 Dalvik 虚拟机 专门为移动设备做了优化 内部集成浏览器 该浏览器基于开源的 WebKit 引擎 优化的图形库 包括 2D 和 3D 图形库,3D 图形库基于 OpenGL ES SQLite 用作结构化的数据存储 多媒体支持 包括常见的音频、视频和静态印象文件格式(如 MPEG4, MP3, AAC, AMR, JPG, PNG) GSM 电话(依赖于硬件) 蓝牙 Bluetooth, EDGE, 3G, and WiFi (依赖于硬件) 照相机,GPS,指南针,和加速度计 (依赖于硬件) 丰富的开发环境 包括设备模拟器,调试工具,内存及性能分析图表,和 Eclipse 集成开发环境插件 湖南科技大学本科生毕业设计(论文) - 4 - 2.1.3 Android 基本框架(基本框架(Android Architecture) 图图 2.1 Android Architecture 2.1.4 Android 系统的四大组件系统的四大组件 在 Android 系统中,为我们提供了四大基本组件,每个组件是一个视图,但是有 些是可见的,有些是不可见的视图,像 Activity,ContentProvider 是可见的视图, Service 和 BroadcastReceiver 是不可见的,它们只在系统的后台运行。下面分别介绍四 大组件3: (1)Activity 简介 在 Android 系统中 Activity 提供可视化的用户界面,一个 Android 应用通常由多个 Activity 组成。多个 Activity 组成了 Activity 栈(Stack) ,当前活动的 Activity 处于栈顶。 Activity 有自己的生命周期,由 Android 系统来控制。 (2)Service 简介 顾名思义 Service 就是运行在后台的一种服务程序,一般很少和用户交互,因此没 有可视化界面定义一个 Service 类比较简单,只要继承 Service 类,实现其生命周期中 的方法就可以了。一个定义好的 Service 必须在 AndroidManifest.xml 配置文件注册,通 过元素声明才能使用.Service 有自己的生命周期,我们可以调用 startService() 启动一个 Service 或者 bindService()方法来绑定一个存在的 Service (3)Broadcast Receiver 简介 Broadcast Receiver 顾名思义广播接收器,它和事件处理机制类似,只不过事件处 理机制是程序组件级别的(例如,某个按钮的单击事件) ,而广播事件处理机制是系统 湖南科技大学本科生毕业设计(论文) - 5 - 级别的。到目前为止我们可以使用 Intent 来启动一个程序组件,我们还可以通过使用 sendBroadcast()方法来发起一个系统级别的事件广播来传递消息。我们可以在你的应用 程序中实现 Broadcast Receiver 来监听和响应这些广播的 Intent (4)ContentProvider 简介 Content Provider 用来保存和检索数据,并且使应用程序之间相互访问数据成为可 能。它是跨应用程序共享数据的唯一方法。 Android 为常用的数据类型(如:音视频、图片和联系方式等)提供了大量的 Content Provider。它们被定义在 vider 包下面。通过这样定义好的 ContentProvider 我们可以方便的进行数据操作。当然我们必须拥有适当的权限。我们 也可以自己来定 ContentProvider 共享我们的数据,方便用户的访问。 2.2 Java Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的 Java 程序设计语言和 Java 平台(即 JavaSE, JavaEE, JavaME)的总称。Java 技术具有卓越的通用性、高效性、平台移植性和安全 性,广泛应用于个人 PC、数据中心、游戏控制台、科学超级计算机、移动电话和互联 网,同时拥有全球最大的开发者专业社群。在全球云计算和移动互联网的产业环境下, Java 更具备了显著优势和广阔前景。 Eclipse 是一个开放源代码的、基于 Java 的可扩展开发平台。就其本身而言,它只 是一个框架和一组服务,用于通过插件组件构建开发环境。幸运的是,Eclipse 附带了 一个标准的插件集,包括 Java 开发工具(Java Development Kit,JDK) 。 虽然大多数用户很乐于将 Eclipse 当作 Java 集成开发环境(IDE)来使用,但 Eclipse 的目标却不仅限于此。Eclipse 还包括插件开发环境(Plug-in Development Environment,PDE) ,这个组件主要针对希望扩展 Eclipse 的软件开发人员,因为它允 许他们构建与 Eclipse 环境无缝集成的工具。由于 Eclipse 中的每样东西都是插件, 对于给 Eclipse 提供插件,以及给用户提供一致和统一的集成开发环境而言,所有工 具开发人员都具有同等的发挥场所。 这种平等和一致性并不仅限于 Java 开发工具。尽管 Eclipse 是使用 Java 语言开 发的,但它的用途并不限于 Java 语言;例如,支持诸如 C/C+ 和 COBOL 等编程 语言的插件已经可用,或预计将会推出。Eclipse 框架还可用来作为与软件开发无关的 其他应用程序类型的基础,比如内容管理系统。 基于 Eclipse 的应用程序的一个突出例子是 IBM Rational Software Architect,它 构成了 IBM Java 开发工具系列的基础7。 2.3 SQL Server 2005 和和 SQLite 数据库数据库 SQL Server 是一个关系数据库管理系统。它最初是由 Microsoft Sybase 和 Ashton- 湖南科技大学本科生毕业设计(论文) - 6 - Tate 三家公司共同开发的,于 1988 年推出了第一个 OS/2 版本。在 Windows NT 推出 后,Microsoft 与 Sybase 在 SQL Server 的开发上就分道扬镳了,Microsoft 将 SQL Server 移植到 Windows NT 系统上,专注于开发推广 SQL Server 的 Windows NT 版本。 Sybase 则较专注于 SQL Server 在 UNIX 操作系统上的应 SQL Server 安装界面用。 SQLite,是一款轻型的数据库,是遵守 ACID 的关联式数据库管理系统,它的设 计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的 低,在嵌入式设备中,可能只需要几百 K 的内存就够了。它能够支持 Windows/Linux/Unix 等等主流的操作系统,同时能够跟很多程序语言相结合,比如 Tcl、C#、PHP、Java 等,还有 ODBC 接口,同样比起 Mysql、PostgreSQL 这两款开源 世界著名的数据库管理系统来讲,它的处理速度比他们都快。SQLite 第一个 Alpha 版 本诞生于 2000 年 5 月. 至今已经有 10 个年头,SQLite 也迎来了一个版本 SQLite 3 已 经发布。 2.4 C/S 模式模式 在网络连接模式中,除对等网外,还有另一种形式的网络,即客户机/服务器网, Client/Server。在客户机/服务器网络中,服务器是网络的核心,而客户机是网络的基础, 客户机依靠服务器获得所需要的网络资源,而服务器为客户机提供网络必须的资源。 这里客户和服务器都是指通信中所涉及的两个应用进程(软件) 。使用计算机的人 是计算机的“用户” (user)而不是“客户” (client) 。但在许多国外文献中,也经常把 运行客户程序的机器称为 client(这种情况下也可把 client 译为“客户机” ) ,把运行服 务器程序的机器称为 server。所以有时要根据上下文判断 client 与 server 是指软件还是 硬件。 它是软件系统体系结构,通过它可以充分利用两端硬件环境的优势,将任务合理 分配到 Client 端和 Server 端来实现,降低了系统的通讯开销。目前大多数应用软件系 统都是 Client/Server 形式的两层结构,由于现在的软件应用系统正在向分布式的 Web 应用发展,Web 和 Client/Server 应用都可以进行同样的业务处理,应用不同的模块共 享逻辑组件;因此,内部的和外部的用户都可以访问新的和现有的应用系统,通过现 有应用系统中的逻辑可以扩展出新的应用系统。这也就是目前应用系统的发展方向。 C/S 架构软件的优势和劣势9: 应用服务器运行数据负荷较轻。最简单的 C/S 体系结构的数据库应用由两部分组 成,即客户应用程序和数据库服务器程序。二者可分别称为前台程序与后台程序。运 行数据库服务器程序的机器,也称为应用服务器。一旦服务器程序被启动,就随时等 待响应客户程序发来的请求;客户应用程序运行在用户自己的电脑上,对应于数据库 服务器,可称为客户电脑,当需要对数据库中的数据进行任何操作时,客户程序就自 动地寻找服务器程序,并向其发出请求,服务器程序根据预定的规则作出应答,送回 湖南科技大学本科生毕业设计(论文) - 7 - 结果,应用服务器运行数据负荷较轻。 数据的储存管理功能较为透明。在数据库应用中,数据的储存管理功能,是由服 务器程序和客户应用程序分别独立进行的,前台应用可以违反的规则,并且通常把那 些不同的(不管是已知还是未知的)运行数据,在服务器程序中不集中实现,例如访 问者的权限,编号可以重复、必须有客户才能建立定单这样的规则。所有这些,对于 工作在前台程序上的最终用户,是“透明”的,他们无须过问(通常也无法干涉)背 后的过程,就可以完成自己的一切工作。在客户服务器架构的应用中,前台程序不是 非常“瘦小” ,麻烦的事情都交给了服务器和网络。在 C/S 体系的下,数据库不能真正 成为公共、专业化的仓库,它受到独立的专门管理。 C/S 架构的劣势是高昂的维护成本且投资大。首先,采用 C/S 架构,要选择适当的 数据库平台来实现数据库数据的真正“统一” ,使分布于两地的数据同步完全交由数据 库系统去管理,但逻辑上两地的操作者要直接访问同一个数据库才能有效实现,有这 样一些问题,如果需要建立“实时”的数据同步,就必须在两地间建立实时的通讯连 接,保持两地的数据库服务器在线运行,网络管理工作人员既要对服务器维护管理, 又要对客户端维护和管理,这需要高昂的投资和复杂的技术支持,维护成本很高,维 护任务量大。 (4)传统的 C/S 结构的软件需要针对不同的操作系统系统开发不同版本的软件, 由于产品的更新换代十分快,代价高和低效率已经不适应工作需要。在 JAVA 这样的 跨平台语言出现之后,B/S 架构更是猛烈冲击 C/S,并对其形成威胁和挑战。 湖南科技大学本科生毕业设计(论文) - 8 - 第三章第三章 系统分析与设计系统分析与设计 3.1 功能需求功能需求 随着 3G 时代的到来,手机应用越来越普遍,加之国民手机持有量更是爆炸式增长。 为了方便 Android 手机用户能随时随地点到自己喜欢的菜品,提出一种操作简便,功 能齐全,占用资源少,能为用户节约流量的的网上订餐应用,于是提出本系统的主要 功能。 需求界面如下: 客户端: 1、登陆、注册界面 2、显示菜品界面 3、搜索菜品界面(按菜品名称、种类、店铺名称进行搜索) 4、购物车界面 5、个人信息界面 6、菜品详情界面 服务器端: 1、登陆界面 2、订单管理、菜品管理、会员管理界面 需求实现功能如下: 客户端: 1、实现客户端与服务器之间的连接 2、实现登陆、注册功能 3、实现登陆后能浏览到服务器数据,并对数据进行一系列的操作 4、能把菜品加入到购物车,并结算生成订单 5、把生成的订单信息传回服务器端 服务器端: 1、实现管理员登陆 2、实现添加、删除、修改菜品信息 3、实现对客户端传过来的订单进行处理 4、实现添加、删除会员列表 功能模块图如 3.1 所示: 湖南科技大学本科生毕业设计(论文) - 9 - 图图 3.1 系统功能模块图系统功能模块图 3.2 模块结构与流程模块结构与流程 3.2.1 客户端客户端 表表 3.1 客户端概要设计表客户端概要设计表 客户端模块客户端模块简要说明简要说明 登陆模块在连接上服务器的前提下登陆成功 注册模块在连接上服务器的前提下注册成功 浏览菜品模块从服务器中读取数据,并把数据封装显示在菜品列表中 菜品详情模块点击菜品进入到菜品的详细介绍和订餐服务页面 搜索模块按照用户选择的条件从手机数据库中搜索菜品 购物车模块当用户定了菜品之后,所有订单信息都显示在这个模块中, 并且点击结算按钮生成订单传送回服务器 个人信息模块显示用户的个人信息 湖南科技大学本科生毕业设计(论文) - 10 - 图图 3.2 客户端流程图客户端流程图 3.2.2 服务端服务端 表表 3.2 服务器端概要设计表服务器端概要设计表 服务器端模块服务器端模块简要说明简要说明 登陆模块提供管理员登陆 订单信息模块显示现有的订单信息并给与处理按钮 菜品添加删除修改模块对要显示在客户端的菜品进行添加删除修改操作 会员管理模块对会员进行添加和删除以及查看信息 湖南科技大学本科生毕业设计(论文) - 11 - 图图 3.3 服务器流程图服务器流程图 3.3 数据库设计数据库设计 数据库结构组织和数据库文件设计要根据不同用途,使用要求等,来决定数据库 的整体组织形式等一系列问题。 数据库,顾名思义,是存放数据的仓库,只不过这个仓库是在计算机存储设备上 的,而且数据是按一定格式存放。数据库中的数据按一定模型组织描述和存储。具有 较小的重复度,较高的数据独立性和易扩张性,并且可以被一定范围内的各种用户共 享。在涉及数据库的软件开发中,需要根据有待解决的问题性质,规模,以及所采用 的前端程序创建工具等。做出合适的数据库类型选择。 在该项目中建立了两个数据库,客户端和服务器各一个,用这种设计方式主要是 为用户减少许多不必要的流量浪费,如果只创建一个服务器数据库的话,用户每次连 接上服务器时都会将服务器的所有资源全部接受一遍,但是事实上该项目并不需要实 时的更新数据,因为有些菜品的信息可能很久都不会有变动,所以考虑在客户端也创 建一个数据库把服务器端发送过来的数据存储在本地数据库中,当服务器有更新时只 需要传递改变的数据就可以实现更新。 3.3.1 数据库表及其结构数据库表及其结构 服务器数据库(SQL Server 2005) Admin 表:管理员编号,用户名,密码,权限。 BaseProducts 表:菜品编号,菜品名字,菜品种类,菜品价格,菜品图片。 DetailOrders 表:订单编号,详细编号,菜品编号,数量。 DetailProducts 表:编号,菜品编号,菜品价格,菜品状态,折扣,菜品描述。 Member 表:会员编号,会员名字,会员密码,会员性别,会员电话,会员地址, 湖南科技大学本科生毕业设计(论文) - 12 - 会员积分,会员金钱。 Orders 表:订单编号,订单生成时间,会员编号,订单状态。 客户端数据库(SQLite) Shoppingrecord 表:订单编号,详细编号,菜品编号,数量。 Showedgoods 表:菜品编号,菜品名字,菜品种类,菜品价格,菜品图片。 3.3.2 数据数据 系统 E-R(实体-联系)图用来描述数据关系模型,可以用来建立数据模型。本系 统共有 8 个实体,其关系如图 3.4 所示。 图图 3.4 全局全局 E-R 图图 下面列举主要实体: 管理员实体(Admin)包括管理员编号、管理员姓名(登录姓名)、登录密码、管理 员等级等属性,如图 3.5 所示。 湖南科技大学本科生毕业设计(论文) - 13 - 管理员编号 管理员姓名 (登录帐号) 登录密码 管理员级别 管理员表 图图 3.5 管理员实体属性图管理员实体属性图 会员实体(Member)包括会员编号、会员姓名(登录帐号)、登录密码、管理员性 别,联系电话,联系地址,会员积分等属性。如图 3.6 所示。 会员编号 会员姓名 (登录帐号) 登录密码 会员性别 会员表 联系电话 联系地址 会员积分 图图 3.6 会员实体属性图会员实体属性图 3.3.3 客户端数据库的连接客户端数据库的连接 Andorid 数据库存储的位置在 data/data/databases/目录下,Android 是利用 ContentProvider 作为内容提供商,SQLiteOpenHelper 数据库帮助类来进行对数 据库的创建和操作。程序中数据库类为 MyopenHelper extends SQLiteOpenHelper(继承 关系) ,在此列出连接数据库的代码: public class MyopenHelper extends SQLiteOpenHelper / 生成表shoppingrecod,用以记录购买过的商品 private static final String RECORD_TABLE = “create table shoppingrecord (oid integer primary key ,doid integer,bid integer,donum integer)“; / 生成表showedgoods,用以存储上次购买过的商品 private static final String GOODS_TABLE = “create table showedgoods (bid integer 湖南科技大学本科生毕业设计(论文) - 14 - primary key ,bname varchar,bstyle varchar,bprice float,bpicture varchar)“; /创建表 public void onCreate(SQLiteDatabase db) db.execSQL(RECORD_TABLE); db.execSQL(GOODS_TABLE); /更新表 public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) db.execSQL(“drop table if exists shoppingrecord“); db.execSQL(“drop table if exists showedgoods“); db.execSQL(RECORD_TABLE); db.execSQL(GOODS_TABLE); 3.3.4 服务器数据库的连接服务器数据库的连接 服务器端采用 SQL Server 2005 来创建数据库,首先得导入 sql2000_2005jdbc.jar 库 文件,然后在数据库的配置工具中开启 SQL Server 服务,接下来就要在 java 代码中实 现连接数据库的功能了,代码如下: public static Connection getCon() Connection con = null; if (!isInitialized) return con; try Class.forName(prop.getProperty(“className“); /连接数据库语句,url user pwd都在配置文件sql.ini中 con = DriverManager.getConnection(prop.getProperty(“url“), prop .getProperty(“user“), prop.getProperty(“pwd“); catch (Exception e) e.printStackTrace(); return con; Sql.ini 配置文件内容: className=com.microsoft.sqlserver.jdbc.SQLServerDriver url=jdbc:sqlserver:/localhost:1433;databaseName=Dinner user=sa pwd=123 湖南科技大学本科生毕业设计(论文) - 15 - 3.4 系统结构系统结构 本系统采用 HTTP 协议来进行数据传输。采用 C/S 结构,客户端为基于 Android 操作系统平台的智能手机,主要的业务逻辑则服务器端来实现,数据存储在数据库服 务器。 3.4.1 部署图部署图 系统部署如图 3.7 所示,客户端采用基于 Android 操作系统平台的智能手机,服务 器端包括服务器、图形界面化工具和数据库服务器,主要处理业务逻辑和对数据的增 删改查。 图图 3.7 系统部署图系统部署图 3.4.2 类图类图 根据已建立的用例图确定要建立的对象类并确定属性和操作。通过检查类的定义, 分析问题的需求和运用该领域知识来确定类的属性。根据系统功能需求和系统设计需 要确定类的操作,本系统有 6 个实体类,分别为管理员实体类(Admin) 、会员实体类 (Member) 、订单实体类(Orders) 、订单详情实体类(DetailOrders) 、商品实体类 (Products) 、商品详情实体类(DetailProducts) ,如图 3.8 所示。 湖南科技大学本科生毕业设计(论文) - 16 - +getAid() : int +setAid() +getAname() : string +setAname() +getAcode() : string +setAcode() -aid : int -aname : string -acode : string A Am mi in n +getBid() : int +setBid() +getBname() : string +setBname() +getBstyle() : string +setBstyle() +getBprice() : float +setBprice() +getBpicture() : string +setBpicture() -bid : int -bname : string -bstyle : string -bprice : float -bpicture : string B Ba as se eP Pr ro od du uc ct ts s +getOid() : int +setOid() +getDoid() : int +setDoid() +getBid() : int +setBid() +getDonum() : int +setDonum() -oid : int -doid : int -bid : int -donum : int D De et ta ai il lO Or rd de er r +getDid() : int +setDid() +getBid() : int +setBid() +getDappraise() : float +setDappraise() +getDstate() : int +setDstate() +getDdiscount() : int +setDdiscount() +getDcomment() : string +setDcomment() -did : int -bid : int -dappraise : float -dstate : int -ddiscount : int -dcomment : string D De et ta ai il lP Pr ro od du uc ct ts s +getMid() : int +setMid() +getMname() : string +setMname() +getMcode() : string +setMcode() +getMsex() : string +setMsex() +getMnumber() : string +setMnumber() +getMaddress() : string +setMaddress() +getMscore() : int +setMscore() +getMmoney() : float +setMmoney() -mid : int -mname : string -mcode : string -msex : string -mnumber : string -maddress : string -mscore : int -mmoney : float M Me em mb be er r +getOid() : int +setOid() +getOtime() : string +setOtime() +getMid() : int +setMid() +getOstate() : int +setOstate() -oid : int -otime : string -mid : int -ostate : int O Or rd de er rs s 图图 3.8 实体类实体类 3.5 执行概念执行概念 本系统时序图如图 3.9 所示。 图图 3.9 系统时序图系统时序图 湖南科技大学本科生毕业设计(论文) - 17 - 1、客户端发送请求给服务器,服务器的后台 Servlet 负责处理数据。 2、服务器业务逻辑处理会调用 DAO,进行数据处理。 3、调用实体类,把数据保存到数据库 DB 中。 4、DAO 返回结果给 Servlet。 5、Servlet 把结果返回给客户端。 湖南科技大学本科生毕业设计(论文) - 18 - 第第四四章章 系统实现系统实现 4.1 Android 环境搭建环境搭建 任何事物要运行,都要有它的环境,Android 也有它的环境才能够运行,下面介绍 Android 的开发环境配置. 搭建开发环境需要的软件: 1、操作系统:Windows 7 或 Linux 2、软件包:Android SDK(Software Development kit Java Development kit) 、ADT(Android Develoopment Tool) 3、IDE 环境:Eclipse IDE+ADT Eclipse3.3 以上 4、JDK:Java Runtime Environment 虚拟机 、(JDK)Java Development kit 安装步骤如下: 第一步:安装 Java 虚拟机 sun-java6-jdk 版本 第二步:安装 Eclipse3.5 工具 官网 /downloads/ 选择版本(图 4.1):进行安装 图图4.1 eclipse 下载下载 第三步:安装 Android SDK:首先要下载 SDK,可以在这个网址下载 Http://sdk ,如图 4.2,选择相应的系统进行安装 图图4.2 SDK 下载下载 第四步:安装 Android ADT 插件 运行 Eclipse,选择 help-install new software 选择 add,将会弹出一个框,如图 湖南科技大学本科生毕业设计(论文) - 19 - 4.3 所示 图图4.3 ADT 的安装的安装 点击 OK,选择要安装的软件,占 next,然后选择接受协议,直到安装成功,重启 Eclipse 软件,设置 Android SDK Home,Window-refrence 图图4.4 设置设置 SDK 路径路径 在 SDK location 中输入 SDK Tools 路径:D:androidandroid-sdk 点击 OK 这样 Android 环境就已经搭建成功了。 4.2 客户端客户端 4.2.1 系统登录系统登录 登陆模块界面如图4.5所示,显示了一个登陆窗口,在其中加入许多控件,如文本 湖南科技大学本科生毕业设计(论文) - 20 - 输入框(EditText) ,文本显示框(TextView) ,单选按钮(RaidoButton) ,复选按钮 (CheckBox)等,然后用一系列的布局将其有条理的放在这个窗口中。 图图4.5 登陆窗口登陆窗口 当用户点击游客登陆时,将不会跟服务器的数据库进行匹配,直接进入主界面, 代码如下: if (flag) / 当用户选择游客登陆时点击登陆按钮直接进入主界面 Intent intent = new Intent(LoginActivity.this, ProductListActivity.class); startActivity(intent); Intent intent1 = new Intent(LoginActivity.this, UpdateService.class); startService(intent1); 当用户点击会员登陆时,会把用户输入的数据跟服务器端数据库中的数据进行匹 配,如果相同则登陆成功,否则弹出登陆失

温馨提示

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

评论

0/150

提交评论