畢業(yè)設(shè)計基于Android的網(wǎng)上訂餐系統(tǒng)設(shè)計_第1頁
畢業(yè)設(shè)計基于Android的網(wǎng)上訂餐系統(tǒng)設(shè)計_第2頁
畢業(yè)設(shè)計基于Android的網(wǎng)上訂餐系統(tǒng)設(shè)計_第3頁
畢業(yè)設(shè)計基于Android的網(wǎng)上訂餐系統(tǒng)設(shè)計_第4頁
畢業(yè)設(shè)計基于Android的網(wǎng)上訂餐系統(tǒng)設(shè)計_第5頁
已閱讀5頁,還剩21頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、湖湖 南南 科科 技技 大大 學(xué)學(xué) 畢畢 業(yè)業(yè) 設(shè)設(shè) 計(計( 論論 文文 ) 題目題目 基于基于 android 的網(wǎng)上訂餐系統(tǒng)的網(wǎng)上訂餐系統(tǒng) 作者作者 學(xué)院學(xué)院 專業(yè)專業(yè) 學(xué)號學(xué)號 指導(dǎo)教師指導(dǎo)教師 二一二 年 五月 十六日 摘摘 要要 隨著科技的發(fā)展,二十一世紀(jì)成為了以網(wǎng)絡(luò)化,信息化為核心的社會。網(wǎng)絡(luò)商業(yè) 化也成為了時下最熱門的詞匯。隨著信息技術(shù)的不斷更新,特別是 07 年谷歌公司推出 了 android 開放源碼,讓 android 操作系統(tǒng)成為了移動平臺的寵兒,本系統(tǒng)主要分析了 中小型餐飲店管理與發(fā)展的現(xiàn)狀所面臨的問題,發(fā)現(xiàn)傳統(tǒng)的服務(wù)模式已經(jīng)不能適應(yīng)市 場發(fā)展的需求,方便、快捷、個性

2、化的網(wǎng)上訂餐服務(wù)正在進入人們的生活。針對這類 問題,結(jié)合當(dāng)代科技發(fā)展的新成果,本文構(gòu)思規(guī)劃了一套最貼切的服務(wù)模式,為中小 型餐飲店外送服務(wù)提供了一套系統(tǒng)。 本設(shè)計是一個基于 android 手機的網(wǎng)上訂餐系統(tǒng),采用 c/s 模式,能為客戶提供 網(wǎng)上選擇瀏覽菜品介紹,點菜訂餐服務(wù),并為管理員提供一個服務(wù)平臺實現(xiàn)用戶信息 與顧客訂單的管理,從而提高了服務(wù)的質(zhì)量,本文從系統(tǒng)需求、系統(tǒng)實際、代碼實現(xiàn) 幾個方面介紹了整個軟件的開發(fā)過程,這個系統(tǒng)采用 java、sql server 數(shù)據(jù)庫,并利 用 myeclipse、tomcat、android sdk、adt、avd、ddms 等開發(fā)環(huán)境或者開發(fā)工

3、具。 關(guān)鍵詞關(guān)鍵詞: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 i

4、s 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 mid

5、dle 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

6、 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 provid

7、e 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 deve

8、lopment 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 us

9、ed in it. keywords: android;java;myeclipse;sqlite;sql server 2005 目目 錄錄 第一章第一章 引引 言言.1 1.1 項目背景.1 1.2 項目目的.1 1.3 主要內(nèi)容.2 第二章第二章 系統(tǒng)理論與技術(shù)系統(tǒng)理論與技術(shù).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 系統(tǒng)的四大組件 .4 2.2 java.5 2.3 sql server

10、 2005 和 sqlite 數(shù)據(jù)庫.5 2.4 c/s 模式.6 第三章第三章 系統(tǒng)分析與設(shè)計系統(tǒng)分析與設(shè)計.8 3.1 功能需求.8 3.2 模塊結(jié)構(gòu)與流程.9 3.2.1 客戶端.9 3.2.2 服務(wù)端.10 3.3 數(shù)據(jù)庫設(shè)計.11 3.3.1 數(shù)據(jù)庫表及其結(jié)構(gòu).11 3.3.2 數(shù)據(jù).12 3.3.3 客戶端數(shù)據(jù)庫的連接.13 3.3.4 服務(wù)器數(shù)據(jù)庫的連接.14 3.4 系統(tǒng)結(jié)構(gòu).15 3.4.1 部署圖.15 3.4.2 類圖.15 3.5 執(zhí)行概念.16 第第四四章章 系統(tǒng)實現(xiàn)系統(tǒng)實現(xiàn).18 4.1 android 環(huán)境搭建 .18 4.2 客戶端.19 4.2.1 系統(tǒng)登錄.

11、19 4.2.2 系統(tǒng)注冊.21 4.2.3 瀏覽菜品.23 4.2.4 搜索菜品.25 4.2.5 訂餐.26 4.2.6 結(jié)賬.28 4.3 服務(wù)端.29 4.3.1 系統(tǒng)登錄.29 4.3.2 訂單管理.30 4.3.3 菜品管理.32 4.3.4 會員管理.35 第第五五章章 結(jié)束語結(jié)束語.37 參參 考考 文文 獻獻.38 致致 謝謝.39 第一章第一章 引引 言言 1.1 項目背景項目背景 伴隨著我國市場經(jīng)濟的高度發(fā)展,企業(yè)越來越依賴于市場和客戶,這種依賴關(guān)系 已經(jīng)開始逐步提升到關(guān)乎企業(yè)生存的高度。如何獲得更多客流量,如何通過小的代價 而使商家獲得更大的知名度,這是使企業(yè)得以生存、

12、發(fā)展、壯大的關(guān)鍵。年銷售過億 的眾多電子商務(wù)案例讓人們看到了更多的商機。與應(yīng)用場景相當(dāng)有限的 pc (個人電 腦)相比,生而具備便攜屬性的手機給了電商們更大的想象空間。移動電子商務(wù)由此 產(chǎn)生了。移動電子商務(wù)就是利用手機、pda 及掌上電腦等無線終端進行的 b2b、b2c 或 c2c 的電子商務(wù)。它將因特網(wǎng)、移動通信技術(shù)、短距離通信技術(shù)及其它信息處理技 術(shù)完美的結(jié)合,使人們可以在任何時間、任何地點進行各種商貿(mào)活動,實現(xiàn)隨時隨地、 線上線下的購物與交易、在線電子支付以及各種交易活動、商務(wù)活動、金融活動和相 關(guān)的綜合服務(wù)活動等。 而 android 操作系統(tǒng)憑借著自己開放的平臺允許任何移動終端廠商加

13、入到 android 聯(lián)盟中,從而使得越來越多的用戶傾向于選擇操作系統(tǒng)為 android 的手機品牌。選擇 設(shè)計基于 android 平臺的軟件,毫無疑問能覆蓋更多的群眾, 餐飲業(yè)在電子商務(wù)中還 處于形成的初期,傳統(tǒng)的餐飲業(yè)中,大都是以實際門面形式來進行宣傳和交流。作為 網(wǎng)絡(luò)普及化的社會,這還缺少了一些更為現(xiàn)代化的元素。餐飲業(yè)是一個個性化、多樣 化的服務(wù)業(yè),而電子商務(wù)則最能體現(xiàn)個性化、多樣化服務(wù)的方式。而且現(xiàn)在大部分電 子商務(wù)都體現(xiàn)為向大企業(yè)服務(wù),結(jié)合餐飲這個行業(yè)的特點,最終還發(fā)展為同小區(qū)小店 服務(wù)的模式。以最貼切的方式,最靈便的服務(wù)進入個個網(wǎng)絡(luò)社區(qū),進入人們的生活。 1.21.2 項目目的項

14、目目的 如今宅男宅女日益增加,很多餐飲店都提供外賣服務(wù),傳統(tǒng)的外賣服務(wù)需要客戶 給商家打電話并報出地址,商家那邊也需要記錄下客戶的信息,才能將外賣準(zhǔn)確的送 達,但在這之間都是人在操作,難免會出現(xiàn)偏差和遺漏為客戶或者商家?guī)頁p失。如 今 3g 網(wǎng)絡(luò)覆蓋范圍越來越廣,android 手機也占領(lǐng)了手機行業(yè)的大頭,那么我們可以 考慮做一個 android 的應(yīng)用來方便商家和客戶,讓出錯率達到最低。用戶要點餐的時 候只需手機上網(wǎng)點一下菜單就能吃到自己喜歡吃的菜品,這里面蘊含了很大的商機, 完全能夠有效的提高商家的營業(yè)額,基于以上因素,所以提出了這樣一個基于 android 的網(wǎng)上訂餐系統(tǒng)。 本項目的目的

