版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、1 / 54 西安欧亚学院信息工程学院专业综合课程设计报告项目题目: 基于安卓的网上订餐系统 专业班级: 统本电信 1301 班 姓名学号: 马丽 13610706150192 指导教师: 赵宏宇 李有强 完成时间: 2016 年 12 月 30 日 设计报告成绩评定表设计报告成绩评定表:备注:以上总分为该组的平均分,根据成员分工具体分数如下。评分内容评分内容成绩成绩系统方案思路合理性(10%)报告内容的完整性(10%)硬件原理图及说明(20%)程序流程图(20%)程序清单(10%)调试及结果分析(10%)系统改进建议或者方案(10%)格式规范(10%)总分总分小组成员分工分数马丽 软件调试摘
2、摘 要要随着科技的发展,二十一世纪成为了以网络化,信息化为核心的社会。网络商业化也成为了时下最热门的词汇。随着信息技术的不断更新,特别是 07 年谷歌公司推出了 Android 开放源码,让 Android 操作系统成为了移动平台的宠儿,本系统主要分析了中小型餐饮店管理与发展的现状所面临的问题,发现传统的服务模式已经不能适应市场发展的需求,方便、快捷、个性化的网上订餐服务正在进入人们的生活。针对这类问题,结合当代科技发展的新成果,本文构思规划了一套最贴切的服务模式,为中小型餐饮店外送服务提供了一套系统。本设计是一个基于 Android 手机的网上订餐系统,采用 C/S 模式,能为客户提供网上选
3、择浏览菜品介绍,点菜订餐服务,并为管理员提供一个服务平台实现用户信息与顾客订单的管理,从而提高了服务的质量,本文从系统需求、系统实际、代码实现几个方面介绍了整个软件的开发过程,这个系统采用 JAVA、SQL Server 数据库,并利用 MyEclipse、TOMCAT、Android SDK、ADT、AVD、DDMS 等开发环境或者开发工具。关键词关键词:Android;Java;MyEclipse;SQLite;SQL Server 2005ABSTRACTWith the development of science and technology,the 21st century has
4、 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, es
5、pecially 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 need
6、s 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 patte
7、rn 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
8、 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 aspec
9、ts.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目目 录录第一章第一章 引引 言言.11.1 项目背景.11.2 项目目的.11.3 主要内容.2第二章第二章 系统理论与技术系统理论与技
10、术.32.1 Android .32.1.1 Android 简介 .32.1.2 Android Features 特性.32.1.3 Android 基本框架(Android Architecture).42.1.4 Android 系统的四大组件 .42.2 Java.52.3 SQL Server 2005 和 SQLite 数据库.52.4 C/S 模式.6第三章第三章 系统分析与设计系统分析与设计.83.1 功能需求.83.2 模块结构与流程.93.2.1 客户端.93.2.2 服务端.103.3 数据库设计.113.3.1 数据库表及其结构.113.3.2 数据.123.3.3
11、客户端数据库的连接.133.3.4 服务器数据库的连接.143.4 系统结构.153.4.1 部署图.153.4.2 类图.153.5 执行概念.16第四章第四章 系统实现系统实现.184.1 Android 环境搭建 .184.2 客户端.194.2.1 系统登录.194.2.2 系统注册.214.2.3 浏览菜品.234.2.4 搜索菜品.254.2.5 订餐.264.2.6 结账.284.3 服务端.294.3.1 系统登录.294.3.2 订单管理.304.3.3 菜品管理.324.3.4 会员管理.35第五章第五章 结束语结束语.37参参 考考 文文 献献.38致致 谢谢.39第一章
12、第一章 引引 言言1.1 项目背景项目背景伴随着我国市场经济的高度发展,企业越来越依赖于市场和客户,这种依赖关系已经开始逐步提升到关乎企业生存的高度。如何获得更多客流量,如何通过小的代价而使商家获得更大的知名度,这是使企业得以生存、发展、壮大的关键。年销售过亿的众多电子商务案例让人们看到了更多的商机。与应用场景相当有限的 PC (个人电脑)相比,生而具备便携属性的手机给了电商们更大的想象空间。移动电子商务由此产生了。移动电子商务就是利用手机、PDA 及掌上电脑等无线终端进行的 B2B、B2C或 C2C 的电子商务。它将因特网、移动通信技术、短距离通信技术及其它信息处理技术完美的结合,使人们可以
13、在任何时间、任何地点进行各种商贸活动,实现随时随地、线上线下的购物与交易、在线电子支付以及各种交易活动、商务活动、金融活动和相关的综合服务活动等。 而 Android 操作系统凭借着自己开放的平台允许任何移动终端厂商加入到 Android联盟中,从而使得越来越多的用户倾向于选择操作系统为 Android 的手机品牌。选择设计基于 Android 平台的软件,毫无疑问能覆盖更多的群众, 餐饮业在电子商务中还处于形成的初期,传统的餐饮业中,大都是以实际门面形式来进行宣传和交流。作为网络普及化的社会,这还缺少了一些更为现代化的元素。餐饮业是一个个性化、多样化的服务业,而电子商务则最能体现个性化、多样
14、化服务的方式。而且现在大部分电子商务都体现为向大企业服务,结合餐饮这个行业的特点,最终还发展为同小区小店服务的模式。以最贴切的方式,最灵便的服务进入个个网络社区,进入人们的生活。1.21.2 项目目的项目目的如今宅男宅女日益增加,很多餐饮店都提供外卖服务,传统的外卖服务需要客户给商家打电话并报出地址,商家那边也需要记录下客户的信息,才能将外卖准确的送达,但在这之间都是人在操作,难免会出现偏差和遗漏为客户或者商家带来损失。如今 3G 网络覆盖范围越来越广,Android 手机也占领了手机行业的大头,那么我们可以考虑做一个 Android 的应用来方便商家和客户,让出错率达到最低。用户要点餐的时候
15、只需手机上网点一下菜单就能吃到自己喜欢吃的菜品,这里面蕴含了很大的商机,完全能够有效的提高商家的营业额,基于以上因素,所以提出了这样一个基于 Android的网上订餐系统。本项目的目的是开发一个可以让用户在手机上操作的客户端,然后与服务器连接进行数据交互,来实现网上订餐的流程。客户端需要实现浏览菜品,点菜,下订单,搜索等功能。服务器端需实现添加、删除、修改菜品、对订单的处理,以及对会员的管理等功能。本项目是一款基于 Android 手机平台的订餐系统,使拥有 Android 手机的用户生活更加方便快捷,使得手机显得更生动灵活化,与人们更为接近,让手机主人随时随地都能吃到自己喜欢的菜品。使人们的
16、生活更加多样化。也使设计者更加熟练 Android的技术和其他在市场上的特点。1.31.3 主要内容主要内容通过对实际情况的调研,本系统大致可分为三个部分,即手机客户端、电脑服务器端和图形化界面工具。系统采用 HTTP 协议来进行数据传输。采用 C/S 结构,客户端为基于 Android 操作系统平台的智能手机,主要的业务逻辑则服务器端来实现,数据存储在数据库服务器。客户端主要实现位置服务,商品展示,会员注册及登录,购物车,商品搜索和个人信息等功能,服务器端主要是完成数据交互和数据逻辑处理,而图形界面化工具则是负责商品、订单等的增删改查。为了一步步实现确定的功能,本论文主要内容安排如下:第一章
17、:引言(介绍课题研究的背景和目的)第二章:系统理论与技术(在本项目中设计到的技术简介)第三章:系统分析与设计(需求分析,数据库的分析与设计以及系统结构的设计)第四章:系统实现(根据需求分析来实现系统的各个模块功能,使客户端与服务器,服务器与数据库能正常数据交互。这部分主要搭建开发环境,编写代码,测试,运行)第五章:结束语(对本项目做一个项目总结)第二章第二章 系统理论与技术系统理论与技术2.1 Android2.1.1 Android 简介简介 Android 一词的本义指“机器人” ,同时也是 Google 于 2007 年 11 月 5 日宣布的基于 Linux 平台的开源手机操作系统的名
18、称,该平台由操作系统、中间件、用户界面和应用软件组成,号称是首个为移动终端打造的真正开放和完整的移动软件。Android 是基于 Linux 内核的软件平台和操作系统,早期由 Google 开发(在华注册商标名为“安致” ) ,后由开放手机联盟(Open Handset Alliance)开发。它采用了软件堆层(software stack,又名以软件叠层)的架构,主要分为三部分。低层以 Linux 内核工作为基础,只提供基本功能;其他的应用软件则由各公司自行开发,以 Java 作为编写程序的一部分。另外,为了推广此技术,Google 和其它几十个手机公司建立了开放手机联盟。Android 在
19、未公开之前常被传闻为 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 SQLi
20、te 用作结构化的数据存储 多媒体支持 包括常见的音频、视频和静态印象文件格式(如 MPEG4, MP3, AAC, AMR, JPG, PNG) GSM 电话(依赖于硬件) 蓝牙 Bluetooth, EDGE, 3G, and WiFi (依赖于硬件) 照相机,GPS,指南针,和加速度计 (依赖于硬件) 丰富的开发环境 包括设备模拟器,调试工具,内存及性能分析图表,和Eclipse 集成开发环境插件2.1.3 Android 基本框架(基本框架(Android Architecture)图图 2.1 Android Architecture2.1.4 Android 系统的四大组件系统的四
21、大组件在 Android 系统中,为我们提供了四大基本组件,每个组件是一个视图,但是有些是可见的,有些是不可见的视图,像 Activity,ContentProvider 是可见的视图,Service 和 BroadcastReceiver 是不可见的,它们只在系统的后台运行。下面分别介绍四大组件3:(1)Activity 简介在 Android 系统中 Activity 提供可视化的用户界面,一个 Android 应用通常由多个Activity 组成。多个 Activity 组成了 Activity 栈(Stack) ,当前活动的 Activity 处于栈顶。Activity 有自己的生命周
22、期,由 Android 系统来控制。(2)Service 简介顾名思义 Service 就是运行在后台的一种服务程序,一般很少和用户交互,因此没有可视化界面定义一个 Service 类比较简单,只要继承 Service 类,实现其生命周期中的方法就可以了。一个定义好的 Service 必须在 AndroidManifest.xml 配置文件注册,通过元素声明才能使用.Service 有自己的生命周期,我们可以调用 startService()启动一个 Service 或者 bindService()方法来绑定一个存在的 Service (3)Broadcast Receiver 简介Broad
23、cast Receiver 顾名思义广播接收器,它和事件处理机制类似,只不过事件处理机制是程序组件级别的(例如,某个按钮的单击事件) ,而广播事件处理机制是系统级别的。到目前为止我们可以使用 Intent 来启动一个程序组件,我们还可以通过使用sendBroadcast()方法来发起一个系统级别的事件广播来传递消息。我们可以在你的应用程序中实现 Broadcast Receiver 来监听和响应这些广播的 Intent (4)ContentProvider 简介Content Provider 用来保存和检索数据,并且使应用程序之间相互访问数据成为可能。它是跨应用程序共享数据的唯一方法。And
24、roid 为常用的数据类型(如:音视频、图片和联系方式等)提供了大量的Content Provider。它们被定义在 vider 包下面。通过这样定义好的ContentProvider 我们可以方便的进行数据操作。当然我们必须拥有适当的权限。我们也可以自己来定 ContentProvider 共享我们的数据,方便用户的访问。2.2 JavaJava 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的 Java 程序设计语言和 Java 平台(即 JavaSE, JavaEE, JavaME)的总
25、称。Java 技术具有卓越的通用性、高效性、平台移植性和安全性,广泛应用于个人 PC、数据中心、游戏控制台、科学超级计算机、移动电话和互联网,同时拥有全球最大的开发者专业社群。在全球云计算和移动互联网的产业环境下,Java 更具备了显著优势和广阔前景。Eclipse 是一个开放源代码的、基于 Java 的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。幸运的是,Eclipse 附带了一个标准的插件集,包括 Java 开发工具(Java Development Kit,JDK) 。 虽然大多数用户很乐于将 Eclipse 当作 Java 集成开发环境(IDE
26、)来使用,但 Eclipse 的目标却不仅限于此。Eclipse 还包括插件开发环境(Plug-in Development Environment,PDE) ,这个组件主要针对希望扩展 Eclipse 的软件开发人员,因为它允许他们构建与 Eclipse 环境无缝集成的工具。由于 Eclipse 中的每样东西都是插件,对于给 Eclipse 提供插件,以及给用户提供一致和统一的集成开发环境而言,所有工具开发人员都具有同等的发挥场所。 这种平等和一致性并不仅限于 Java 开发工具。尽管 Eclipse 是使用 Java 语言开发的,但它的用途并不限于 Java 语言;例如,支持诸如 C/C+
27、 和 COBOL 等编程语言的插件已经可用,或预计将会推出。Eclipse 框架还可用来作为与软件开发无关的其他应用程序类型的基础,比如内容管理系统。 基于 Eclipse 的应用程序的一个突出例子是 IBM Rational Software Architect,它构成了 IBM Java 开发工具系列的基础7。2.3 SQL Server 2005 和和 SQLite 数据库数据库SQL Server 是一个关系数据库管理系统。它最初是由 Microsoft Sybase 和 Ashton-Tate 三家公司共同开发的,于 1988 年推出了第一个 OS/2 版本。在 Windows NT
28、 推出后,Microsoft 与 Sybase 在 SQL Server 的开发上就分道扬镳了,Microsoft 将 SQL Server 移植到 Windows NT 系统上,专注于开发推广 SQL Server 的 Windows NT 版本。Sybase 则较专注于 SQL Server 在 UNIX 操作系统上的应 SQL Server 安装界面用。 SQLite,是一款轻型的数据库,是遵守 ACID 的关联式数据库管理系统,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百 K 的内存就够了。它能够支持Windows/
29、Linux/Unix 等等主流的操作系统,同时能够跟很多程序语言相结合,比如 Tcl、C#、PHP、Java 等,还有 ODBC 接口,同样比起 Mysql、PostgreSQL 这两款开源世界著名的数据库管理系统来讲,它的处理速度比他们都快。SQLite 第一个 Alpha 版本诞生于 2000 年 5 月. 至今已经有 10 个年头,SQLite 也迎来了一个版本 SQLite 3 已经发布。2.4 C/S 模式模式在网络连接模式中,除对等网外,还有另一种形式的网络,即客户机/服务器网,Client/Server。在客户机/服务器网络中,服务器是网络的核心,而客户机是网络的基础,客户机依靠
30、服务器获得所需要的网络资源,而服务器为客户机提供网络必须的资源。这里客户和服务器都是指通信中所涉及的两个应用进程(软件) 。使用计算机的人是计算机的“用户” (user)而不是“客户” (client) 。但在许多国外文献中,也经常把运行客户程序的机器称为 client(这种情况下也可把 client 译为“客户机” ) ,把运行服务器程序的机器称为 server。所以有时要根据上下文判断 client 与 server 是指软件还是硬件。它是软件系统体系结构,通过它可以充分利用两端硬件环境的优势,将任务合理分配到 Client 端和 Server 端来实现,降低了系统的通讯开销。目前大多数应
31、用软件系统都是 Client/Server 形式的两层结构,由于现在的软件应用系统正在向分布式的 Web应用发展,Web 和 Client/Server 应用都可以进行同样的业务处理,应用不同的模块共享逻辑组件;因此,内部的和外部的用户都可以访问新的和现有的应用系统,通过现有应用系统中的逻辑可以扩展出新的应用系统。这也就是目前应用系统的发展方向。C/S 架构软件的优势和劣势9:应用服务器运行数据负荷较轻。最简单的 C/S 体系结构的数据库应用由两部分组成,即客户应用程序和数据库服务器程序。二者可分别称为前台程序与后台程序。运行数据库服务器程序的机器,也称为应用服务器。一旦服务器程序被启动,就随
32、时等待响应客户程序发来的请求;客户应用程序运行在用户自己的电脑上,对应于数据库服务器,可称为客户电脑,当需要对数据库中的数据进行任何操作时,客户程序就自动地寻找服务器程序,并向其发出请求,服务器程序根据预定的规则作出应答,送回结果,应用服务器运行数据负荷较轻。数据的储存管理功能较为透明。在数据库应用中,数据的储存管理功能,是由服务器程序和客户应用程序分别独立进行的,前台应用可以违反的规则,并且通常把那些不同的(不管是已知还是未知的)运行数据,在服务器程序中不集中实现,例如访问者的权限,编号可以重复、必须有客户才能建立定单这样的规则。所有这些,对于工作在前台程序上的最终用户,是“透明”的,他们无
33、须过问(通常也无法干涉)背后的过程,就可以完成自己的一切工作。在客户服务器架构的应用中,前台程序不是非常“瘦小” ,麻烦的事情都交给了服务器和网络。在 C/S 体系的下,数据库不能真正成为公共、专业化的仓库,它受到独立的专门管理。C/S 架构的劣势是高昂的维护成本且投资大。首先,采用 C/S 架构,要选择适当的数据库平台来实现数据库数据的真正“统一” ,使分布于两地的数据同步完全交由数据库系统去管理,但逻辑上两地的操作者要直接访问同一个数据库才能有效实现,有这样一些问题,如果需要建立“实时”的数据同步,就必须在两地间建立实时的通讯连接,保持两地的数据库服务器在线运行,网络管理工作人员既要对服务
34、器维护管理,又要对客户端维护和管理,这需要高昂的投资和复杂的技术支持,维护成本很高,维护任务量大。(4)传统的 C/S 结构的软件需要针对不同的操作系统系统开发不同版本的软件,由于产品的更新换代十分快,代价高和低效率已经不适应工作需要。在 JAVA 这样的跨平台语言出现之后,B/S 架构更是猛烈冲击 C/S,并对其形成威胁和挑战。 第三章第三章 系统分析与设计系统分析与设计3.1 功能需求功能需求随着 3G 时代的到来,手机应用越来越普遍,加之国民手机持有量更是爆炸式增长。为了方便 Android 手机用户能随时随地点到自己喜欢的菜品,提出一种操作简便,功能齐全,占用资源少,能为用户节约流量的
35、的网上订餐应用,于是提出本系统的主要功能。需求界面如下:客户端:1、登陆、注册界面2、显示菜品界面3、搜索菜品界面(按菜品名称、种类、店铺名称进行搜索)4、购物车界面5、个人信息界面6、菜品详情界面服务器端:1、登陆界面2、订单管理、菜品管理、会员管理界面需求实现功能如下:客户端:1、实现客户端与服务器之间的连接2、实现登陆、注册功能3、实现登陆后能浏览到服务器数据,并对数据进行一系列的操作4、能把菜品加入到购物车,并结算生成订单5、把生成的订单信息传回服务器端服务器端:1、实现管理员登陆2、实现添加、删除、修改菜品信息3、实现对客户端传过来的订单进行处理4、实现添加、删除会员列表功能模块图如
36、 3.1 所示:图图 3.1 系统功能模块图系统功能模块图3.2 模块结构与流程模块结构与流程3.2.1 客户端客户端表表 3.1 客户端概要设计表客户端概要设计表客户端模块客户端模块简要说明简要说明登陆模块在连接上服务器的前提下登陆成功注册模块在连接上服务器的前提下注册成功浏览菜品模块从服务器中读取数据,并把数据封装显示在菜品列表中菜品详情模块点击菜品进入到菜品的详细介绍和订餐服务页面搜索模块按照用户选择的条件从手机数据库中搜索菜品购物车模块当用户定了菜品之后,所有订单信息都显示在这个模块中,并且点击结算按钮生成订单传送回服务器个人信息模块显示用户的个人信息图图 3.2 客户端流程图客户端流
37、程图3.2.2 服务端服务端表表 3.2 服务器端概要设计表服务器端概要设计表服务器端模块服务器端模块简要说明简要说明登陆模块提供管理员登陆订单信息模块显示现有的订单信息并给与处理按钮菜品添加删除修改模块对要显示在客户端的菜品进行添加删除修改操作会员管理模块对会员进行添加和删除以及查看信息图图 3.3 服务器流程图服务器流程图3.3 数据库设计数据库设计数据库结构组织和数据库文件设计要根据不同用途,使用要求等,来决定数据库的整体组织形式等一系列问题。数据库,顾名思义,是存放数据的仓库,只不过这个仓库是在计算机存储设备上的,而且数据是按一定格式存放。数据库中的数据按一定模型组织描述和存储。具有较
38、小的重复度,较高的数据独立性和易扩张性,并且可以被一定范围内的各种用户共享。在涉及数据库的软件开发中,需要根据有待解决的问题性质,规模,以及所采用的前端程序创建工具等。做出合适的数据库类型选择。在该项目中建立了两个数据库,客户端和服务器各一个,用这种设计方式主要是为用户减少许多不必要的流量浪费,如果只创建一个服务器数据库的话,用户每次连接上服务器时都会将服务器的所有资源全部接受一遍,但是事实上该项目并不需要实时的更新数据,因为有些菜品的信息可能很久都不会有变动,所以考虑在客户端也创建一个数据库把服务器端发送过来的数据存储在本地数据库中,当服务器有更新时只需要传递改变的数据就可以实现更新。3.3
39、.1 数据库表及其结构数据库表及其结构服务器数据库(SQL Server 2005)Admin 表:管理员编号,用户名,密码,权限。BaseProducts 表:菜品编号,菜品名字,菜品种类,菜品价格,菜品图片。DetailOrders 表:订单编号,详细编号,菜品编号,数量。DetailProducts 表:编号,菜品编号,菜品价格,菜品状态,折扣,菜品描述。Member 表:会员编号,会员名字,会员密码,会员性别,会员电话,会员地址,会员积分,会员金钱。Orders 表:订单编号,订单生成时间,会员编号,订单状态。客户端数据库(SQLite)Shoppingrecord 表:订单编号,详细
40、编号,菜品编号,数量。Showedgoods 表:菜品编号,菜品名字,菜品种类,菜品价格,菜品图片。3.3.2 数据数据系统 E-R(实体-联系)图用来描述数据关系模型,可以用来建立数据模型。本系统共有 8 个实体,其关系如图 3.4 所示。图图 3.4 全局全局 E-R 图图下面列举主要实体:管理员实体(Admin)包括管理员编号、管理员姓名(登录姓名)、登录密码、管理员等级等属性,如图 3.5 所示。 管理员编号管理员姓名(登录帐号)登录密码管理员级别管理员表图图 3.5 管理员实体属性图管理员实体属性图会员实体(Member)包括会员编号、会员姓名(登录帐号)、登录密码、管理员性别,联系
41、电话,联系地址,会员积分等属性。如图 3.6 所示。 会员编号会员姓名(登录帐号)登录密码会员性别会员表联系电话联系地址会员积分图图 3.6 会员实体属性图会员实体属性图3.3.3 客户端数据库的连接客户端数据库的连接Andorid 数据库存储的位置在 data/data/databases/目录下,Android是利用 ContentProvider 作为内容提供商,SQLiteOpenHelper 数据库帮助类来进行对数据库的创建和操作。程序中数据库类为 MyopenHelper extends SQLiteOpenHelper(继承关系) ,在此列出连接数据库的代码:public cla
42、ss 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 showedgoo
43、ds (bid integer 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 shoppingr
44、ecord);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 = nu
45、ll;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.m
46、icrosoft.sqlserver.jdbc.SQLServerDriverurl=jdbc:sqlserver:/localhost:1433;databaseName=Dinneruser=sapwd=1233.4 系统结构系统结构本系统采用 HTTP 协议来进行数据传输。采用 C/S 结构,客户端为基于 Android操作系统平台的智能手机,主要的业务逻辑则服务器端来实现,数据存储在数据库服务器。3.4.1 部署图部署图系统部署如图 3.7 所示,客户端采用基于 Android 操作系统平台的智能手机,服务器端包括服务器、图形界面化工具和数据库服务器,主要处理业务逻辑和对数据的增删改查
47、。图图 3.7 系统部署图系统部署图 3.4.2 类图类图根据已建立的用例图确定要建立的对象类并确定属性和操作。通过检查类的定义,分析问题的需求和运用该领域知识来确定类的属性。根据系统功能需求和系统设计需要确定类的操作,本系统有 6 个实体类,分别为管理员实体类(Admin) 、会员实体类(Member) 、订单实体类(Orders) 、订单详情实体类(DetailOrders) 、商品实体类(Products) 、商品详情实体类(DetailProducts) ,如图 3.8 所示。+getAid() : int+setAid()+getAname() : string+setAname()
48、+getAcode() : string+setAcode()-aid : int-aname : string-acode : stringA 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-bpi
49、cture : stringB 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 : intD De et ta ai il lO Or rd de er r+getDid() : int+setDid()+getBid() : int+setBid()+getDappraise() : float+
50、setDappraise()+getDstate() : int+setDstate()+getDdiscount() : int+setDdiscount()+getDcomment() : string+setDcomment()-did : int-bid : int-dappraise : float-dstate : int-ddiscount : int-dcomment : stringD De et ta ai il lP Pr ro od du uc ct ts s+getMid() : int+setMid()+getMname() : string+setMname()+
51、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-mmon
52、ey : floatM 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 : intO Or rd de er rs s 图图 3.8 实体类实体类3.5 执行概念执行概念本系统时序图如图 3.9 所示。图图 3.9 系统时序图系统时序图1、客户端发送请求给服务器,服务器的后台 Servlet 负责处理数据。2、
53、服务器业务逻辑处理会调用 DAO,进行数据处理。3、调用实体类,把数据保存到数据库 DB 中。4、DAO 返回结果给 Servlet。5、Servlet 把结果返回给客户端。第第四四章章 系统实现系统实现4.1 Android 环境搭建环境搭建任何事物要运行,都要有它的环境,Android 也有它的环境才能够运行,下面介绍Android 的开发环境配置.搭建开发环境需要的软件:1、操作系统:Windows 7 或 Linux2、软件包:Android SDK(Software Development kit Java Development kit) 、ADT(Android Develoop
54、ment 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:/ ,如图 4.2,选择相应的系统进行
55、安装图图4.2 SDK 下载下载第四步:安装 Android ADT 插件运行 Eclipse,选择 help-install new software 选择 add,将会弹出一个框,如图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 环境就已经搭建成功
56、了。4.2 客户端客户端4.2.1 系统登录系统登录登陆模块界面如图4.5所示,显示了一个登陆窗口,在其中加入许多控件,如文本输入框(EditText) ,文本显示框(TextView) ,单选按钮(RaidoButton) ,复选按钮(CheckBox)等,然后用一系列的布局将其有条理的放在这个窗口中。图图4.5 登陆窗口登陆窗口当用户点击游客登陆时,将不会跟服务器的数据库进行匹配,直接进入主界面,代码如下:if (flag) / 当用户选择游客登陆时点击登陆按钮直接进入主界面Intent intent = new Intent(LoginActivity.this,ProductListA
57、ctivity.class);startActivity(intent);Intent intent1 = new Intent(LoginActivity.this,UpdateService.class);startService(intent1);当用户点击会员登陆时,会把用户输入的数据跟服务器端数据库中的数据进行匹配,如果相同则登陆成功,否则弹出登陆失败的信息。如果用户点击了记住密码选项,则把用户输入的用户名和密码都保存到SharedPreferences中。代码如下:String name = etUsername.getText().toString().trim();String
58、 password = etPassword.getText().toString().trim();/ 包装用户发送的用户数据Member member = new Member(name, password);protocolHelper.setObject(member);protocolHelper.setRequest(ProtocolHelper.REGISTER,ProtocolHelper.QUERY, member);result = protocolHelper.sendRequestVO();/ 向服务端发送数据if (result.size() 0) response
59、= result.get(0);/ 根据服务端的相应信息进行相应判断if (response != null) / 将用户名存在sharedPreferencesEditor namedata = sharedPreferences.edit();namedata.putString(name, etUsername.getText().toString().trim();mit();/ 将密码存在sharedPreferencesEditor passworddata = sharedPreferences.edit();passworddata.putString(password, et
60、Password.getText().toString().trim();mit();/ 登录成功,进入主界面 else / 登录失败,弹出错误信息当用户点击注册按钮时,通过Android的Intent机制,就从登陆界面跳转到注册界面,接下来实现系统注册的功能。4.2.2 系统注册系统注册注册界面如图4.6,跟登陆界面一下,它也有一个属于它的布局文件来摆放这些控件,在此模块中必须要输入正确这些注册信息,才能正常的进行注册。图图4.6 注册界面注册界面当用户点击取消按钮时,界面会跳转回到登陆界面,当用户点击注册按钮时会跟服务器端的数据库进行连接,把用户所填的信息拼接发给服务器,服务器处理过后将数
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 食品安全复习题(附参考答案)
- 基站施工合同范例
- 2025年白山货运资格证考试题库
- 别墅装修装饰设计合同范例
- 数字技术适老化发展报告(2024年)
- 2025年江西货运上岗证模拟考试题
- 台球厅合作合同范例
- 成都租房月租合同范例
- 天府新区航空旅游职业学院《近世代数》2023-2024学年第一学期期末试卷
- 公益文艺演出聘用合同范例
- 一汽大众新员工三级安全教育(入厂级)
- 常见繁体字的简化表 香港人简体字教学
- 塑料模具肥皂盒设计说明书
- 最新X公司事业部建设规划方案
- 十一学校行动纲要
- 穿越河流工程定向钻专项施工方案
- 社会主义新农村建设建筑废料利用探究
- 唯一住房补贴申请书(共2页)
- 《质量守恒定律》评课稿
- 数据中心IDC项目建议书
- 中医养生脾胃为先PPT文档
评论
0/150
提交评论