軟件架構(gòu)設(shè)計文檔_第1頁
軟件架構(gòu)設(shè)計文檔_第2頁
軟件架構(gòu)設(shè)計文檔_第3頁
軟件架構(gòu)設(shè)計文檔_第4頁
軟件架構(gòu)設(shè)計文檔_第5頁
已閱讀5頁,還剩19頁未讀 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、 .密 級:內(nèi)部公開文檔編號:1002 版 本 號:V3.0測測(基于安卓平臺的測評軟件)軟件架構(gòu)設(shè)計文檔文件狀態(tài): 草稿 正在修改 正式發(fā)布文件標(biāo)識:開發(fā)組當(dāng)前版本:V 3.0作 者:張放、張鈺若、陳國忠完成日期:2014-5-26中國石油大學(xué)(華東)計算機與通信工程學(xué)院 天師團開發(fā)團隊 .頁腳. 項目名稱:測測基于安卓平臺測評軟件 版本: <V3.0>軟件架構(gòu)設(shè)計文檔 日期: <2014/5/26>修訂歷史記錄日期版本說明作者2014.5.13<V3.0>對軟件架構(gòu)進行初始設(shè)計陳國忠,張放2014.5.23<V3.0>對軟件架構(gòu)進行初始設(shè)計進

2、行修正陳國忠,張放2014.5.26<V3.0>確定軟件架構(gòu)陳國忠,張放目錄1文檔介紹41.1文檔目的41.2文檔范圍41.3讀者對象41.4參考文獻(xiàn)42架構(gòu)設(shè)計思想53架構(gòu)體系描述54 views54.1 Module structs54.2 Component & Connector(組件-連接器視圖)74.3 Allocation85 Mappping between views85.1 Class map to Package85.2 Package map to Allocation86 Utility tree96.1 Quality attribute sce

3、nario (質(zhì)量屬性場景)96.2 Utility tree116.3 Tactics127. Architecture137.1 WebService137.2 MVC (Model View Controller)167.3 Publish/Subscrib181文檔介紹1.1文檔目的本文檔是對于測測軟件系統(tǒng)進行詳細(xì)設(shè)計和編碼的重要依據(jù)。對該軟件的整個系統(tǒng)的結(jié)構(gòu)關(guān)系進行了詳細(xì)描述,闡述了系統(tǒng)的總體框架,包括物理、邏輯結(jié)構(gòu),說明了體系結(jié)構(gòu)所采取的設(shè)計策略和所有技術(shù),并對相關(guān)內(nèi)容做出了統(tǒng)一的規(guī)定。為今后的設(shè)計、編碼、測試都提供了可以參考的模版并且提高效率,使整個開發(fā)過程做到資源利用最大化,減

4、少由于需求變更而修改的時間,大大的降低了成本,節(jié)約了時間,也使得客戶更加的滿意。1.2文檔范圍本文檔包含以下幾個部分:1、 架構(gòu)設(shè)計思想2、 架構(gòu)體系描述3、 系統(tǒng)模塊化分4、 系統(tǒng)模塊描述5、 模塊接口設(shè)計1.3讀者對象本文檔主要讀者包括:1、本系統(tǒng)的設(shè)計人員:包括模塊設(shè)計人員(理解用戶需求,在設(shè)計時把握用戶需求)。2、本系統(tǒng)的系統(tǒng)開發(fā)人員:編碼人員(了解用戶需求,為編碼提供模版)。3、本系統(tǒng)的測試人員(了解用戶需求,為測試提供參考)。4、 客戶(檢查是否滿足要求)。1.4參考文獻(xiàn)軟件工程講義測測需求規(guī)格說明書2架構(gòu)設(shè)計思想為了降低系統(tǒng)耦合度,增加系統(tǒng)內(nèi)聚性,在需求發(fā)生更改時能在較短的時間內(nèi)

5、對系統(tǒng)做出修改,并重新投入使用,我們決定以分層體系架構(gòu)風(fēng)格作為整個系統(tǒng)的體系風(fēng)格,嚴(yán)格按照一定的規(guī)則來進行接口設(shè)計,并以之為根據(jù)進行詳細(xì)設(shè)計。分為數(shù)據(jù)層、業(yè)務(wù)邏輯層、表示層。3架構(gòu)體系描述整個系統(tǒng)頂層架構(gòu)采用分層的風(fēng)格,整個系統(tǒng)的體系結(jié)構(gòu)非常清晰,使得后期易于詳細(xì)設(shè)計、編碼、維護以及適應(yīng)需求變更。通過分層,定義出層與層之間的接口,使得在更加規(guī)范的同時擁有更為多臺花的接口描述,使得層與層之間的耦合度降低,增強了模塊的服用型和可擴展性以及可維護性。同時,分層也有益于項目模塊的劃分以及任務(wù)的分配,通過明確清晰的接口,降低集成的難度,提高效率。4 views4.1 Module structs(1)具