15、是開發(fā)一個可以讓用戶在手機上操作的客戶端,然后與服務(wù)器連接 進行數(shù)據(jù)交互,來實現(xiàn)網(wǎng)上訂餐的流程??蛻舳诵枰獙崿F(xiàn)瀏覽菜品,點菜,下訂單, 搜索等功能。服務(wù)器端需實現(xiàn)添加、刪除、修改菜品、對訂單的處理,以及對會員的 管理等功能。 本項目是一款基于 android 手機平臺的訂餐系統(tǒng),使擁有 android 手機的用戶生活 更加方便快捷,使得手機顯得更生動靈活化,與人們更為接近,讓手機主人隨時隨地 都能吃到自己喜歡的菜品。使人們的生活更加多樣化。也使設(shè)計者更加熟練 android 的技術(shù)和其他在市場上的特點。 1.31.3 主要內(nèi)容主要內(nèi)容 通過對實際情況的調(diào)研,本系統(tǒng)大致可分為三個部分,即手機客戶

16、端、電腦服務(wù) 器端和圖形化界面工具。系統(tǒng)采用 http 協(xié)議來進行數(shù)據(jù)傳輸。采用 c/s 結(jié)構(gòu),客戶 端為基于 android 操作系統(tǒng)平臺的智能手機,主要的業(yè)務(wù)邏輯則服務(wù)器端來實現(xiàn),數(shù) 據(jù)存儲在數(shù)據(jù)庫服務(wù)器??蛻舳酥饕獙崿F(xiàn)位置服務(wù),商品展示,會員注冊及登錄,購 物車,商品搜索和個人信息等功能,服務(wù)器端主要是完成數(shù)據(jù)交互和數(shù)據(jù)邏輯處理, 而圖形界面化工具則是負責(zé)商品、訂單等的增刪改查。 為了一步步實現(xiàn)確定的功能,本論文主要內(nèi)容安排如下: 第一章:引言(介紹課題研究的背景和目的) 第二章:系統(tǒng)理論與技術(shù)(在本項目中設(shè)計到的技術(shù)簡介) 第三章:系統(tǒng)分析與設(shè)計(需求分析,數(shù)據(jù)庫的分析與設(shè)計以及系統(tǒng)結(jié)

17、構(gòu)的設(shè)計) 第四章:系統(tǒng)實現(xiàn)(根據(jù)需求分析來實現(xiàn)系統(tǒng)的各個模塊功能,使客戶端與服務(wù) 器,服務(wù)器與數(shù)據(jù)庫能正常數(shù)據(jù)交互。這部分主要搭建開發(fā)環(huán)境,編寫代碼,測試, 運行) 第五章:結(jié)束語(對本項目做一個項目總結(jié)) 第二章第二章 系統(tǒng)理論與技術(shù)系統(tǒng)理論與技術(shù) 2.1 android 2.1.1 android 簡介簡介 android 一詞的本義指“機器人” ,同時也是 google 于 2007 年 11 月 5 日宣布的 基于 linux 平臺的開源手機操作系統(tǒng)的名稱,該平臺由操作系統(tǒng)、中間件、用戶界面 和應(yīng)用軟件組成,號稱是首個為移動終端打造的真正開放和完整的移動軟件。 android 是基于

