🙊作者簡介:擁有多年開發工作經驗,分享技術代碼幫助學生學習,獨立完成自己的項目或者畢業設計。
- 代碼可以私聊博主獲取。🌹
- 贈送計算機畢業設計600個選題excel文件,幫助大學選題。
- 贈送開題報告模板,幫助書寫開題報告。
作者完整代碼目錄供你選擇:
- 《Springboot網站項目》400套
- 《ssm網站項目》800套
- 《小程序項目》300套
- 《App項目》500套
- 《python網站項目》600套
?感興趣大家可以點點關注收藏,后續更新更多項目資料。?
項目演示



摘 要
隨著我國經濟迅速發展,人們對手機的需求越來越大,各種手機軟件也都在被廣泛應用,但是對于手機進行數據信息管理,對于手機的各種軟件也是備受用戶的喜愛,微信小程序被用戶普遍使用,為方便用戶能夠可以隨時進行小程序的相應信息內容的管理,特開發了基于微信小程序的學生公寓電費信息管理系統小程序。
學生公寓電費信息管理系統的設計主要是對系統所要實現的功能進行詳細考慮,確定所要實現的功能后進行界面的設計,在這中間還要考慮如何可以更好的將功能及頁面進行很好的結合,方便用戶可以很容易明了的找到自己所需要的信息,還有系統平臺后期的可操作性,通過對信息內容的詳細了解進行技術的開發。
學生公寓電費信息管理系統平臺開發使系統能夠更加方便快捷,同時也促使學生公寓電費信息管理系統變的更加系統化、有序化。系統界面較友好,易于操作。具體在系統設計上,微信端使用微信開發者,后臺也使用java技術在動態頁面上進行了設計,Mysql數據庫,是一個非常優秀的學生公寓電費信息管理系統
關鍵詞:學生公寓電費信息管理系統 ;微信開發者 java語言 ?Mysql?數據庫 SSM框架
1 系統概述
1.1 概述
隨著信息時代的快速發展,互聯網的優勢和普及,人們生活水平的不斷提高,工作時間的繁忙,使得學生公寓電費信息管理系統的開發成為必需。學生公寓電費信息管理系統主要是借助計算機,通過對學生公寓電費信息管理系統管理所需的信息管理,增加用戶的選擇,同時也方便廣大用戶信息的及時查詢、修改以及對學生公寓電費信息管理系統信息的及時了解。學生公寓電費信息管理系統序給用戶帶來了更多的選擇, 該系統通過和數據庫軟件協作來滿足用戶的需求。
1.2課題意義
1.3 主要內容
學生公寓電費信息管理系統從功能、數據流程、可行性、運行環境進行需求分析。對學生公寓電費信息管理系統的數據庫、功能進行了詳細設計,分析了主要界面設計和相關組件設計,學生公寓電費信息管理系統的具體實現進行了介紹。從數據庫中獲取數據、向數據庫中寫入數據,實現系統直接對數據庫進行各種數據庫查詢、插入、刪除、更新等操作,在網頁中加入動態內容,從而實現學生公寓電費信息管理系統所需要的各種基本功能。
2?系統開發環境
2.1微信開發者工具
微信開發者工具現在已經被小程序開發團隊開發運行,目前微信開發者工具任然在不斷的完善中,在開發小程序時經常要不斷的更新。可以使用微信掃碼登陸開發者工具,開發者工具將使用這個微信帳號的信息進行小程序的開發和調試。
機型選擇:小程序以智能手機的屏幕尺寸為設計標準,進行切圖。
預覽界面:寫好視圖布局后點擊編譯,用來刷新視圖界面。
控制臺:方便調試打印輸出信息。
上傳代碼:上傳到騰訊服務器,提交審核必經步驟。上傳代碼時可以填寫版本號和備注信息。
資源文件:一般可以在資源文件進行對應項目的文件目錄的斷點調試。
顯示遠程調試:手機端和PC端開發工具聯調對用戶而言是非常實用的。
本地數據存儲:顯示的是本地存儲的數據。
視圖調試:標組件以子父層級結構呈現,方便調試。
微信限制在2M 以內的代碼體積;開發中一般不校驗合法域名信息;小程序后臺要做配置服務器域名。
以上就是在開發過程中微信開發者工具常用到的功能,微信開發者工具也在不斷的完善。
2.2小程序框架以及目錄結構介紹
2.3?JAVA簡介
Java主要采用CORBA技術和安全模型,可以在互聯網應用的數據保護。它還提供了對EJB(Enterprise JavaBeans)的全面支持,java servlet API,JSP(java server pages),和XML技術。多進步。例如,當我在微軟Word中寫這篇文章時,我還打開了一個MP3播放器來播放音樂。偶爾,我也會編輯Word,讓電影信息管理機器執行打印作業,我也喜歡通過IE。對我來說,這些操作是同時執行的,我不需要等待一首歌來完成電影信息管理論文編輯。似乎他們都在電影信息管理機器上同時為我工作。事實是,對于一個CPU,它只能在某個時間點執行一個程序。CPU在這些程序之間不斷地“跳躍”。那么為什么我們看不到任何破壞呢?這是因為,與我們的感情相比,它的速度太快了。因此,盡管我們看到一些同步操作,實際上對于計算機來說,它只能在某個時間點執行一個程序,除非您的計算機是多CPU的。
Java是一種計算機編程語言,具有封裝、繼承和多態性三個主要特性,廣泛應用于企業Web應用程序開發和移動應用程序開發。
Java語言和一般編譯器以及直譯的區別在于,Java首先將源代碼轉換為字節碼,然后將其轉換為JVM的可執行文件,JVM可以在各種不同的JVM上運行。因此,實現了它的跨平臺特性。雖然這使得Java在早期非常緩慢,但是隨著Java的開發,它已經得到了明顯改進。
2.4 MySQL數據庫
Mysql的語言是非結構化的,用戶可以在數據上進行工作。MySQL因為其速度、可靠性和適應性而備受關注。大多數人都認為在不需要事務化處理的情況下,MySQL是管理內容最好的選擇。并且因為Mysql的語言和結構比較簡單,但是功能和存儲信息量很強大,所以得到了普遍的應用。
Mysql數據庫在編程過程中的作用是很廣泛的,為用戶進行數據查詢帶來了方便。Mysql數據庫的應用因其靈活性強,功能強大,所以在實現某功能時只需要一小段代碼,而不像其他程序需要編寫大段代碼。總體來說,Mysql數據庫的語言相對要簡潔很多。
數據流程分析主要就是數據存儲的儲藏室,它是在計算機上進行的,而不是現實中的儲藏室。數據的存放是按固定格式,而不是無序的,其定義就是:長期有固定格式,可以共享的存儲在計算機存儲器上。數據庫管理主要是數據存儲、修改和增加以及數據表的建立。為了保證系統數據的正常運行,一些有能力的處理者可以進行管理而不需要專業的人來處理。數據表的建立,可以對數據表中的數據進行調整,數據的重新組合及重新構造,保證數據的安全性。介于數據庫的功能強大等特點,本系統的開發主要應用了Mysql進行對數據的管理。
2.5 SSM三大框架
1.Spring的優勢:
通過Spring的IOC特性,將對象之間的依賴關系交給了Spring控制,方便解耦,簡化了開發。
2.Spring MVC的優勢:
SpringMVC是使用了MVC設計思想的輕量級web框架,對web層進行解耦,使我們的開發更簡潔。
3.Mybatis的優勢:
數據庫的操作(sql)采用xml文件配置,解除了sql和代碼的耦合,提供映射標簽,支持對象和和數據庫orm字段關系的映射,支持對象關系映射標簽,支持對象關系的組建提供了xml標簽,支持動態的sql。
當今社會的生活節奏越來越快,人們對手機微信的需求也越來越高,不僅對操作簡單、功能齊全方面,而且對于用戶的體驗度也有了更高的要求,最快捷高效的方式莫過于利用互聯網,將學生公寓電費信息管理系統和互聯網結合起來,為用戶提供方便快捷的服務。
需求分析的任務是通過詳細調查現實要處理的對象,充分了解系統的工作概況,明確用戶的各種需求,然后在此基礎上確定新系統的功能。新系統必須充分考慮今后可能的擴充和改變。
學生公寓電費信息管理系統平臺主要是為了提高用戶的工作效率和更方便快捷的滿足用戶,更好存儲所有數據信息及快速方便的檢索功能,對學生公寓電費信息管理系統的各個模塊是通過許多今天的發達學生公寓電費信息管理系統做出合理的分析來確定考慮用戶的可操作性,遵循開發的系統優化的原則,經過全面的調查和研究。
學生公寓電費信息管理系統所要實現的功能分析,對于現在網絡方便,學生公寓電費信息管理系統要實現管理員、公寓管理員、學生可以直接在平臺上進行查看自己所需數據信息,這樣既能節省管理的時間,不用再像傳統的方式,如果用戶想要進行交流信息,必須雙方見面進行溝通交流所需的信息,由于很多用戶時間的原因,沒有辦法進行見面溝通交流,真的很難滿足用戶的各種需求。所以學生公寓電費信息管理系統的開發不僅僅是能滿足用戶的需求,還能提高用戶的使用率。所以系統管理必須要更快捷、有效、長期地為用戶或潛在用戶傳遞信息。建立一個學生公寓電費信息管理系統更好的交流平臺,提高系統對用戶交流后的信息服務的效率。此系統可以滿足大多數用戶所提出的問題,用戶可以根據自身的需求獲取相應的服務,為系統管理提供了快捷的途徑。
學生公寓電費信息管理系統用戶端要求在系統的安卓手機上可以運行,主要實現了線上購買和支付等相關信息的查看,并且根據需求進行對管理端;個人中心、公寓管理員管理、學生管理、樓層信息管理、用電情況管理、繳費清單管理、電費統計管理、公寓報修管理、系統管理,公寓管理員微信端;首頁、用電情況、我的等,學生微信端:首頁、用電情況、我的等主要功能模塊的操作和管理。
總體分布如圖3.1所示:
3.1 ?總體功能需求圖
系統實現給用戶展示的界面與該對象是面對面的,包括是否允許用戶簡單,方便使用,該請求的響應時間,對整體質量的主圖像,整體的布局的質量。
技術可行性:
(1)硬件可行性分析
系統的硬件要求方面不存在特殊的要求,只需要在普通的硬件配置就能夠輕松的實現,只是需要確保系統的正常工作即可,以及擁有較高的效率。如果有特別低的硬件,它可以導致系統的低性能以及效率低,從而導致整個網站的運行不順暢。以目前普遍的個人計算機的配置而言,這是十分容易實現的?。因此,本系統的開發在硬件方面是可行的。
提供完整的技術支持和保護,確保網站的穩定,安全運行,提供24×7和24小時技術支持項目完成提供主要的服務器系統安全及時的通知和更新服務。
(2)軟件可行性分析
提供一個共同的機制類似的借口動態模型,設計更集中。此外,代碼復用,也可以很好的體現。因此,考慮到系統的實際情況,選擇小程序作為本系統開發技術。通過上述分析,該系統的設計實現在軟件方面是可行的。
因此,我們進行了兩個方面的可行性研究,可以看出,該系統的開發是沒有問題的。
3.4經濟可行性
系統是基于小程序語言開發的軟件,所以系統在開發人力、財力要求不高,具有經濟可行性。
3.5操作可行性:?
本學生公寓電費信息管理系統序采用微信開發者,利用網絡就能夠進行訪問和操作,且界面簡單易操作,用戶只要平時有在用智能手機并連接到網絡,都能進行訪問和操作。
本學生公寓電費信息管理系統具有易操作、易管理、交互性好的特點,在操作上是非常簡單的。因此本系統可以進行開發。
3.6系統流程和邏輯
系統業務流程圖如圖所示:
圖3-1登錄流程圖
圖3-2添加信息流程圖
圖3-3注冊信息流程圖
4系統概要設計
4.1 概述
本系統基于Web服務模式,是一個適用于Internet環境下的模型結構。只要用戶能連上Internet,便可以在任何時間、任何地點使用。系統工作原理圖如圖4-1所示:
圖4-1 ?系統工作原理圖
4.2 系統結構
本系統架構網站,本系統的具體功能如下:
學生公寓電費信息管理系統小程序功能模塊如下圖4-2。
圖4-2系統功能結構圖
學生公寓電費信息管理系統微信小程序操作系統的結構,功能模塊如下圖4-3。
圖4-3系統結構圖
4.3. 數據庫設計
4.3.1 數據庫實體
圖4-4學生信息實體屬性圖
用電情況信息實體屬性圖如圖4-5所示。
圖4-5用電情況信息實體屬性圖
公寓報修域實體屬性圖如圖4-6所示。
圖4-6公寓報修實體屬性圖
4.3.2 數據庫設計表
此系統需要后臺數據庫,下面介紹數據庫中的各個表的詳細信息。
表4.1 config表
列名 | 數據類型 | 長度 | 約束 |
id | bigint | 20 | PRIMARY KEY |
name | varchar | 100 | DEFAULT NULL |
value | varchar | 100 | DEFAULT NULL |
表4.2 dianfeitongji表
列名 | 數據類型 | 長度 | 約束 |
id | bigint | 20 | PRIMARY KEY |
dianfeitongji | varchar | 200 | DEFAULT NULL |
jiaonarenshu | int | 11 | DEFAULT NULL |
zongjine | int | 11 | DEFAULT NULL |
dengjiren | varchar | 200 | DEFAULT NULL |
表4.3 gongyubaoxiu表
列名 | 數據類型 | 長度 | 約束 |
id | bigint | 20 | PRIMARY KEY |
baoxiubiaoti | varchar | 200 | DEFAULT NULL |
tupian | varchar | 200 | DEFAULT NULL |
xueshengzhanghao | varchar | 200 | DEFAULT NULL |
xueshengxingming | varchar | 200 | DEFAULT NULL |
sfsh | varchar | 200 | DEFAULT NULL |
表4.4 gongyuguanliyuan表
列名 | 數據類型 | 長度 | 約束 |
id | bigint | 20 | PRIMARY KEY |
zhanghao | varchar | 200 | DEFAULT NULL |
mima | varchar | 200 | DEFAULT NULL |
xingming | varchar | 200 | DEFAULT NULL |
xingbie | varchar | 200 | DEFAULT NULL |
nianling | varchar | 200 | DEFAULT NULL |
shouji | varchar | 200 | DEFAULT NULL |
shenfenzheng | varchar | 200 | DEFAULT NULL |
zhaopian | varchar | 200 | DEFAULT NULL |
表4.5 jiaofeiqingdan表
列名 | 數據類型 | 長度 | 約束 |
id | bigint | 20 | PRIMARY KEY |
danhao | varchar | 200 | DEFAULT NULL |
xueshengzhanghao | varchar | 200 | DEFAULT NULL |
xueshengxingming | varchar | 200 | DEFAULT NULL |
loucenghao | int | 200 | DEFAULT NULL |
yongdianliang | varchar | 200 | DEFAULT NULL |
jine | varchar | 200 | DEFAULT NULL |
zhuangtai | varchar | 200 | DEFAULT NULL |
jiaofeishijian | varchar | 200 | DEFAULT NULL |
zhanghao | varchar | 200 | DEFAULT NULL |
xingming | varchar | 200 | DEFAULT NULL |
tupian | varchar | 200 | DEFAULT NULL |
userid | bigint | 20 | DEFAULT NULL |
表4.6 loucengxinxi表
列名 | 數據類型 | 長度 | 約束 |
id | bigint | 20 | PRIMARY KEY |
louceng | varchar | 200 | DEFAULT NULL |
表4.7 news表
列名 | 數據類型 | 長度 | 約束 |
id | bigint | 20 | PRIMARY KEY |
title | varchar | 200 | DEFAULT NULL |
picture | varchar | 200 | DEFAULT NULL |
表4.8?token表
列名 | 數據類型 | 長度 | 約束 |
id | bigint | 20 | PRIMARY KEY |
userid | bigint | 20 | DEFAULT NULL |
username | varchar | 100 | DEFAULT NULL |
tablename | varchar | 100 | DEFAULT NULL |
role | varchar | 100 | DEFAULT NULL |
token | varchar | 200 | DEFAULT NULL |
表4.8?users表
列名 | 數據類型 | 長度 | 約束 |
id | bigint | 20 | PRIMARY KEY |
username | varchar | 100 | DEFAULT NULL |
password | varchar | 100 | DEFAULT NULL |
role | varchar | 100 | DEFAULT NULL |
5系統詳細設計
本系統使用了微信開發者結合java和mysql結合的結構開發了學生公寓電費信息管理系統 應用,系統中所有和數據庫有關系的操作都通過一個通用類來實現,大大提高了代碼的耦合性,當數據庫類型等信息變化后直接修改類文件就可以了,不再需要每個頁面都修改。另外本系統解決了中文的問題,也是在配置文件中添加了編碼方式的形式解決的,本系統另外一個大的特點是系統對數據庫的操作都單獨的寫在了一個類里,這樣對系統的所有數據庫操作都只訪問這個類就可以了,不要每個頁面都去寫數據庫的操作,提高了系統的集成性。
5.1管理員服務端功能界面
管理員通過填寫賬號、密碼、角色進行登錄如圖5-7所示。
圖5.1管理員登錄界面圖
管理員進入到首頁界面,通過界面的任務大廳,進入到系統可以進行查看個人中心、公寓管理員管理、學生管理、樓層信息管理、用電情況管理、繳費清單管理、電費統計管理、公寓報修管理、系統管理等功能模塊,進行相對應操作。
公寓管理管理:通過列表可以獲取賬號、姓名、性別、年齡手機、身份證、圖片等信息,進行查看詳情或刪除操作,如圖5-2所示。
圖5.2公寓管理員管理界面圖
學生管理:通過列表可以獲取學生賬號、學生姓名、樓層號、性別、年齡、手機、郵箱、身份證、照片等信息,進行查看詳情或刪除操作,如圖5-3所示。
圖5.3學生管理界面圖
樓層信息管理:通過列表可以獲取樓層等信息,進行查看詳情、新增、修改或刪除操作,并通過輸入樓層進行查詢,如圖5-4所示
圖5-4樓層信息管理界面圖
????
用電情況管理:通過列表可以獲取學生賬號、學生姓名、樓層號、用電量、金額、用電余額、登記時間、賬號、姓名、圖片、是否支付等信息,進行查看詳情或刪除操作,如圖5-5所示。
圖5-5用電情況管理界面圖
繳費清單管理:通過列表可以獲取單號、學生賬號、學生姓名、樓層號、用電量、金額、狀態、繳費時間、登記日期、賬號、姓名、圖片等信息,進行查看詳情、刪除操作,如圖5-6所示。
圖5-6繳費清單管理界面圖
電費統計管理:通過列表可以獲取電費統計、繳納人數、總金額、登記人、登記時間等信息,進行查看詳情、新增、修改、刪除操作,并通過輸入電費統計進行查詢,如圖5-7所示。
圖5-7電費統計管理界面
公寓報修管理:通過列表可以獲取報修標題、圖片、報修時間、學生賬號、學生姓名、審核回復、審核狀態等信息,進行查看詳情或刪除操作,如圖5-8所示。
圖5-8公寓報修界面圖
5.2公寓管理員微信端功能模塊
用戶注冊,在用戶注冊頁面可以填寫用戶名、姓名、性別、聯系電話等信息,進行注冊如圖5-9所示。
圖5-9用戶注冊界面圖
用戶登錄,在用戶登錄頁面填寫賬號、密碼進行登錄,如圖5-10所示。
圖5-10用戶登錄界面圖
首頁、用戶登錄到學生公寓電費信息管理系統客可以查看首頁、用電情況、我的等功能模塊,進行相對應操作,如圖5-11所示。
圖5-11公寓管理員首頁功能界面圖
公告詳情:通過頁面可以進行查看標題、簡介、內容、圖片等信息,進行查看公告操作,如圖5-12所示。
? ? ? ??
圖5-12公告詳情界面圖
用電情況:通過列表可以輸入學生賬號、學生姓名、樓層號、用電量、金額、用電余額、登記時間、賬號、姓名、圖片、備注等信息,進行提交操作,如圖5-13所示。
圖5-13用電情況界面圖
我的:通過頁面可以獲取學生、用電情況、繳費清單、公寓報修等功能模塊,進行相對應操作,如圖5-14所示。
5-14我的界面
報修詳情:通過列表可以獲取報修標題、報修時間、學生賬號、學生姓名、報修內容、等信息,進行在線審核操作,如圖5-15所示。
圖5-15報修詳情界面圖
5.3學生微信端功能模塊
首頁、用戶登錄到學生公寓電費信息管理系統客可以查看首頁、用電情況、我的等功能模塊,進行相對應操作,如圖5-16所示。
公告詳情:通過頁面可以進行查看標題、簡介、內容、圖片等信息,進行查看公告操作,如圖5-17所示。
? ? ? ?
圖5-17公告詳情界面圖
用電情況:通過頁面可以獲取姓名、學生賬號、學生姓名、樓稱號、用電量、金額、用電余額、登記時間、賬號、備注等信息,進行查看或在線支付操作,如圖5-18所示。
圖5-18用電情況界面圖
我的:通過列表可以獲取用電情況、繳費清單、公寓報修等功能模塊,進行相對應操作,如圖5-19所示。
5-19我的界面
繳費清單:通過列表可以獲取學生賬號、學生姓名、樓層號、用電量、金額、狀態、繳費時間、登記日期、賬號、姓名等信息,進行查看操作,如圖5-20所示。
圖5-20繳費清單界面圖
公寓報修:通過頁面可以進行輸入報修標題、圖片、報修時間、學生賬號、學生姓名、報修內容等信息,進行新增報修信息操作,如圖5-21所示。
圖5-21公寓報修界面圖
6 系統測試
6.1 測試理論
軟件系統測試的目的是通過測試找出在程序中的存在的錯誤信息和阻礙程序正常運轉的安全隱患。這同時也是每一個系統軟件測試的主要的規定,軟件系統的應用過程中,發現一個重要的錯誤也是極具有很大的影響力的,一個好的測試的方案就為發展程序中存在的重大問題的;同樣,一個成功的測試方案也就發現了迄今為止尚未發現的一個重要錯誤的測試。
軟件測試的主要的好處就是為了讓軟件的運行情況更好,讓用戶的使用的過程中更加的滿意。在軟件工程中,軟件測試是一個十分重要環節,在交付用戶使用最終的軟件之前,軟件測試就是一個檢驗的過程,主要針對的是軟件的軟件設計開發、需求分析、系統編碼各階段結果的一個檢驗過程。
軟件測試應遵循的原則如下:
(1) 軟件測試要盡快的進行并且整個測試部分要是在整個軟件開發的各個過程和細節。在發現了錯誤的情況下,立刻處理,這樣會大大的減少軟件的開發成,提高軟件的質量。
(2) 在關于軟件的各種測試中,例如測試的過程中使用的計劃、報告等等要做到妥善的處理和保管,主要目的就是為了方便將來的對系統的維護。
(3) 群集現象是應該得到高度重視的,在軟件的整個測試的過程中。就是在整個測試的過程中發現了錯誤的主要地方很有可能是就很多的錯誤的聚集的地方,所以要對這樣的部分給予特殊的照顧。
(4) 對于軟件的測試要盡量不要軟件的設計開發人員或是機構,而是要另一方來進行測試程序,這樣也是為了保證軟件的測試結果的客觀性以及公平公正性。
(5) 對于整個測試計劃要嚴格的按照一定的規則來進行軟件測試。
(6) 關于軟件測試的過程中的用例應該是預期結果以及之前輸入的數據信息構成,輸入條件中的要考慮的有合理和不合理的因素都要考慮到,這樣也是為了更好的幫助開發的人員更多的發現軟件中存在的錯誤。
(7) 對于整個的測試結果進行全面的檢查,盡量避免出現重復的錯誤。
6.2 測試方法及用例
1、功能測試
從用戶的角度來看,測試時不了解新開發軟件的內部結構,因此可以將系統與黑匣子進行比較,盲目輸入后可以查看系統給出的反饋。這種測試屬于黑盒測試,在測試中如果輸入錯誤信息系統會報錯。
2、性能測試
測試軟件程序的整體狀態(稱為性能測試)通常使用自動化測試工具來檢測系統的整體功能,在負載和壓力測試之間進行劃分,在某些情況下,將兩者結合起來。雖然壓力測試可以檢測到系統可以提供的最高級別的服務,但是負載測試可以測試系統如何響應增加的負載。
在對系統進行測試的時候在找到問題的情況下必須在第一時間找到解決問題的辦法,不要存在僥幸的心理,這樣才能讓系統開發的質量可以過關,并且開發的周期會大大縮短,還有就是在測試時,不要出現重復性的錯誤,遇到一個錯誤問題,要將整個系統開發所牽扯的該問題都必須一一解決,提高系統的安全性、穩定性。
白盒測試與黑盒測試是測試中比較常用的兩種方法。
①結構測試俗稱白盒測試:這種測試是在對程序的處理過程與結構都有詳盡了解的前提下,順從程序內部的邏輯而完成的系統測試,以確定系統中所有的通路都能夠遵照設計要求正常工作,不出現任何偏差。
②功能測試又成黑盒測試:主要是針對程序功能能夠按照設計正常實現的一種檢測,在程序接口處進行,檢測程序手法數據是否正常,與外部信息的交換是否完整。
測試用例:
表6.1 用戶注冊測試用例
用例編號 | UC-TEST-001 | 測試名稱 | 用戶注冊 | |
前提條件 | 用戶注冊 | |||
步驟 | 操作描述 | 數據 | 期望結果 | |
1 | 點擊用戶注冊查看詳情按鈕 | 無 | 跳轉到用戶注冊詳情 | |
2 | 點擊添加按鈕 | 無 | 跳轉到添加頁面 | |
3 | 選中添加后按鈕 | 無 | 跳轉到用戶注冊頁面 | |
測試說明 | 用戶未登錄時到步驟3跳轉到登錄頁面 | |||
測試結果 | 成功 | 測試人 |
表6.2 登錄測試用例
情況 | 用戶名輸入 | 密碼輸入 | 期望結果 |
(1) | 15546219225 | 1244566 | 提示“用戶名或者密碼錯誤,或賬號未經審核” |
(2) | aaaaa | 123456 | 提示“用戶名或密碼錯誤,或者賬號未經審核” |
(3) | 15546219225 | hangguowei | 登陸成功 |
6.3測試結果
測試后得到的性能和用例,系統具有足夠的正確性、可靠性、穩定性,并且可以對輸入數據進行準確的點擊操作處理和響應測試用戶的體驗也得到了很好的反饋和響應時間。合理的范圍,可以兼容所有主流瀏覽器,設計所需的效果。
結論
學生公寓電費信息管理系統的設計,通過互聯網來解決實現信息化的網站系統,通過我四年所學的所有專業知識整合一起,進行對學生公寓電費信息管理系統進行開發設計,當然在真正著手來做的時候遇到了很多問題,一個是網站的技術問題,一個是自己之前沒有單獨開發過程序,動手實踐比較少,面對問題的同時,自己的自信心也受到了一些打擊,不過我也是快速的調整自己的狀態,老師與同學討論的方法解決了所有的困難。
畢業設計是我們所學知識應用的最佳體現,也是在考核我們四年中所學的所有的專業知識及技術應用情況,通過這樣畢業設計可以更好的得到鍛煉及對所學知識的復習及運用,也是一種訓練和實踐。學生公寓電費信息管理系統的實現,不僅鞏固了我以前的知識,還對學到的知識通過結合技術進行詳細了解,還結合了對跨學科效果的深入理解。
在以后我的工作中,我仍然會繼續努力我的計算機方面的技術,讓我在后期的平臺開發中可以更好更快的實現需求功能。我相信自己可以勝任更多的好工作并在工作領域做出更大的貢獻。
回顧畢業設計的整個過程,既付出了努力與汗水也收獲了很多難以忘懷的美好經歷。雖然在系統開發過程中經歷了各種各樣的困難,自己也在不斷研究與探索,可是系統的實現仍有許多不足之處。但是經過系統編程工作讓我有了更多的信心,我相信在未來的路上,我會走的更好。
致 謝
畢業設計結束的同時也意味著四年的大學生活就要結束了。學生公寓電費信息管理系統的完成以及如何在系統運行過程中實現的更好,這其中付出了很大的努力,這段時光將會終身難忘。
在畢業設計的這一段時間里,離不開導師的細心指導,還有同學們的熱情幫助,有時候幾個同學在一起討論系統中的某個功能模塊如何實現,如何實現的更好,或是問題沒得到有效的解決,就會沒有心思做其他的事情,讓我們對理想充滿了動力。
在畢業設計即將結束之時,首先要感謝我的指導老師,謝謝您在畢業設計和畢業論文中對我的指導。在您的細心指導下我才能快速的掌握系統的相關功能,在您的大力幫助下我才能將課本上的知識與自己的項目結合,真正的做到學以致用。感謝您經常犧牲自己的休息時間,利用其豐富的教學和項目經驗對我進行指導。 課堂上,您教會我們如何做人、教會我們新的知識,在課下,您又像朋友一樣親切,教會了我很多道理,讓我意識到先做人、后做事。感謝所有教過我的老師,為我傾注了大量的心血,正是你們的諄諄教誨、嚴謹教學才使我能順利的完成學業,再此向你們表示深深的感謝。感謝大學里教過我的每一位老師,真心祝福您們。
在這里還得感謝我的戰友們,也就是同學們對我的大力支持及幫助。正是因為有你們的不斷幫助、鼓勵,熬夜通宵,不停的調試、測試程序,給我帶來了極大的動力,才能最終完成網站的運行。我們在一起交流、談論的時光,都將是我們在通往未來道路上的寶貴財富。我要深深地感謝你們!
畢業在即,在今后的工作和生活中,我會銘記師長們的教誨、同學們的幫助,繼續不懈努力和追求,來報答所有支持和幫助過我的人!
最后,耽誤了老師的休息時間來對本文進行審閱,評議和參與論文答辯的各位老師表示深深的感謝。在此,衷心的謝謝您們!
參考文獻
[1] 楊文志. Google 小程序程序設計指南[M]. 北京:電子工業出版社,2018:10-100.
[2] 韓超,梁泉著. 小程序系統原理及開發要點詳解 [M]. 北京:電子工業出版社,2019:50-150.
[3] 周元興. Google入門與實例教程 [M]. 北京:電子工業出版社,2017:30-80.
[4]熊偉,葉淋瑋. 我國虛擬旅游網站的功能評價研究[J]. 人文地理,2018,02:154-160.
[5]趙宣容. 計算機軟件數據庫設計的重要性以及原則探討[J]. 電子技術與軟件工程,2019,17:209.
[6]李凱,鹿艷晶.網站的設計與開發[J]. 軟件導刊,2019,03:79-81.
[7]白凱,呂洋洋,李薇薇.網站信息類型、品牌與服務保證對網站信任的影響[J]. 旅游學刊,2019,03:91-99.
[8]郝進義. 數據庫設計規范及設計技巧研究[J]. 計算機光盤軟件與應用,2017,12:176-177.
[9]趙春燕. 網站優化深度研究[J]. 信息安全與技術,2019,01:61-63.
[10] 靳巖. 小程序?開發入門與實戰 [M]. 北京:人民郵電出版社,2019:10-50.
[11] 余志龍 陳昱勛. Google 小程序?SDK開發范例大全 [M]. 北京:人民郵電出版社,2019:30-70.
[12] 楊豐盛. 小程序應用開發揭秘 L004 [M]. 北京:機械工業出版社,2018:43-65.
[13] 吳亞峰,蘇亞光. 小程序?2.0系統開發實戰寶典 [M]. 北京:人民郵電出版社,2019:15-30.
[14] 郭宏志.小程序應用開發詳解 [M]. 北京:電子工業出版社,2017:22-300.
[15] 陳昱,江蘭帆.基于Google 小程序平臺的應用程序開發和研究[J].福建電腦,2018(11):156-157.
[16] 楊豐盛.小程序應用開發揭秘[M] 第一版.北京:機械工業出版社,2019年.7頁
[17] 姚昱旻,劉衛國.學生公寓電費信息管理系統?的架構與應用開發研究[J].計算機系統應用,2018(11):110-1
[18] 姚昱旻,劉衛國.小程序?與J2ME 平臺間即時通信的研究與實現[J].計算機系統應用,2018(12):118-120
[19] 公磊,周聰.基于小程序?的移動終端應用程序開發與研究[J].計算機與現代化,2018(8):86-89.
[20]范佳佳,葉繼元. 21世紀以來網站評價研究進展與趨勢[J]. 中國圖書館學報,2019,02:92-106.
[21]廉同輝,余菜花,宗乾進. 我國旅游網站的網絡結構研究——基于社會網絡分析法[J]. 旅游科學,2019,06:80-88.
[22]莫祖英,馬費成. 數據庫信息資源內容質量用戶滿意度模型及實證研究[J]. 中國圖書館學報,2019,02:85-97.
[23]李志義,義梅練. 基于用戶體驗的網站優化研究綜述[J]. 情報科學,2018,11:150-154.
[24]Dong Qiu,Bixin Li,Hareton Leung. Understanding the API usage in Java[J]. Information and Software Technology,2018,73:.
[25]Oscar Vega-Gisbert,Jose E. Roman,Jeffrey M. Squyres. Design and implementation of Java bindings in Open MPI[J]. Parallel Computing,2018:. ?????????????????????????????????????????????????????
核心代碼展示
/*** 公告通知* 后端接口* @author * @email * @date 2021-03-09 11:33:59*/
@RestController
@RequestMapping("/news")
public class NewsController {@Autowiredprivate NewsService newsService;/*** 后端列表*/@RequestMapping("/page")public R page(@RequestParam Map<String, Object> params,NewsEntity news, HttpServletRequest request){EntityWrapper<NewsEntity> ew = new EntityWrapper<NewsEntity>();PageUtils page = newsService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, news), params), params));return R.ok().put("data", page);}/*** 前端列表*/@IgnoreAuth@RequestMapping("/list")public R list(@RequestParam Map<String, Object> params,NewsEntity news, HttpServletRequest request){EntityWrapper<NewsEntity> ew = new EntityWrapper<NewsEntity>();PageUtils page = newsService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, news), params), params));return R.ok().put("data", page);}/*** 列表*/@RequestMapping("/lists")public R list( NewsEntity news){EntityWrapper<NewsEntity> ew = new EntityWrapper<NewsEntity>();ew.allEq(MPUtil.allEQMapPre( news, "news")); return R.ok().put("data", newsService.selectListView(ew));}/*** 查詢*/@RequestMapping("/query")public R query(NewsEntity news){EntityWrapper< NewsEntity> ew = new EntityWrapper< NewsEntity>();ew.allEq(MPUtil.allEQMapPre( news, "news")); NewsView newsView = newsService.selectView(ew);return R.ok("查詢公告通知成功").put("data", newsView);}/*** 后端詳情*/@RequestMapping("/info/{id}")public R info(@PathVariable("id") Long id){NewsEntity news = newsService.selectById(id);return R.ok().put("data", news);}/*** 前端詳情*/@IgnoreAuth@RequestMapping("/detail/{id}")public R detail(@PathVariable("id") Long id){NewsEntity news = newsService.selectById(id);return R.ok().put("data", news);}/*** 后端保存*/@RequestMapping("/save")public R save(@RequestBody NewsEntity news, HttpServletRequest request){news.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(news);newsService.insert(news);return R.ok();}/*** 前端保存*/@RequestMapping("/add")public R add(@RequestBody NewsEntity news, HttpServletRequest request){news.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(news);newsService.insert(news);return R.ok();}/*** 修改*/@RequestMapping("/update")public R update(@RequestBody NewsEntity news, HttpServletRequest request){//ValidatorUtils.validateEntity(news);newsService.updateById(news);//全部更新return R.ok();}/*** 刪除*/@RequestMapping("/delete")public R delete(@RequestBody Long[] ids){newsService.deleteBatchIds(Arrays.asList(ids));return R.ok();}/*** 提醒接口*/@RequestMapping("/remind/{columnName}/{type}")public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request, @PathVariable("type") String type,@RequestParam Map<String, Object> map) {map.put("column", columnName);map.put("type", type);if(type.equals("2")) {SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");Calendar c = Calendar.getInstance();Date remindStartDate = null;Date remindEndDate = null;if(map.get("remindstart")!=null) {Integer remindStart = Integer.parseInt(map.get("remindstart").toString());c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindStart);remindStartDate = c.getTime();map.put("remindstart", sdf.format(remindStartDate));}if(map.get("remindend")!=null) {Integer remindEnd = Integer.parseInt(map.get("remindend").toString());c.setTime(new Date());c.add(Calendar.DAY_OF_MONTH,remindEnd);remindEndDate = c.getTime();map.put("remindend", sdf.format(remindEndDate));}}Wrapper<NewsEntity> wrapper = new EntityWrapper<NewsEntity>();if(map.get("remindstart")!=null) {wrapper.ge(columnName, map.get("remindstart"));}if(map.get("remindend")!=null) {wrapper.le(columnName, map.get("remindend"));}int count = newsService.selectCount(wrapper);return R.ok().put("count", count);}}