6、有三層結(jié)構(gòu)的測測軟件包圖:圖4.1.1領(lǐng)域模型圖(2)測測軟件領(lǐng)域模型圖:圖4.1.2領(lǐng)域模型圖(3)測測軟件類圖:圖4.1.3類圖(4)測測系統(tǒng)用例圖:圖4.1.4系統(tǒng)用例圖4.2 Component & Connector(組件-連接器視圖)(1)性格測試順序圖:圖4.2.1性格測試順序圖4.3 Allocation(1)測測軟件部署圖:圖4.3.1部署圖5 Mappping between views5.1 Class map to Package(1)類圖中的TTestController類、UserContainer類、TendencyContainer類對應(yīng)于包圖中表示層的

7、UI包。(2)類圖中的TTest類、User類、Test類、InteligentTest類、CharactTest類、Tendency類、Daily Trend類、ServiceController類對應(yīng)于包圖中業(yè)務(wù)邏輯層的測試模塊包和評價模塊包。(3)類圖中的DataHelp類、I/OEventStream類、QuestionBase類、UserInfo類對應(yīng)于包圖中數(shù)據(jù)層的題庫管理包和用戶管理包。5.2 Package map to Allocation(1)包圖中的UI包、測試模塊包、評價模塊包位于部署圖中的C/S客戶端。(2)包圖中的題庫管理包和用戶管理包位于部署圖中的客戶端數(shù)據(jù)庫和數(shù)

8、據(jù)庫服務(wù)器。6 Utility tree6.1 Quality attribute scenario (質(zhì)量屬性場景)(1)可用性:情節(jié)描述:用戶在進行性格測試時,點擊無反應(yīng)。相關(guān)質(zhì)量屬性: 可用性刺激源:進行性格測試的用戶刺激:用戶點擊性格測試環(huán)境:正常運行狀態(tài)制品:性格測試功能模塊反應(yīng):提示程序無響應(yīng),需重啟軟件反應(yīng)度量:在2s內(nèi)給出提示策略:異常檢測異常處理(2)互操作性:情節(jié)描述:用戶完成測試,進行提交,數(shù)據(jù)庫返回測試結(jié)果。相關(guān)質(zhì)量屬性: 互操作性刺激源:進行測試的用戶刺激:用戶完成測試,進行提交環(huán)境:正常運行狀態(tài)制品:數(shù)據(jù)庫、測試模塊反應(yīng):顯示測試結(jié)果反應(yīng)度量:在1s內(nèi)顯示測試結(jié)果。

9、策略:發(fā)現(xiàn)服務(wù)(3)可修改性:情節(jié)描述:開發(fā)人員更新數(shù)據(jù)庫相關(guān)質(zhì)量屬性:可修改性刺激源:開發(fā)人員刺激: 開發(fā)人員更新數(shù)據(jù)庫數(shù)據(jù)環(huán)境:正常運行狀態(tài)制品:數(shù)據(jù)庫,反應(yīng):顯示測試結(jié)果反應(yīng)度量:在1s內(nèi)顯示測試結(jié)果。策略: 減少耦合提高內(nèi)聚封裝(4)性能:情節(jié)描述:用戶完成測試,提交,數(shù)據(jù)庫返回測試結(jié)果。相關(guān)質(zhì)量屬性:性能刺激源:進行測試的用戶刺激: 開發(fā)人員更新數(shù)據(jù)庫數(shù)據(jù)環(huán)境:用戶完成測試,提交。制品:正常運行狀態(tài)反應(yīng):顯示測試結(jié)果反應(yīng)度量:在1s內(nèi)顯示測試結(jié)果。策略:同時計算(5)安全性:情節(jié)描述:黑客侵入數(shù)據(jù)庫盜取用戶密碼。相關(guān)質(zhì)量屬性:安全性刺激源:黑客刺激: 黑客非法侵入數(shù)據(jù)庫環(huán)境:正常運行