18、 linux 內(nèi)核的軟件平臺和操作系統(tǒng),早期由 google 開發(fā)(在華注 冊商標(biāo)名為“安致” ) ,后由開放手機聯(lián)盟(open handset alliance)開發(fā)。它采用了軟 件堆層(software stack,又名以軟件疊層)的架構(gòu),主要分為三部分。低層以 linux 內(nèi) 核工作為基礎(chǔ),只提供基本功能;其他的應(yīng)用軟件則由各公司自行開發(fā),以 java 作為 編寫程序的一部分。另外,為了推廣此技術(shù),google 和其它幾十個手機公司建立了開 放手機聯(lián)盟。android 在未公開之前常被傳聞為 google 電話或 gphone。大多傳聞?wù)J為 google 開發(fā)的是自己的手機電話產(chǎn)品,而不

19、是一套軟件平臺。到了 2010 年 1 月, google 開始發(fā)表自家品牌手機電話的 nexus one,目前最新 sdk 版本為 android 4.0.3。 2.1.2 android features 特性特性 android 系統(tǒng)有如下的幾大特性1: 應(yīng)用程序框架 支持組件的重用與替換 dalvik 虛擬機 專門為移動設(shè)備做了優(yōu)化 內(nèi)部集成瀏覽器 該瀏覽器基于開源的 webkit 引擎 優(yōu)化的圖形庫 包括 2d 和 3d 圖形庫,3d 圖形庫基于 opengl es sqlite 用作結(jié)構(gòu)化的數(shù)據(jù)存儲 多媒體支持 包括常見的音頻、視頻和靜態(tài)印象文件格式(如 mpeg4, mp3, a

20、ac, amr, jpg, png) gsm 電話(依賴于硬件) 藍牙 bluetooth, edge, 3g, and wifi (依賴于硬件) 照相機,gps,指南針,和加速度計 (依賴于硬件) 豐富的開發(fā)環(huán)境 包括設(shè)備模擬器,調(diào)試工具,內(nèi)存及性能分析圖表,和 eclipse 集成開發(fā)環(huán)境插件 2.1.3 android 基本框架(基本框架(android architecture) 圖圖 2.1 android architecture 2.1.4 android 系統(tǒng)的四大組件系統(tǒng)的四大組件 在 android 系統(tǒng)中,為我們提供了四大基本組件,每個組件是一個視圖,但是有 些是可見的,

21、有些是不可見的視圖,像 activity,contentprovider 是可見的視圖, service 和 broadcastreceiver 是不可見的,它們只在系統(tǒng)的后臺運行。下面分別介紹四 大組件3: (1)activity 簡介 在 android 系統(tǒng)中 activity 提供可視化的用戶界面,一個 android 應(yīng)用通常由多個 activity 組成。多個 activity 組成了 activity 棧(stack) ,當(dāng)前活動的 activity 處于棧頂。 activity 有自己的生命周期,由 android 系統(tǒng)來控制。 (2)service 簡介 顧名思義 servi

22、ce 就是運行在后臺的一種服務(wù)程序,一般很少和用戶交互,因此沒 有可視化界面定義一個 service 類比較簡單,只要繼承 service 類,實現(xiàn)其生命周期中 的方法就可以了。一個定義好的 service 必須在 androidmanifest.xml 配置文件注冊,通 過元素聲明才能使用.service 有自己的生命周期,我們可以調(diào)用 startservice() 啟動一個 service 或者 bindservice()方法來綁定一個存在的 service (3)broadcast receiver 簡介 broadcast receiver 顧名思義廣播接收器,它和事件處理機制類似,只

23、不過事件處 理機制是程序組件級別的(例如,某個按鈕的單擊事件) ,而廣播事件處理機制是系統(tǒng) 級別的。到目前為止我們可以使用 intent 來啟動一個程序組件,我們還可以通過使用 sendbroadcast()方法來發(fā)起一個系統(tǒng)級別的事件廣播來傳遞消息。我們可以在你的應(yīng)用 程序中實現(xiàn) broadcast receiver 來監(jiān)聽和響應(yīng)這些廣播的 intent (4)contentprovider 簡介 content provider 用來保存和檢索數(shù)據(jù),并且使應(yīng)用程序之間相互訪問數(shù)據(jù)成為可 能。它是跨應(yīng)用程序共享數(shù)據(jù)的唯一方法。 android 為常用的數(shù)據(jù)類型(如:音視頻、圖片和聯(lián)系方式等)

24、提供了大量的 content provider。它們被定義在 vider 包下面。通過這樣定義好的 contentprovider 我們可以方便的進行數(shù)據(jù)操作。當(dāng)然我們必須擁有適當(dāng)?shù)臋?quán)限。我們 也可以自己來定 contentprovider 共享我們的數(shù)據(jù),方便用戶的訪問。 2.2 java java 是一種可以撰寫跨平臺應(yīng)用軟件的面向?qū)ο蟮某绦蛟O(shè)計語言,是由 sun microsystems 公司于 1995 年 5 月推出的 java 程序設(shè)計語言和 java 平臺(即 javase, javaee, javame)的總稱。java 技術(shù)具有卓越的通用性、高效性、平臺

25、移植性和安全 性,廣泛應(yīng)用于個人 pc、數(shù)據(jù)中心、游戲控制臺、科學(xué)超級計算機、移動電話和互聯(lián) 網(wǎng),同時擁有全球最大的開發(fā)者專業(yè)社群。在全球云計算和移動互聯(lián)網(wǎng)的產(chǎn)業(yè)環(huán)境下, java 更具備了顯著優(yōu)勢和廣闊前景。 eclipse 是一個開放源代碼的、基于 java 的可擴展開發(fā)平臺。就其本身而言,它只 是一個框架和一組服務(wù),用于通過插件組件構(gòu)建開發(fā)環(huán)境。幸運的是,eclipse 附帶了 一個標(biāo)準(zhǔn)的插件集,包括 java 開發(fā)工具(java development kit,jdk) 。 雖然大多數(shù)用戶很樂于將 eclipse 當(dāng)作 java 集成開發(fā)環(huán)境(ide)來使用,但 eclipse 的目標(biāo)

26、卻不僅限于此。eclipse 還包括插件開發(fā)環(huán)境(plug-in development environment,pde) ,這個組件主要針對希望擴展 eclipse 的軟件開發(fā)人員,因為它允 許他們構(gòu)建與 eclipse 環(huán)境無縫集成的工具。由于 eclipse 中的每樣?xùn)|西都是插件, 對于給 eclipse 提供插件,以及給用戶提供一致和統(tǒng)一的集成開發(fā)環(huán)境而言,所有工 具開發(fā)人員都具有同等的發(fā)揮場所。 這種平等和一致性并不僅限于 java 開發(fā)工具。盡管 eclipse 是使用 java 語言開 發(fā)的,但它的用途并不限于 java 語言;例如,支持諸如 c/c+ 和 cobol 等編程 語

27、言的插件已經(jīng)可用,或預(yù)計將會推出。eclipse 框架還可用來作為與軟件開發(fā)無關(guān)的 其他應(yīng)用程序類型的基礎(chǔ),比如內(nèi)容管理系統(tǒng)。 基于 eclipse 的應(yīng)用程序的一個突出例子是 ibm rational software architect,它 構(gòu)成了 ibm java 開發(fā)工具系列的基礎(chǔ)7。 2.3 sql server 2005 和和 sqlite 數(shù)據(jù)庫數(shù)據(jù)庫 sql server 是一個關(guān)系數(shù)據(jù)庫管理系統(tǒng)。它最初是由 microsoft sybase 和 ashton- tate 三家公司共同開發(fā)的,于 1988 年推出了第一個 os/2 版本。在 windows nt 推出 后,mi