10、狀態(tài)制品:數(shù)據(jù)庫安全保護模塊反應(yīng):阻止黑客獲取數(shù)據(jù)庫內(nèi)容反應(yīng)度量:在1s內(nèi)進行攔截策略: 拒絕攻擊反應(yīng)攻擊 確定用戶(6)可測試性情節(jié)描述:在開發(fā)階段開發(fā)者對自己的模塊進行單元測試。相關(guān)質(zhì)量屬性:可測試性刺激源:開發(fā)人員刺激: 對已完成的子系統(tǒng)進行測試環(huán)境:系統(tǒng)開發(fā)中制品:被測代碼段反應(yīng):顯示代碼出錯情況反應(yīng)度量:執(zhí)行測試的時間不能超過2s策略: 限制復(fù)雜性(7)易用性情節(jié)描述:用戶在完成某一測試后重新進行測試相關(guān)質(zhì)量屬性:易用性刺激源:欲進行重新測試的用戶刺激: 用戶點擊重新測試環(huán)境:軟件正常運行環(huán)境制品:相應(yīng)測試功能模塊反應(yīng):進入該測試,顯示測試題反應(yīng)度量:重新跳轉(zhuǎn)到相應(yīng)測試界面的時間不超

11、過2s。6.2 Utility tree質(zhì)量屬性屬性細(xì)化場景 ASR性能題庫更新響應(yīng)時間在系統(tǒng)處于正常運行時,為對題庫更新做出響應(yīng),用戶更新題庫要在3分鐘內(nèi)完成(H,M)可維護性軟件更新軟件產(chǎn)商發(fā)布了一個新版本,必須盡快安裝該版本。(H,L)維護人員發(fā)現(xiàn)了軟件的缺陷,修復(fù)該bug。(H,M)安全性機密性完整性非維護人員侵入數(shù)據(jù)庫,需在1S內(nèi)完成攔截。(H,M)系統(tǒng)拒絕未經(jīng)登錄的訪問。(H,M)可用性發(fā)布新版本網(wǎng)絡(luò)環(huán)境不佳軟件產(chǎn)商發(fā)布了一個新軟件,該軟件是熱插拔的。(H,L)軟件產(chǎn)商發(fā)布了一個新軟件,支持用戶隨時進行更新。(M,L)用戶進行每日運勢測評無響應(yīng),終端在1S內(nèi)提示用戶網(wǎng)絡(luò)環(huán)境不佳,請

12、打開網(wǎng)絡(luò)連接。(M,L)性能響應(yīng)時間吞吐量用戶提交測評后,系統(tǒng)在0.5s內(nèi)顯示測評結(jié)果。(M,H)100名用戶同時在線時,系統(tǒng)每秒能處理150個正常請求。(M,H)可修改性優(yōu)化算話的復(fù)雜性優(yōu)化測評結(jié)果分析算法,兩名開發(fā)人員在一個工作日內(nèi)完成。(H,L)6.3 Tactics一,安全性策略: 1、反應(yīng)攻擊 2、確定用戶二,可用性策略: 1、異常檢測 2、異常處理3、實時監(jiān)聽三,安全性策略1、加密數(shù)據(jù)2、拒絕攻擊3、反應(yīng)攻擊4、確定用戶四,可修改性策略1、降低依賴2、減少耦合3、提高內(nèi)聚4、封裝五,性能策略1、同時計算7. Architecture根據(jù)軟件的重要需求,確定了本軟件所采用的設(shè)計模式:

13、7.1 WebService決定運用該模式的需求:(1)客戶端數(shù)據(jù)庫與服務(wù)器同步,采用雙數(shù)據(jù)庫實現(xiàn)效率提高。(2)需調(diào)用API,進行每日運勢分析。WebService 調(diào)用每日星座運勢API核心代碼如下:private void updateEverydayFortune() if(isNetworkAvailable()/有網(wǎng)絡(luò)就更新/啟動更新數(shù)據(jù)線程new Thread(new updateEverydayFortuneRunnable().start();private class updateEverydayFortuneRunnable implements RunnableSimp

14、leDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");String now = simpleDateFormat.format(new Date();SharedPreferences sharedPreferences = MainActivity.this.getSharedPreferences("xzlm",Context.MODE_WORLD_READABLE);Overridepublic void run() /將值取獲,然后保存for(int i=1;i<

15、;=12;i+)/判斷是否要更新String date = sharedPreferences.getString(i+"_date", "NoDate");if(date.equals("NoDate")|!date.equals(now)/需要更新的星座就去更新。sendInfo(i);private StringBuffer json;private void sendInfo(int constellationid) / 發(fā)送http請求URL url = null;HttpURLConnection conn = null;

16、DataOutputStream outputStream = null;BufferedInputStream bufferedInputStream = null;String requestUrl = "String param = "fun=day&id=" + EverydayFortune.httpConstellationNumberconstellationid - 1 + "&format=json"byte entity = param.getBytes();try url = new URL(request

17、Url);conn = (HttpURLConnection) url.openConnection();conn.setConnectTimeout(5000);conn.setDoOutput(true);conn.setUseCaches(false);conn.setRequestMethod("POST");conn.setRequestProperty("Charset", "UTF-8");conn.setRequestProperty("Content-Length", String.valueOf

18、(entity.length);outputStream = new DataOutputStream(conn.getOutputStream();outputStream.write(entity);outputStream.flush();if (conn.getResponseCode() = 200) bufferedInputStream = new BufferedInputStream(conn.getInputStream();byte bf = new byte1024;int i = 0;json = new StringBuffer();while (i = buffe

19、redInputStream.read(bf) != -1) String str = new String(bf, 0, i);json.append(str); catch (MalformedURLException e) e.printStackTrace(); catch (IOException e) e.printStackTrace();if (json != null) / 有數(shù)據(jù)返回,下面解析這些數(shù)據(jù),并保存resolveJSONAndSave(constellationid);/解析回傳的jsonprivate void resolveJSONAndSave(int co

20、nstellationid) JSONArray array;try array = new JSONArray(json.toString();String zhys = array.getJSONObject(0).getString("rank");String aqys = array.getJSONObject(1).getString("rank");String gzzk = array.getJSONObject(2).getString("rank");String lctz = array.getJSONObjec

21、t(3).getString("rank");String jkzs = array.getJSONObject(4).getString("value");String stzs = array.getJSONObject(5).getString("value");String xyys = array.getJSONObject(6).getString("value");String xysz = array.getJSONObject(7).getString("value");Str

22、ing spxz = array.getJSONObject(8).getString("value");String zhgs = array.getJSONObject(9).getString("value");String date = array.getString(11);/保存到sharedPreferencesSharedPreferences sharedPreferences = MainActivity.this.getSharedPreferences("xzlm", Context.MODE_WORLD_WR

23、ITEABLE);Editor editor = sharedPreferences.edit();editor.putString(constellationid+"_zhys", zhys);editor.putString(constellationid+"_aqys", aqys);editor.putString(constellationid+"_gzzk", gzzk);editor.putString(constellationid+"_lctz", lctz);editor.putString(c

24、onstellationid+"_jkzs", jkzs);editor.putString(constellationid+"_stzs", stzs);editor.putString(constellationid+"_xyys", xyys);editor.putString(constellationid+"_xysz", xysz);editor.putString(constellationid+"_spxz", spxz);editor.putString(constellati

25、onid+"_zhgs", zhgs);editor.putString(constellationid+"_date", date);mit(); catch (JSONException e) / TODO Auto-generated catch blocke.printStackTrace();/* * 判斷有沒有網(wǎng)絡(luò) * * return是否有網(wǎng)絡(luò) */private boolean isNetworkAvailable() Context context = getApplicationContext();ConnectivityManage

26、r connectivity = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);if (connectivity != null) NetworkInfo info = connectivity.getAllNetworkInfo();if (info != null) for (int i = 0; i < info.length; i+) if (infoi.getState() = NetworkInfo.State.CONNECTED) return true;return

27、 false;7.2 MVC (Model View Controller)決定運用MVC模式的需求:(1)實現(xiàn)測試題目選項統(tǒng)計,進行測試結(jié)果分析。MVC核心代碼如下:/Model:/package com.example.service;import java.util.ArrayList;import java.util.List;import java.util.Observable;public class Model extends Observable private List <Integer> mList ;public int get(int idx) retur

28、n mList.get(idx);public void set(int idx) mList.set(idx,1); setChanged(); notifyObservers();public void back(int idx) mList.set(idx,0);setChanged();notifyObservers();public Model()mList = new ArrayList<Integer>(4);mList.add(0);mList.add(0);mList.add(0);mList.add(0);/Controller:/answerGroup.set

29、OnCheckedChangeListener(new OnCheckedChangeListener()Overridepublic void onCheckedChanged(RadioGroup group, int checkedId) / TODO Auto-generated method stubnextBtn.setEnabled(true);switch (group.getCheckedRadioButtonId() case R.id.answerA:model.set(0);model.back(1);model.back(2);model.back(3);break;

30、case R.id.answerB:model.set(1);model.back(0);model.back(2);model.back(3);break;case R.id.answerC:model.set(2);model.back(0);model.back(1);model.back(3);break;case R.id.answerD:model.set(3);model.back(0);model.back(1);model.back(2);break;7.3 Publish/Subscrib決定運用“發(fā)布訂閱”模式的需求:(1)測試題庫需定期更新,并自動提示用戶。Publish/Subscrib核心代碼如下:/Publish/Subscribe接口:/public interface ISubscribe void getNewPaper();/個人訂閱者:/public class PersonalSubscriber implements ISubscribe private String strName;public void setNewsPaperName(String strName)this.strName = strName;public String getNewsPaperName()return strName;Overridepubli

溫馨提示

  • 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)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論