28、crosoft 與 sybase 在 sql server 的開發(fā)上就分道揚鑣了,microsoft 將 sql server 移植到 windows nt 系統(tǒng)上,專注于開發(fā)推廣 sql server 的 windows nt 版本。 sybase 則較專注于 sql server 在 unix 操作系統(tǒng)上的應(yīng) sql server 安裝界面用。 sqlite,是一款輕型的數(shù)據(jù)庫,是遵守 acid 的關(guān)聯(lián)式數(shù)據(jù)庫管理系統(tǒng),它的設(shè) 計目標(biāo)是嵌入式的,而且目前已經(jīng)在很多嵌入式產(chǎn)品中使用了它,它占用資源非常的 低,在嵌入式設(shè)備中,可能只需要幾百 k 的內(nèi)存就夠了。它能夠支持 windows/lin

29、ux/unix 等等主流的操作系統(tǒng),同時能夠跟很多程序語言相結(jié)合,比如 tcl、c#、php、java 等,還有 odbc 接口,同樣比起 mysql、postgresql 這兩款開源 世界著名的數(shù)據(jù)庫管理系統(tǒng)來講,它的處理速度比他們都快。sqlite 第一個 alpha 版 本誕生于 2000 年 5 月. 至今已經(jīng)有 10 個年頭,sqlite 也迎來了一個版本 sqlite 3 已 經(jīng)發(fā)布。 2.4 c/s 模式模式 在網(wǎng)絡(luò)連接模式中,除對等網(wǎng)外,還有另一種形式的網(wǎng)絡(luò),即客戶機/服務(wù)器網(wǎng), client/server。在客戶機/服務(wù)器網(wǎng)絡(luò)中,服務(wù)器是網(wǎng)絡(luò)的核心,而客戶機是網(wǎng)絡(luò)的基礎(chǔ), 客

30、戶機依靠服務(wù)器獲得所需要的網(wǎng)絡(luò)資源,而服務(wù)器為客戶機提供網(wǎng)絡(luò)必須的資源。 這里客戶和服務(wù)器都是指通信中所涉及的兩個應(yīng)用進程(軟件) 。使用計算機的人 是計算機的“用戶” (user)而不是“客戶” (client) 。但在許多國外文獻中,也經(jīng)常把 運行客戶程序的機器稱為 client(這種情況下也可把 client 譯為“客戶機” ) ,把運行服 務(wù)器程序的機器稱為 server。所以有時要根據(jù)上下文判斷 client 與 server 是指軟件還是 硬件。 它是軟件系統(tǒng)體系結(jié)構(gòu),通過它可以充分利用兩端硬件環(huán)境的優(yōu)勢,將任務(wù)合理 分配到 client 端和 server 端來實現(xiàn),降低了系統(tǒng)的

31、通訊開銷。目前大多數(shù)應(yīng)用軟件系 統(tǒng)都是 client/server 形式的兩層結(jié)構(gòu),由于現(xiàn)在的軟件應(yīng)用系統(tǒng)正在向分布式的 web 應(yīng)用發(fā)展,web 和 client/server 應(yīng)用都可以進行同樣的業(yè)務(wù)處理,應(yīng)用不同的模塊共 享邏輯組件;因此,內(nèi)部的和外部的用戶都可以訪問新的和現(xiàn)有的應(yīng)用系統(tǒng),通過現(xiàn) 有應(yīng)用系統(tǒng)中的邏輯可以擴展出新的應(yīng)用系統(tǒng)。這也就是目前應(yīng)用系統(tǒng)的發(fā)展方向。 c/s 架構(gòu)軟件的優(yōu)勢和劣勢9: 應(yīng)用服務(wù)器運行數(shù)據(jù)負荷較輕。最簡單的 c/s 體系結(jié)構(gòu)的數(shù)據(jù)庫應(yīng)用由兩部分組 成,即客戶應(yīng)用程序和數(shù)據(jù)庫服務(wù)器程序。二者可分別稱為前臺程序與后臺程序。運 行數(shù)據(jù)庫服務(wù)器程序的機器,也稱為

32、應(yīng)用服務(wù)器。一旦服務(wù)器程序被啟動,就隨時等 待響應(yīng)客戶程序發(fā)來的請求;客戶應(yīng)用程序運行在用戶自己的電腦上,對應(yīng)于數(shù)據(jù)庫 服務(wù)器,可稱為客戶電腦,當(dāng)需要對數(shù)據(jù)庫中的數(shù)據(jù)進行任何操作時,客戶程序就自 動地尋找服務(wù)器程序,并向其發(fā)出請求,服務(wù)器程序根據(jù)預(yù)定的規(guī)則作出應(yīng)答,送回 結(jié)果,應(yīng)用服務(wù)器運行數(shù)據(jù)負荷較輕。 數(shù)據(jù)的儲存管理功能較為透明。在數(shù)據(jù)庫應(yīng)用中,數(shù)據(jù)的儲存管理功能,是由服 務(wù)器程序和客戶應(yīng)用程序分別獨立進行的,前臺應(yīng)用可以違反的規(guī)則,并且通常把那 些不同的(不管是已知還是未知的)運行數(shù)據(jù),在服務(wù)器程序中不集中實現(xiàn),例如訪 問者的權(quán)限,編號可以重復(fù)、必須有客戶才能建立定單這樣的規(guī)則。所有這些

33、,對于 工作在前臺程序上的最終用戶,是“透明”的,他們無須過問(通常也無法干涉)背 后的過程,就可以完成自己的一切工作。在客戶服務(wù)器架構(gòu)的應(yīng)用中,前臺程序不是 非?!笆菪 ?,麻煩的事情都交給了服務(wù)器和網(wǎng)絡(luò)。在 c/s 體系的下,數(shù)據(jù)庫不能真正 成為公共、專業(yè)化的倉庫,它受到獨立的專門管理。 c/s 架構(gòu)的劣勢是高昂的維護成本且投資大。首先,采用 c/s 架構(gòu),要選擇適當(dāng)?shù)?數(shù)據(jù)庫平臺來實現(xiàn)數(shù)據(jù)庫數(shù)據(jù)的真正“統(tǒng)一” ,使分布于兩地的數(shù)據(jù)同步完全交由數(shù)據(jù) 庫系統(tǒng)去管理,但邏輯上兩地的操作者要直接訪問同一個數(shù)據(jù)庫才能有效實現(xiàn),有這 樣一些問題,如果需要建立“實時”的數(shù)據(jù)同步,就必須在兩地間建立實時

34、的通訊連 接,保持兩地的數(shù)據(jù)庫服務(wù)器在線運行,網(wǎng)絡(luò)管理工作人員既要對服務(wù)器維護管理, 又要對客戶端維護和管理,這需要高昂的投資和復(fù)雜的技術(shù)支持,維護成本很高,維 護任務(wù)量大。 (4)傳統(tǒng)的 c/s 結(jié)構(gòu)的軟件需要針對不同的操作系統(tǒng)系統(tǒng)開發(fā)不同版本的軟件, 由于產(chǎn)品的更新?lián)Q代十分快,代價高和低效率已經(jīng)不適應(yīng)工作需要。在 java 這樣的 跨平臺語言出現(xiàn)之后,b/s 架構(gòu)更是猛烈沖擊 c/s,并對其形成威脅和挑戰(zhàn)。 第三章第三章 系統(tǒng)分析與設(shè)計系統(tǒng)分析與設(shè)計 3.1 功能需求功能需求 隨著 3g 時代的到來,手機應(yīng)用越來越普遍,加之國民手機持有量更是爆炸式增長。 為了方便 android 手機用戶

35、能隨時隨地點到自己喜歡的菜品,提出一種操作簡便,功 能齊全,占用資源少,能為用戶節(jié)約流量的的網(wǎng)上訂餐應(yīng)用,于是提出本系統(tǒng)的主要 功能。 需求界面如下: 客戶端: 1、登陸、注冊界面 2、顯示菜品界面 3、搜索菜品界面(按菜品名稱、種類、店鋪名稱進行搜索) 4、購物車界面 5、個人信息界面 6、菜品詳情界面 服務(wù)器端: 1、登陸界面 2、訂單管理、菜品管理、會員管理界面 需求實現(xiàn)功能如下: 客戶端: 1、實現(xiàn)客戶端與服務(wù)器之間的連接 2、實現(xiàn)登陸、注冊功能 3、實現(xiàn)登陸后能瀏覽到服務(wù)器數(shù)據(jù),并對數(shù)據(jù)進行一系列的操作 4、能把菜品加入到購物車,并結(jié)算生成訂單 5、把生成的訂單信息傳回服務(wù)器端 服務(wù)

36、器端: 1、實現(xiàn)管理員登陸 2、實現(xiàn)添加、刪除、修改菜品信息 3、實現(xiàn)對客戶端傳過來的訂單進行處理 4、實現(xiàn)添加、刪除會員列表 功能模塊圖如 3.1 所示: 圖圖 3.1 系統(tǒng)功能模塊圖系統(tǒng)功能模塊圖 3.2 模塊結(jié)構(gòu)與流程模塊結(jié)構(gòu)與流程 3.2.1 客戶端客戶端 表表 3.1 客戶端概要設(shè)計表客戶端概要設(shè)計表 客戶端模塊客戶端模塊簡要說明簡要說明 登陸模塊在連接上服務(wù)器的前提下登陸成功 注冊模塊在連接上服務(wù)器的前提下注冊成功 瀏覽菜品模塊從服務(wù)器中讀取數(shù)據(jù),并把數(shù)據(jù)封裝顯示在菜品列表中 菜品詳情模塊點擊菜品進入到菜品的詳細介紹和訂餐服務(wù)頁面 搜索模塊按照用戶選擇的條件從手機數(shù)據(jù)庫中搜索菜品

37、購物車模塊當(dāng)用戶定了菜品之后,所有訂單信息都顯示在這個模塊中, 并且點擊結(jié)算按鈕生成訂單傳送回服務(wù)器 個人信息模塊顯示用戶的個人信息 圖圖 3.2 客戶端流程圖客戶端流程圖 3.2.2 服務(wù)端服務(wù)端 表表 3.2 服務(wù)器端概要設(shè)計表服務(wù)器端概要設(shè)計表 服務(wù)器端模塊服務(wù)器端模塊簡要說明簡要說明 登陸模塊提供管理員登陸 訂單信息模塊顯示現(xiàn)有的訂單信息并給與處理按鈕 菜品添加刪除修改模塊對要顯示在客戶端的菜品進行添加刪除修改操作 會員管理模塊對會員進行添加和刪除以及查看信息 圖圖 3.3 服務(wù)器流程圖服務(wù)器流程圖 3.3 數(shù)據(jù)庫設(shè)計數(shù)據(jù)庫設(shè)計 數(shù)據(jù)庫結(jié)構(gòu)組織和數(shù)據(jù)庫文件設(shè)計要根據(jù)不同用途,使用要求等

38、,來決定數(shù)據(jù)庫 的整體組織形式等一系列問題。 數(shù)據(jù)庫,顧名思義,是存放數(shù)據(jù)的倉庫,只不過這個倉庫是在計算機存儲設(shè)備上 的,而且數(shù)據(jù)是按一定格式存放。數(shù)據(jù)庫中的數(shù)據(jù)按一定模型組織描述和存儲。具有 較小的重復(fù)度,較高的數(shù)據(jù)獨立性和易擴張性,并且可以被一定范圍內(nèi)的各種用戶共 享。在涉及數(shù)據(jù)庫的軟件開發(fā)中,需要根據(jù)有待解決的問題性質(zhì),規(guī)模,以及所采用 的前端程序創(chuàng)建工具等。做出合適的數(shù)據(jù)庫類型選擇。 在該項目中建立了兩個數(shù)據(jù)庫,客戶端和服務(wù)器各一個,用這種設(shè)計方式主要是 為用戶減少許多不必要的流量浪費,如果只創(chuàng)建一個服務(wù)器數(shù)據(jù)庫的話,用戶每次連 接上服務(wù)器時都會將服務(wù)器的所有資源全部接受一遍,但是事實

39、上該項目并不需要實 時的更新數(shù)據(jù),因為有些菜品的信息可能很久都不會有變動,所以考慮在客戶端也創(chuàng) 建一個數(shù)據(jù)庫把服務(wù)器端發(fā)送過來的數(shù)據(jù)存儲在本地數(shù)據(jù)庫中,當(dāng)服務(wù)器有更新時只 需要傳遞改變的數(shù)據(jù)就可以實現(xiàn)更新。 3.3.1 數(shù)據(jù)庫表及其結(jié)構(gòu)數(shù)據(jù)庫表及其結(jié)構(gòu) 服務(wù)器數(shù)據(jù)庫(sql server 2005) admin 表:管理員編號,用戶名,密碼,權(quán)限。 baseproducts 表:菜品編號,菜品名字,菜品種類,菜品價格,菜品圖片。 detailorders 表:訂單編號,詳細編號,菜品編號,數(shù)量。 detailproducts 表:編號,菜品編號,菜品價格,菜品狀態(tài),折扣,菜品描述。 membe

40、r 表:會員編號,會員名字,會員密碼,會員性別,會員電話,會員地址, 會員積分,會員金錢。 orders 表:訂單編號,訂單生成時間,會員編號,訂單狀態(tài)。 客戶端數(shù)據(jù)庫(sqlite) shoppingrecord 表:訂單編號,詳細編號,菜品編號,數(shù)量。 showedgoods 表:菜品編號,菜品名字,菜品種類,菜品價格,菜品圖片。 3.3.2 數(shù)據(jù)數(shù)據(jù) 系統(tǒng) e-r(實體-聯(lián)系)圖用來描述數(shù)據(jù)關(guān)系模型,可以用來建立數(shù)據(jù)模型。本系 統(tǒng)共有 8 個實體,其關(guān)系如圖 3.4 所示。 圖圖 3.4 全局全局 e-r 圖圖 下面列舉主要實體: 管理員實體(admin)包括管理員編號、管理員姓名(登錄

41、姓名)、登錄密碼、管理 員等級等屬性,如圖 3.5 所示。 管理員編號 管理員姓名 (登錄帳號) 登錄密碼 管理員級別 管理員表 圖圖 3.5 管理員實體屬性圖管理員實體屬性圖 會員實體(member)包括會員編號、會員姓名(登錄帳號)、登錄密碼、管理員性 別,聯(lián)系電話,聯(lián)系地址,會員積分等屬性。如圖 3.6 所示。 會員編號 會員姓名 (登錄帳號) 登錄密碼 會員性別 會員表 聯(lián)系電話 聯(lián)系地址 會員積分 圖圖 3.6 會員實體屬性圖會員實體屬性圖 3.3.3 客戶端數(shù)據(jù)庫的連接客戶端數(shù)據(jù)庫的連接 andorid 數(shù)據(jù)庫存儲的位置在 data/data/databases/目錄下,andro

42、id 是利用 contentprovider 作為內(nèi)容提供商,sqliteopenhelper 數(shù)據(jù)庫幫助類來進行對數(shù) 據(jù)庫的創(chuàng)建和操作。程序中數(shù)據(jù)庫類為 myopenhelper extends sqliteopenhelper(繼承 關(guān)系) ,在此列出連接數(shù)據(jù)庫的代碼: public class myopenhelper extends sqliteopenhelper / 生成表shoppingrecod,用以記錄購買過的商品 private static final string record_table = create table shoppingrecord (oid integ

43、er primary key ,doid integer,bid integer,donum integer); / 生成表showedgoods,用以存儲上次購買過的商品 private static final string goods_table = create table showedgoods (bid integer primary key ,bname varchar,bstyle varchar,bprice float,bpicture varchar); /創(chuàng)建表 public void oncreate(sqlitedatabase db) db.execsql(rec

44、ord_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 服務(wù)器數(shù)據(jù)庫的連接服務(wù)器數(shù)據(jù)庫的連接 服務(wù)器端采用 sql ser

45、ver 2005 來創(chuàng)建數(shù)據(jù)庫,首先得導(dǎo)入 sql2000_2005jdbc.jar 庫 文件,然后在數(shù)據(jù)庫的配置工具中開啟 sql server 服務(wù),接下來就要在 java 代碼中實 現(xiàn)連接數(shù)據(jù)庫的功能了,代碼如下: public static connection getcon() connection con = null; if (!isinitialized) return con; try class.forname(prop.getproperty(classname); /連接數(shù)據(jù)庫語句,url user pwd都在配置文件sql.ini中 con = drivermanag

46、er.getconnection(prop.getproperty(url), prop .getproperty(user), prop.getproperty(pwd); catch (exception e) e.printstacktrace(); return con; sql.ini 配置文件內(nèi)容: classname=com.microsoft.sqlserver.jdbc.sqlserverdriver url=jdbc:sqlserver:/localhost:1433;databasename=dinner user=sa pwd=123 3.4 系統(tǒng)結(jié)構(gòu)系統(tǒng)結(jié)構(gòu) 本系統(tǒng)采

47、用 http 協(xié)議來進行數(shù)據(jù)傳輸。采用 c/s 結(jié)構(gòu),客戶端為基于 android 操作系統(tǒng)平臺的智能手機,主要的業(yè)務(wù)邏輯則服務(wù)器端來實現(xiàn),數(shù)據(jù)存儲在數(shù)據(jù)庫服 務(wù)器。 3.4.1 部署圖部署圖 系統(tǒng)部署如圖 3.7 所示,客戶端采用基于 android 操作系統(tǒng)平臺的智能手機,服務(wù) 器端包括服務(wù)器、圖形界面化工具和數(shù)據(jù)庫服務(wù)器,主要處理業(yè)務(wù)邏輯和對數(shù)據(jù)的增 刪改查。 圖圖 3.7 系統(tǒng)部署圖系統(tǒng)部署圖 3.4.2 類圖類圖 根據(jù)已建立的用例圖確定要建立的對象類并確定屬性和操作。通過檢查類的定義, 分析問題的需求和運用該領(lǐng)域知識來確定類的屬性。根據(jù)系統(tǒng)功能需求和系統(tǒng)設(shè)計需 要確定類的操作,本系統(tǒng)

48、有 6 個實體類,分別為管理員實體類(admin) 、會員實體類 (member) 、訂單實體類(orders) 、訂單詳情實體類(detailorders) 、商品實體類 (products) 、商品詳情實體類(detailproducts) ,如圖 3.8 所示。 +getaid() : int +setaid() +getaname() : string +setaname() +getacode() : string +setacode() -aid : int -aname : string -acode : string a am mi in n +getbid() : int +

49、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

50、() : 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() : i

51、nt +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() : str

52、ing +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

53、 +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 執(zhí)行概念執(zhí)行概念 本系統(tǒng)時序圖如圖 3.9 所示。 圖圖 3.9 系統(tǒng)時序圖系統(tǒng)時序圖 1、客戶端發(fā)送請求給服務(wù)器,服務(wù)器的后臺 servlet 負責(zé)處理數(shù)據(jù)。 2、服務(wù)器業(yè)務(wù)邏輯處理會調(diào)用 dao,進行數(shù)據(jù)處理。 3、調(diào)用實體類,把數(shù)據(jù)保存到數(shù)據(jù)庫 db 中。 4、dao 返回結(jié)果給 servlet。 5、servlet 把結(jié)果返回給客戶端。 第第四四章章 系統(tǒng)實現(xiàn)系統(tǒng)實現(xiàn) 4.1 android 環(huán)境搭建環(huán)境搭建 任何事物要運行,都要有它的環(huán)境,android 也有它的

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論