(附源码)springboot民宿网站 毕业设计 221901
Springboot民宿網站的設計與實現
摘?要
信息化社會內需要與之針對性的信息獲取途徑,但是途徑的擴展基本上為人們所努力的方向,由于站在的角度存在偏差,人們經常能夠獲得不同類型信息,這也是技術最為難以攻克的課題。針對民宿預訂等問題,對民宿預訂進行研究分析,然后開發設計出民宿網站以解決問題。
民宿網站主要功能模塊包括系統用戶管理、商城管理、民宿信息管理、住宿訂單管理、活動信息管理、活動預約管理,采取面對對象的開發模式進行軟件的開發和硬體的架設,能很好的滿足實際使用的需求,完善了對應的軟體架設以及程序編碼的工作,采取MySQL作為后臺數據的主要存儲單元,采用Springboot框架、JSP技術、Ajax技術進行業務系統的編碼及其開發,實現了本系統的全部功能。本次報告,首先分析了研究的背景、作用、意義,為研究工作的合理性打下了基礎。針對民宿網站的各項需求以及技術問題進行分析,證明了系統的必要性和技術可行性,然后對設計系統需要使用的技術軟件以及設計思想做了基本的介紹,最后來實現民宿網站和部署運行使用它。
關鍵詞:民宿網站;Springboot框架;MySQL數據庫
Design and implementation of springboot home stay website
Abstract
In the information society, there is a need for targeted information access, but the expansion of access is basically the direction of people's efforts. Due to the deviation of the perspective, people can often obtain different types of information, which is also the most difficult subject for technology to overcome. Aiming at the problems of home stay reservation, this paper studies and analyzes the home stay reservation, and then develops and designs the home stay website to solve the problems.
The main functional modules of the home stay website include system user management, mall management, home stay information management, accommodation order management, activity information management and activity reservation management. The object-oriented development mode is adopted for software development and hardware erection, which can well meet the needs of actual use, improve the corresponding software erection and program coding, and MySQL is adopted as the main storage unit of background data, Using springboot framework, JSP technology and Ajax technology to code and develop the business system, all the functions of the system are realized. This report first analyzes the background, function and significance of the research, which lays a foundation for the rationality of the research work. This paper analyzes the requirements and technical problems of the home stay website, proves the necessity and technical feasibility of the system, and then makes a basic introduction to the technical software and design ideas needed to design the system. Finally, it realizes the home stay website and deploys it.
Key words:B & B website; Springboot framework; Mysql database
目 ?錄
第1章 緒論
1.1?研究背景與意義
1.2?開發現狀
第2章 相關技術介紹
2.1?J2EE技術
2.2 MVVM模式
2.3 B/S結構
2.4 Springboot框架
2.5?Mysql數據庫
2.6?B/S體系工作原理
第3章 系統分析
3.1?可行性分析
3.2?功能需求分析
3.2.1?前臺用戶功能
3.2.2?后臺管理員功能
3.3?非功能需求分析
3.4?安全性需求分析
3.4.1?系統的安全性
3.4.2?數據的安全性
3.5?數據流程分析
第4章 系統設計
4.1?系統架構設計
4.2?系統總體設計
4.3?系統功能設計
4.4?數據庫設計
4.4.1?數據需求分析
4.4.2?數據庫概念設計
4.4.3?數據庫表設計
第5章 系統實現
5.1?數據庫訪問層的實現
5.2?注冊模塊的實現
5.3?登錄模塊的實現
5.4?用戶資料修改模塊的實現
5.5?民宿資訊管理模塊的實現
5.6?活動信息模塊的實現
5.7?民宿訂單模塊的實現
5.8?民宿信息管理模塊的實現
第6章 系統測試
6.1?測試目的
6.2?功能測試
6.3?性能測試
第7章 總結與展望
參考文獻
致謝
新時代理念的轉變,科技的快速發展,人們的物質水平也得到了極大的提高。我國的住宿業經歷了三個大時期,前兩個是商務需求推動的標準住宿期及人們旅游推動的以景區為核心的住宿時期,到了第三個時期,很多住宿產品已經脫離景區,只需要到一個風景好的地方,就可以生產產品滿足用戶需求,這個時候用戶需求的是度假、消磨時間,也就是現在所謂的消費升級。隨著互聯網的快速發展,接觸事物的速度變得越來越快,就比如現在網上的民宿類綜藝節目非常地火,提高了人們對民宿的好感度。這些民宿類的綜藝節目成功帶起了一段民宿潮。并且民宿對比酒店具有性價比高,價格便宜,具有特色等優點,對于精打細算的人和喜歡本地特色的人來說再適合不過了。
現在人們可以利用網絡進行購物、在線支付、在線學習,同時也可以通過定制化實體經濟和互聯網的耦合,從而碰撞出新的火花。隨著民宿業的大力發展,當經營民宿的房主的訂單越來越多,經營的民宿數量越來越多時,他需要處理的信息就變得繁多且枯燥。剛起步經營民宿的房主則面臨著宣傳力度的不足導致生意不好,租客無法快速找到心儀的民宿。互聯網與民宿業結合形成的民宿網站可以給經營民宿的房主提供一個宣傳和預訂的平臺,同時提高民宿的影響力與顧客量。而客戶可以通過民宿網站快速找到適合自己風格、價格便宜、設施齊全、評價真實的民宿進行查看以及線上預訂。希望通過本網站能夠增強傳統民宿在這些方面的薄弱點,從而提高經營者的經營水平,提高租客的用戶體驗,進而提高民宿的收入和產業鏈的升級,這也正是本課題研究的意義所在。
對于房間數量較多的民宿來說,利用一個民宿網站來管理民宿的房間信息和客戶的預訂信息顯得尤為重要,這個系統不僅方便了客戶進行預訂,同時也方便了工作人員,大大節省了時間。所以開發一個民宿網站是很有必要的。
在德國,幾乎每十一個人就有一個人選擇住民宿來解決住宿問題。他們大多是故意選擇有個人特色的民宿而放棄風格一樣的酒店。在英國,他們的民宿在世界排名相當高,是組成英國旅游業的重要組成部分,他們提供定制服務和星級私人服務,在日本的民宿有另一個名字,叫做家庭旅館,都是發揮著每個不同地區特色的民宿,像滑雪場主題、溫泉主題、海邊主題、森林主題的民宿。因為國外的互聯網發展要比國內歷史要悠久一些,所以導致國外的民宿網站發展地已經比較成熟,美國有愛彼迎,澳洲有考拉民宿,歐洲有booking等發展完善的民宿網站。但是中國本土的民宿網站才剛剛起步,未來還有很多空間可以發展。
近年來,全國多地把民宿產業作為鄉村的新發展模式,把民宿產業作為鄉村振興的突破點,不再僅限于養殖畜牧業,吸引城市里的人到鄉下消費使得鄉村開始快速發展,不斷探索創新發展模式。根據報告稱2018年之前,全中國已經出臺了大約二百七十個關于民宿的各種規定和要求標準文件。而且現在已經有二十幾個城市出臺了有利于扶持民宿產業的政策。這么多的扶持民宿發展的政策出現,表示現在對民宿發展的大力支持的態度與對民宿發展的標準化引導。讓民宿產業發展的道路越來越順暢,使得鄉村的民宿運營能夠成為一個完善的產業鏈,讓人們更加重視民宿產業和讓人們能夠享受到更加舒適和標準的民宿。
人可以掌握多門外語,而一個計算機科學家精通的大多是編程語言,它不是人類的自然語言,比如C語言、Java、Perl等等。由于不同的公司開發出的“中間件”不夠規范,所以Sun公司推出J2EE,用這個標準來解決弊病。它提供了良好的機制,讓每個層次允許與之相對的服務器、組件運行,使得系統的搭建穩定可用、開發高效、維護方便。
MVVM模式是常用的開發模式,主要是在代碼實現上將其分為M層、V層和C層。
視圖(View)代表用戶交互界面,一個 Web 應用就可能有很多的界面,在 MVVM?模式中,視圖僅僅處理的只有數據采集、處理,還有用戶的請求, 并不包括業務流程的處理,業務流程由模型(Model)來處理。
模型(Model)就是業務流程/狀態的處理及業務規則的制定。模型處理業務流程的過程其它層是無法看見了的,它就像黑箱子,在接受視圖請求的數據之后,然后返回最終的處理結果。MVVM?最主要的核心就是業務模型的設計,一個典型的應用例子就是目前流行的 EJB 模型,它從應用技術實現的角度對模型做了進一步的劃分,以便充分利用現有的組件,但是它不能作為應用設計模型的框架。
控制器(Controller)可以理解為接收用戶的請求,然后視圖和模型匹配在一起,一起再完成用戶請求。它有非常明顯的作用在劃分控制層上,可以很清晰地告訴你,它就是一個分發器,選擇什么樣的模型、視圖,可以完成用戶的什么樣的請求。控制層不做所有的數據處理,比如說:用戶點擊一個連接,控制層接受到請求之后,并不處理業務信息,它只是向模型傳遞用戶的信息,同時告訴模型做什么,然后選擇符合需求的視圖返回給用戶。
B/S(Browser/Server)比前身架構更為省事的架構。它借助Web server完成數據的傳遞交流。只需要下載瀏覽器作為客戶端,那么工作就達到“瘦身”效果, 不需要考慮不停裝軟件的問題。
Spring框架是Java平臺上的一種開源應用框架,提供具有控制反轉特性的容器。盡管Spring框架自身對編程模型沒有限制,但其在Java應用中的頻繁使用讓它備受青睞,以至于后來讓它作為EJB(EnterpriseJavaBeans)模型的補充,甚至是替補。Spring框架為開發提供了一系列的解決方案,比如利用控制反轉的核心特性,并通過依賴注入實現控制反轉來實現管理對象生命周期容器化,利用面向切面編程進行聲明式的事務管理,整合多種持久化技術管理數據訪問,提供大量優秀的Web框架方便開發等等。Spring框架具有控制反轉(IOC)特性,IOC旨在方便項目維護和測試,它提供了一種通過Java的反射機制對Java對象進行統一的配置和管理的方法。Spring框架利用容器管理對象的生命周期,容器可以通過掃描XML文件或類上特定Java注解來配置對象,開發者可以通過依賴查找或依賴注入來獲得對象。Spring框架具有面向切面編程(AOP)框架,SpringAOP框架基于代理模式,同時運行時可配置;AOP框架主要針對模塊之間的交叉關注點進行模塊化。Spring框架的AOP框架僅提供基本的AOP特性,雖無法與AspectJ框架相比,但通過與AspectJ的集成,也可以滿足基本需求。Spring框架下的事務管理、遠程訪問等功能均可以通過使用SpringAOP技術實現。Spring的事務管理框架為Java平臺帶來了一種抽象機制,使本地和全局事務以及嵌套事務能夠與保存點一起工作,并且幾乎可以在Java平臺的任何環境中工作。Spring集成多種事務模板,系統可以通過事務模板、XML或Java注解進行事務配置,并且事務框架集成了消息傳遞和緩存等功能。Spring的數據訪問框架解決了開發人員在應用程序中使用數據庫時遇到的常見困難。它不僅對Java:JDBC、iBATS/MyBATIs、Hibernate、Java數據對象(JDO)、ApacheOJB和ApacheCayne等所有流行的數據訪問框架中提供支持,同時還可以與Spring的事務管理一起使用,為數據訪問提供了靈活的抽象。Spring框架最初是沒有打算構建一個自己的WebMVC框架,其開發人員在開發過程中認為現有的StrutsWeb框架的呈現層和請求處理層之間以及請求處理層和模型之間的分離不夠,于是創建了SpringMVC。
Mysql 經過多次的更新,功能層面已經非常的豐富和完善了,從Mysql4版本到5版本進行了比較大的更新,在商業的實際使用中取得了很好的實際應用效果。最新版本的Mysql支持對信息的壓縮,同時還能進行加密能更好的滿足對信息安全性的需求。同時經過系統的多次更新,數據庫自身的鏡像功能也得到了很大的增強,運行的流暢度和易用性方面有了不小的進步,驅動的使用和創建也更加的高效快捷。最大的變動還是進行了空間信息的顯示優化,能更加方便的在應用地圖上進行坐標的標注和運算。強大的備份功能也保證了用戶使用的過程會更加安心,同時支持的Office特性還支持用戶的自行安裝和使用。在信息的顯示形式上也進行了不小的更新,增加了兩個非常使用的顯示區,一個是信息區,對表格和文字進行了分類處理,界面的顯示更加清爽和具體。第二是儀表的信息控件,能在儀表信息區進行信息的顯示,同時還能進行多個信息的比對,為用戶的實際使用帶來了很大的便捷。
針對本文中設計的民宿網站在實際的實現過程中,最終選擇Mysql數據庫的主要原因在于在企業的應用系統應用及開發的過程中會存在大量的數據庫比較頻繁的操作,而且數據的安全性要求也是非常的高。綜合這些因素,最終選擇安全性系數比較高的Mysql來對民宿網站后臺數據進行存儲操作。
2.6 B/S體系工作原理:
B/S架構采取瀏覽器請求,服務器響應的工作模式。
用戶可以通過瀏覽器去訪問Internet上由Web服務器產生的文本、數據、圖片、動畫、視頻點播和聲音等信息;
而每一個Web服務器又可以通過各種方式與數據庫服務器連接,大量的數據實際存放在數據庫服務器中;
從Web服務器上下載程序到本地來執行,在下載過程中若遇到與數據庫有關的指令,由Web服務器交給數據庫服務器來解釋執行,并返回給Web服務器,Web服務器又返回給用戶。在這種結構中,將許許多多的網連接到一塊,形成一個巨大的網,即全球網。而各個企業可以在此結構的基礎上建立自己的Internet。
在 B/S 模式中,用戶是通過瀏覽器針對許多分布于網絡上的服務器進行請求訪問的,瀏覽器的請求通過服務器進行處理,并將處理結果以及相應的信息返回給瀏覽器,其他的數據加工、請求全部都是由Web Server完成的。通過該框架結構以及植入于操作系統內部的瀏覽器,該結構已經成為了當今軟件應用的主流結構模式。
技術性方面,采用當前主流的Springboot框架進行系統主體框架的搭建,前臺使用jquery,ajax,實現前臺頁面的設計與美觀調整,以上技術,均由本人經過系統學習,并且都是在課程設計中實踐過的,可以使得開發更加便捷和系統。從技術角度看,這個系統是完全可以實現的。
實用性方面,本次設計的主要任務是實現民宿網站內的民宿信息、住宿訂單、商城管理、活動信息、活動預約模塊等,符合當前潮流的發展。從用戶角度出發,同時也考慮系統運營成本和人力資源,采用網絡上的便捷方式,實現線上業務,使得業務流程更系統,也更方便用戶的體驗,比較實用。
經濟性方面,由于本課題中設計的民宿網站的主要目的是為了能夠更加方便及快捷的進行民宿預訂以及民宿房間的查詢及檢索服務,也就是能夠可以直接投入使用的信息化軟件。系統的主要成本主要是集中在對使用數據后期繼續維護及其管理更新這個操作上。但是一旦系統投入到實際的運行及使用之后就能夠很好的提高信息查詢檢索的效率,同時也需要有效的保證查詢者的信息方面的安全性,同時這個民宿網站所帶來的實際應用方面的價值是遠遠的超過了實際系統進行開發與維護方面的成本,因此,從經濟上來說開發這個軟件是可行的。
民宿網站的功能主要分為前臺用戶根據自己的需求進行注冊登錄,瀏覽民宿信息并對需要的房間進行預訂操作。后臺系統管理員因職責的不同,分為普通管理員和超級管理員,管理員主要對注冊用戶,民宿信息,活動信息,住宿訂單進行處理。
用戶用例圖如下所示。
?
圖3-1 用戶用例圖
管理員用例圖如下所示。
?
圖3-2 管理員用例圖
注冊用戶需求。
注冊賬號:用戶填寫個人信息,并驗證手機號碼。
登錄:根據賬號密碼進行登錄操作。
瀏覽民宿資訊:用戶可以瀏覽主頁面的民宿資訊來了解系統的最新民宿資訊。
瀏覽民宿信息:用戶可以瀏覽民宿的具體信息,名稱、類型、價格、介紹、聯系電話等。
維護個人信息:用戶因個人信息的變更可以隨時修改自己注冊信息。
瀏覽活動信息:選中某個活動進行查看。
民宿預訂:用戶根據自己的需求選中某個民宿房間進行預訂操作。
個人預訂歷史記錄:用戶可以查看自己以往預訂數據。
管理員功能如下:
修改密碼:管理員可以隨時修改自己進入系統的登錄密碼,以保證系統的安全性。
管理普通管理員:對普通管理員進行管理。調動相關工作人員時可以添加或刪除普通管理員。
民宿信息管理:對民宿信息進行維護,添加、刪除、修改信息。
對預訂單信息進行處理:辦理預訂單審核等。
民宿資訊信息管理:發布、刪除相關的民宿資訊信息。
用戶管理:可以查看注冊用戶的信息,并對其進行管理。
首先主要考慮的是系統功能軟件,在具體設計的環節上,是不是能夠較好的滿足各類用戶的基本功能需求,如果不能較好的滿足用戶需求,那么這個系統的存在是沒有價值的。軟件系統的非功能性求分析,從7個方面展開,一個是性能分析,針對系統;一個是安全分析,針對系統,一個是完整度分析,針對系統,一個是可維護分析,針對系統,一個是可擴展性分析,針對系統,一個是適應業務的性能分析。面對民宿網站存在的性能、安全、擴展、完整度等7個方面性能綜合比對分析后發現,需要相應的非功能性需求分析。
安全性對每一個系統來說都是非常重要的。安全性很好的系統可以保護企業的信息和用戶的信息不被竊取。提高系統的安全性不僅是對用戶的負責,更是對企業的負責。尤其針對于民宿網站來說,必須要有很好的安全性來保障整個系統。
系統具有對使用者有權限控制,針對角色的不通限制使用者的權限,以此來確保系統的安全性。
數據庫中的數據是從外界輸入的,當數據的輸入時,由于種種原因,輸入的數據會無效,或者是臟數據。因此,怎樣保證輸入的數據符合規訂 ,成為了數據庫系統,尤其是多用戶的關系數據庫系統首要關注的問題。
因此,在寫入數據庫時,要保證數據完整性、正確性和一致性。
對系統的數據流進行分析,系統的使用者分為二類,一般用戶,管理員。系統主要對界面信息傳送,登錄信息的驗證,注冊信息的接收,用戶各種操作的響應做處理。
系統頂層數據流圖如下圖所示。
?
圖3-2 頂層數據流圖
要判斷用戶是是什么身份,是根據登錄的數據來判斷后,跳轉到對應的功能界面。在系統的內部用戶就可以對數據進行操作,數據庫中心就可以接收到系統傳輸的有效數據流來對數據sql語句進行對應操作。
系統底層數據流圖如下圖所示。
?圖3-3 底層數據流圖
?
系統可以分為前臺和后臺兩部分,每一種操作后系統都返回操作結果。前臺和后臺的數據連接主要通過數據庫,既分別對數據庫做不同的操作。
本民宿網站的架構設計主要分為可以3層,主要有Web層,業務層,Model層。其中web層還包括View層和Controller層,Model層包括元數據擴展層和數據訪問層。
系統架構如下圖所示。
?
圖4-1 系統架構
民宿網站總體分為前臺用戶模塊和后臺管理員模塊。
兩個模塊表現上是分別獨立存在,但是訪問的數據庫是一樣的。每一個模塊的功能都是根據先前完成的需求分析,并查閱相關資料后整理制作的。
綜上所述,系統功能結構圖如下圖所示。
?
圖4-2 系統功能結構圖
登錄模塊:登錄模塊是進入系統的入口,所有用戶必須登錄后才能訪問系統。登錄需要輸入用戶名和密碼,如果多次嘗試登錄需要輸入驗證碼。登錄時需要選擇用戶的角色,是一般用戶還是管理員登錄等。登錄成功后,會通過數據庫獲取用戶的權限,并跳轉至用戶的主頁面。
管理員用戶管理模塊:管理員管理包括:管理員的添加,修改和刪除操作。添加管理員時,先判斷用戶添加的管理員是否是admin(超級管理員),如果不是則添加成功。修改時候,如果是超級管理員,可以修改所有管理員的信息,如果是普通管理員,那么只能修改自己的信息。超級管理員可以刪除自己以外的所有其他管理員,普通管理員不能執行刪除管理員的操作。
民宿資訊模塊:可分為民宿資訊瀏覽、民宿資訊檢索、民宿資訊維護三個模塊,管理員對民宿資訊有維護的權限,發布新的民宿資訊、更新已有的民宿資訊等。
民宿管理模塊:民宿管理分為民宿添加、修改和民宿預訂。民宿信息由管理員進行修改、添加、刪除操作;民宿預訂由普通用戶來執行。
從前面可以分析到數據庫中最重要的是民宿信息,住宿訂單信息,活動信息。分析可以得到如下數據描述:
平臺用戶:用于記錄用戶的各種信息,包括用戶名、密碼、姓名、性別、地址、郵箱、聯系方式等數據項。
管理員:記錄管理員的登錄信息。包括用戶名,密碼,權限等數據項。
民宿信息:存儲各種民宿信息。包括民宿類型、價格、訂金、可入住人數、圖片、是否空閑等數據項。
民宿預訂。存儲用戶的民宿預訂信息。包括民宿預訂的民宿類型、價格、訂金、預訂天數、總價格、姓名、聯系電話、入住日期、預訂人、是否支付等數據項。
民宿數據:存儲平臺內的民宿數據內容。
根據前面的數據流程圖,結合系統的功能模塊設計,設計出符合系統的各信息實體。
系統ER圖如下圖所示。
?
圖4-3 系統ER圖
民宿網站所擁有的數據表有以下:用戶信息表,資訊信息表,民宿信息表,住宿訂單表,活動信息表。
由于數據表較多,只展示系統主要數據表,如下表所示。
| 序號 | 字段名稱 | 字段類型 | 大小 | 允許為空 | 最大長度 | 備注 |
| 1 | id | Int | 4 | 10 | ||
| 2 | fangxing | 150 | 255 | |||
| 3 | addtime | DateTime | 8 | 19 |
| 序號 | 字段名稱 | 字段類型 | 大小 | 允許為空 | 最大長度 | 備注 |
| 1 | id | Int | 4 | 10 | ||
| 2 | mingsuxinxi | 150 | 255 | |||
| 3 | fangxing | 150 | 255 | |||
| 4 | jiage | 150 | 255 | |||
| 5 | dingjin | 150 | 255 | |||
| 6 | keruzhurenshu | 150 | 255 | |||
| 7 | tupian | 150 | 255 | |||
| 8 | zhanshijianjie | 1073741823 | 255 | |||
| 9 | issh | 30 | 255 | |||
| 10 | addtime | DateTime | 8 | 19 |
| 序號 | 字段名稱 | 字段類型 | 大小 | 允許為空 | 最大長度 | 備注 |
| 1 | id | Int | 4 | 10 | ||
| 2 | yudingxinxi | 150 | 255 | |||
| 3 | fangxing | 150 | 255 | |||
| 4 | jiage | 150 | 255 | |||
| 5 | dingjin | 150 | 255 | |||
| 6 | yudingtianshu | 150 | 255 | |||
| 7 | zongjiage | 150 | 255 | |||
| 8 | xingming | 150 | 255 | |||
| 9 | lianxidianhua | 150 | 255 | |||
| 10 | ruzhuriqi | DateTime | 8 | 19 | ||
| 11 | yudingren | 150 | 255 | |||
| 12 | beizhu | 1073741823 | 255 | |||
| 13 | issh | 30 | 255 | |||
| 14 | iszf | 30 | 255 | |||
| 15 | addtime | DateTime | 8 | 19 |
| 序號 | 字段名稱 | 字段類型 | 大小 | 允許為空 | 最大長度 | 備注 |
| 1 | id | Int | 4 | 10 | ||
| 2 | cheng | 150 | 255 | |||
| 3 | xingbie | 150 | 255 | |||
| 4 | | 150 | 255 | |||
| 5 | youxiang | 150 | 255 | |||
| 6 | shouji | 150 | 255 | |||
| 7 | neirong | 1073741823 | 255 | |||
| 8 | huifuneirong | 1073741823 | 255 | |||
| 9 | addtime | DateTime | 8 | 19 |
??
?
該系統是通過jdbc和MySQL達成連接的,新建一個jdbc.properties文件來填寫與數據庫連接所需要的驅動和參數。
jdbc.driverClass=com.MySQL.jdbc.Driver
jdbc.url=jdbc:MySQL://localhost:3306/tsi
jdbc.username=root
jdbc.password=123
第一個參數代表MySQL數據庫的驅動,第二個參數代表要連接的數據庫,第三個和第四個參數代表數據庫連接名和密碼。
后臺與數據庫訪問主要是通過HQL語句來進行查詢的,查詢語句中的表名是表格的實體類名,在這種查詢語句中*是不允許使用的,除非適合聚合函數一起使用才可以。
用戶在填寫數據的時候必須與注冊頁面上的驗證相匹配否則會注冊失敗,注冊頁面的表單驗證是通過JavaScript進行驗證的,用戶名的長度必須在6到18之間,郵箱必須帶有@符號,密碼和密碼確認必須相同,你輸入的密碼,系統會根據你輸入密碼的強度給出指定的值,電話號碼和身份證號碼必須要求輸入格式與生活相符合,當你前臺驗證通過的時候你點擊注冊,表單會將你輸入的值通過name值傳遞給后臺并保存到數據庫中。
用戶注冊流程圖如下圖所示。
?
圖5-1用戶注冊流程圖
用戶注冊界面如下圖所示。
?
圖5-2用戶注冊界面
用戶注冊的關鍵代碼如下。
/**
?????* 注冊
?????* @param user
?????* @return
?????*/
????@PostMapping("register")
????public Map<String, Object> signUp(@RequestBody User user) {
????????// 查詢用戶
????????Map<String, String> query = new HashMap<>();
????????query.put("username",user.getUsername());
????????List list = service.select(query, new HashMap<>()).getResultList();
????????if (list.size()>0){
????????????return error(30000, "用戶已存在");
????????}
????????user.setUserId(null);
????????user.setPassword(service.encryption(user.getPassword()));
????????service.save(user);
????????return success(1);
}
/**
?????* 用戶ID:[0,8388607]用戶獲取其他與用戶相關的數據
?????*/
????@Id
????@GeneratedValue(strategy = GenerationType.IDENTITY)
????@Column(name = "user_id")
????private Integer userId;
????/**
?????* 賬戶狀態:[0,10](1可用|2異常|3已凍結|4已注銷)
?????*/
????@Basic
????@Column(name = "state")
????private Integer state;
????/**
?????* 所在用戶組:[0,32767]決定用戶身份和權限
?????*/
????@Basic
????@Column(name = "user_group")
????private String userGroup;
????/**
?????* 上次登錄時間:
?????*/
????@Basic
????@Column(name = "login_time")
????private Timestamp loginTime;
????/**
?????* 手機號碼:[0,11]用戶的手機號碼,用于找回密碼時或登錄時
?????*/
????@Basic
????@Column(name = "phone")
????private String phone;
????/**
?????* 手機認證:[0,1](0未認證|1審核中|2已認證)
?????*/
????@Basic
????@Column(name = "phone_state")
????private Integer phoneState;
????/**
?????* 用戶名:[0,16]用戶登錄時所用的賬戶名稱
?????*/
????@Basic
????@Column(name = "username")
????private String username;
????/**
?????* 昵稱:[0,16]
?????*/
????@Basic
????@Column(name = "nickname")
????private String nickname;
????/**
?????* 密碼:[0,32]用戶登錄所需的密碼,由6-16位數字或英文組成
?????*/
????@Basic
????@Column(name = "password")
????private String password;
????/**
?????* 郵箱:[0,64]用戶的郵箱,用于找回密碼時或登錄時
?????*/
????@Basic
????@Column(name = "email")
????private String email;
????/**
?????* 郵箱認證:[0,1](0未認證|1審核中|2已認證)
?????*/
????@Basic
????@Column(name = "email_state")
????private Integer emailState;
????/**
?????* 頭像地址:[0,255]
?????*/
????@Basic
????@Column(name = "avatar")
????private String avatar;
????/**
?????* 創建時間:
?????*/
????@Basic
????@Column(name = "create_time")
????@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
????private Timestamp createTime;
????@Basic
????@Transient
????private String code;
}
主要由兩部分組成,登錄前的登錄界面以及登錄后的用戶功能界面。登錄界面,要求用戶輸入用戶名和密碼,當用戶名和密碼其中一個輸入為空時,給出提示“用戶名,密碼不能為空”。獲取用戶名和密碼后到數據庫中查找,如果用戶名存在,以及對應的密碼正確,則登錄成功,否則登錄失敗。登錄失敗后給出提示,并把焦點停在文本框中。登錄成功后將該次會話的全局變量username設置為用戶名。登錄成功后進入會員的功能模塊,主要有會員基本信息修改,已經發布商品信息管理,發布信息,和退出功能。退出功能是清除全局變量username的值,并跳回到首頁。
登錄流程圖如下圖所示。
?
圖5-3登錄流程圖
用戶登錄界面如下圖所示。
?
圖5-4用戶登錄界面
用戶登錄的關鍵代碼如下。
/**
?????* 登錄
?????* @param data
?????* @param httpServletRequest
?????* @return
?????*/
????@PostMapping("login")
????public Map<String, Object> login(@RequestBody Map<String, String> data, HttpServletRequest httpServletRequest) {
????????log.info("[執行登錄接口]");
????????String username = data.get("username");
????????String email = data.get("email");
????????String phone = data.get("phone");
????????String password = data.get("password");
????????List resultList = null;
????????Map<String, String> map = new HashMap<>();
????????if(username != null && "".equals(username) == false){
????????????map.put("username", username);
????????????resultList = service.select(map, new HashMap<>()).getResultList();
????????}
????????else if(email != null && "".equals(email) == false){
????????????map.put("email", email);
????????????resultList = service.select(map, new HashMap<>()).getResultList();
????????}
????????else if(phone != null && "".equals(phone) == false){
????????????map.put("phone", phone);
????????????resultList = service.select(map, new HashMap<>()).getResultList();
????????}else{
????????????return error(30000, "賬號或密碼不能為空");
????????}
????????if (resultList == null || password == null) {
????????????return error(30000, "賬號或密碼不能為空");
????????}
????????//判斷是否有這個用戶
????????if (resultList.size()<=0){
????????????return error(30000,"用戶不存在");
????????}
????????User byUsername = (User) resultList.get(0);
????????Map<String, String> groupMap = new HashMap<>();
????????groupMap.put("name",byUsername.getUserGroup());
????????List groupList = userGroupService.select(groupMap, new HashMap<>()).getResultList();
????????if (groupList.size()<1){
????????????return error(30000,"用戶組不存在");
????????}
????????UserGroup userGroup = (UserGroup) groupList.get(0);
????????//查詢用戶審核狀態
????????if (!StringUtils.isEmpty(userGroup.getSourceTable())){
????????????String sql = "select examine_state from "+ userGroup.getSourceTable() +" WHERE user_id = " + byUsername.getUserId();
????????????String res = String.valueOf(service.runCountSql(sql).getSingleResult());
????????????if (res==null){
????????????????return error(30000,"用戶不存在");
????????????}
????????????if (!res.equals("已通過")){
????????????????return error(30000,"該用戶審核未通過");
????????????}
????????}
????????//查詢用戶狀態
????????if (byUsername.getState()!=1){
????????????return error(30000,"用戶非可用狀態,不能登錄");
????????}
????????String md5password = service.encryption(password);
????????if (byUsername.getPassword().equals(md5password)) {
????????????// 存儲Token到數據庫
????????????AccessToken accessToken = new AccessToken();
????????????accessToken.setToken(UUID.randomUUID().toString().replaceAll("-", ""));
????????????accessToken.setUser_id(byUsername.getUserId());
????????????tokenService.save(accessToken);
????????????// 返回用戶信息
????????????JSONObject user = JSONObject.parseObject(JSONObject.toJSONString(byUsername));
????????????user.put("token", accessToken.getToken());
????????????JSONObject ret = new JSONObject();
????????????ret.put("obj",user);
????????????return success(ret);
????????} else {
????????????return error(30000, "賬號或密碼不正確");
????????}
}
用戶登錄/注冊成功之后可以修改自己的基本信息。修改頁面的表單中每一個input的name值都要與實體類中的參數相匹配,在用戶點擊修改頁面的時候,如果改后用戶名與數據庫里面重復了,頁面會提示該用戶名已經存在了,否則通過Id來查詢用戶,并將用戶的信息修改為表單提交的數據。
如果民宿資訊的信息需要修改,管理員可以通過查詢民宿資訊的基本信息來查詢民宿資訊,查詢民宿資訊是通過ajax技術來進行查詢的,需要傳遞民宿資訊的標題、編號等參數然后在返回到該頁面中,可以選中要修改或刪除的那條信息,如果選中了超過一條數據,頁面會挑一個窗口提醒只能選擇一條數,如果沒有選中數據會挑一個窗口題型必須選擇一條數據。當選擇確認修改的時候,后臺會根據傳過來的id到數據庫查詢,并將結果返回到修改頁面中,可以在修改頁面中修改剛剛選中的信息當點擊確認的時候from表單會將修改的數據提交到后臺并保存到數據庫中,就是說如果提交的數據數據庫中存在就修改,否則就保存。
民宿資訊展示界面如下圖所示。
?
圖5-5民宿資訊展示界面
民宿資訊管理界面如下圖所示。
?
圖5-6民宿資訊管理界面
民宿資訊發布的關鍵代碼如下。
?@PostMapping("/add")
????@Transactional
????public Map<String, Object> add(HttpServletRequest request) throws IOException {
????????service.insert(service.readBody(request.getReader()));
????????return success(1);
????}
????@Transactional
????public Map<String, Object> addMap(Map<String,Object> map){
????????service.insert(map);
????????return success(1);
}
????public Map<String,Object> readBody(BufferedReader reader){
????????BufferedReader br = null;
????????StringBuilder sb = new StringBuilder("");
????????try{
????????????br = reader;
????????????String str;
????????????while ((str = br.readLine()) != null){
????????????????sb.append(str);
????????????}
????????????br.close();
????????????String json = sb.toString();
????????????return JSONObject.parseObject(json, Map.class);
????????}catch (IOException e){
????????????e.printStackTrace();
????????}finally{
????????????if (null != br){
????????????????try{
????????????????????br.close();
????????????????}catch (IOException e){
????????????????????e.printStackTrace();
????????????????}
????????????}
????????}
????????return null;
}
????public void insert(Map<String,Object> body){
????????StringBuffer sql = new StringBuffer("INSERT INTO ");
????????sql.append("`").append(table).append("`").append(" (");
????????for (Map.Entry<String,Object> entry:body.entrySet()){
????????????sql.append("`"+humpToLine(entry.getKey())+"`").append(",");
????????}
????????sql.deleteCharAt(sql.length()-1);
????????sql.append(") VALUES (");
????????for (Map.Entry<String,Object> entry:body.entrySet()){
????????????Object value = entry.getValue();
????????????if (value instanceof String){
????????????????sql.append("'").append(entry.getValue()).append("'").append(",");
????????????}else {
????????????????sql.append(entry.getValue()).append(",");
????????????}
????????}
????????sql.deleteCharAt(sql.length() - 1);
????????sql.append(")");
????????log.info("[{}] - 插入操作:{}",table,sql);
????????Query query = runCountSql(sql.toString());
????????query.executeUpdate();
????}
用戶可以查看活動信息。具體包括活動名稱、活動類型、活動日期等內容。
活動信息流程圖如下圖所示。
?
圖5-7活動信息流程圖
活動信息列表界面如下所示。
?
圖5-8活動信息列表界面
民宿預訂功能整體流程:用戶瀏覽民宿信息時,同時會顯示民宿的狀態,系統會在其顯示詳細信息的頁面時便會判斷民宿的狀態,若民宿狀態為可預訂,則會顯示預訂的鏈接按鈕。在用戶點擊預訂按鈕時,會先通過攔截器判斷用戶是否登錄,若未登錄,會跳轉至登錄頁面,提示用戶先登錄,若為登錄用戶就會跳轉至填寫預訂信息的頁面,填寫好預訂信息之后,點擊提交按鈕,預訂成功之后返回提示信息,告知用戶預訂成功。
民宿預訂流程圖如下圖所示。
?
圖5-9民宿預訂流程圖
民宿預訂界面如下圖所示。
?
圖5-10民宿預訂界面
住宿訂單管理界面如下圖所示。
?
圖5-11住宿訂單管理界面
民宿預訂關鍵代碼如下。
@RequestMapping(value = {"/avg_group", "/avg"})
public Map<String, Object> avg(HttpServletRequest request) {
????????Query count = service.avg(service.readQuery(request), service.readConfig(request));
????????return success(count.getResultList());
}
根據需求,需要對民宿信息進行添加、刪除或修改詳情信息。刪除或修改民宿信息時,系統根據民宿信息的狀態判定為可刪除狀態下,才會給出刪除和修改鏈接,點擊刪除鏈接按鈕時,請求到達后臺,還會先查詢民宿信息狀態再次做出判定能否刪除。點擊修改鏈接按鈕時,會跳轉到修改信息的頁面,重新填寫好數據后,數據提交到后臺會對數據庫中相應的記錄做出修改。
添加民宿信息時,會給出數據填寫的頁面,該頁面根據填寫好的民宿信息編號同樣會事先發送Ajax請求查詢編號是否已存在,數據填寫好之后提交到后臺,會調用相關服務在數據庫中插入記錄。
民宿信息管理流程圖如下圖所示。
?
圖5-20民宿信息管理流程圖
民宿信息添加頁面設計效果如下圖所示。
?
圖5-21民宿信息添加界面
民宿信息管理頁面效果如下圖所示。
?
圖5-22民宿信息管理界面
民宿信息管理的關鍵代碼如下。
@RestController
@RequestMapping("auth")
public class AuthController extends BaseController<Auth, AuthService> {
????/**
?????* 服務對象
?????*/
????@Autowired
????public AuthController(AuthService service) {
????????setService(service);
????}
}
對任何系統而言,測試都是必不可少的環節,測試可以發現系統存在的很多問題,所有的軟件上線之前,都應該進行充足的測試之后才能保證上線后不會Bug頻發,或者是功能不滿足需求等問題的發生。下面分別從單元測試,功能測試和用例測試來對系統進行測試以保證系統的穩定性和可靠性。
下表是民宿信息管理功能的測試用例,檢測了民宿信息管理中對民宿信息信息的增加,刪除,修改,查詢操作是否成功運行。觀察系統的響應情況,得出該功能也達到了設計目標,系統運行正確。
前置條件;用戶登錄系統。
表6-1 民宿信息管理的測試用例
| 功能描述 | 用于民宿信息管理 | |
| 測試目的 | 檢測民宿信息管理時的各種操作的運行情況 | |
| 測試數據以及操作 | 預期結果 | 實際結果 |
| 點擊添加民宿信息,必填項合法輸入,點擊保存 | 提示添加成功 | 與預期結果一致 |
| 點擊添加民宿信息,必填項輸入不合法,點擊保存 | 提示必填項不能為空 | 與預期結果一致 |
| 點擊修改民宿信息,必填項修改為空,點擊保存 | 提示必填項不能為空 | 與預期結果一致 |
| 點擊修改民宿信息,必填項輸入不合法,點擊保存 | 提示必填項不能為空 | 與預期結果一致 |
| 點擊刪除民宿信息,選擇民宿信息刪除 | 提示刪除成功 | 與預期結果一致 |
| 點擊搜索民宿信息,輸入存在的民宿信息名 | 查找出民宿信息 | 與預期結果一致 |
| 點擊搜索民宿信息,輸入不存在的民宿信息名 | 不顯示民宿信息 | 與預期結果一致 |
下表是住宿訂單管理功能的測試用例,檢測了住宿訂單管理中住宿訂單的操作是否成功運行。觀察系統的響應情況,得出該功能也達到了設計目標,系統運行正確。
前置條件;用戶登錄系統。
表6-2 住宿訂單管理的測試用例
| 功能描述 | 用于住宿訂單管理 | |
| 測試目的 | 檢測住宿訂單管理時各種操作的情況 | |
| 測試數據以及操作 | 預期結果 | 實際結果 |
| 未選擇客房,點擊提交 | 提示請選擇客房 | 與預期結果一致 |
| 未輸入數量,點擊提交 | 提示請輸入數量 | 與預期結果一致 |
| 未輸入時間,點擊提交 | 提示請輸入時間 | 與預期結果一致 |
使用阿里云PTS(Performance Testing Service)性能測試服務對線上系統進行壓力測試。線上服務器環境為:1核心CPU,1G內存,1Mbps公網帶寬,Centos7.0操作系統。
壓測過程中使用了2臺并發機器,每臺機器20個用戶并發,對系統主頁,登錄,數據查詢和數據維護等模塊進行并發訪問,測試結果是有40個用戶并發時,數據管理相關頁面的響應時間甚至達到了7s,通過查看服務器出網流量發現已經達到1381kb/s,可以看出服務器的帶寬已經達到峰值,如果系統使用5Mbps的帶寬,系統的響應時間和TPS將會大大增加。在整個測試的過程中,CPU的使用率占用僅8%,也提現出帶寬瓶頸對系統的影響非常嚴重。
隨著計算機互聯網技術的迅猛發展,各行各業都已經實現采用計算機相關技術對日益放大的數據進行管理。該課題是民宿網站為核心展開的,主要是為了實現民宿信息管理和用戶在線預訂的需求。
民宿網站的開發是以Springboot框架作為基礎,在Eclipse平臺上完成編碼工作,系統整體為B/S架構,數據庫系統使用MySQL。文中詳細分析了民宿網站的研究背景、研究目的和意義、開發工具和相關技術以及系統需求、系統詳細設計和系統測試等等一系列內容。系統實現了民宿網站所需的一些基本功能,并通過測試對這些實現的功能進行了完善,進而提高了系統整體的實用性。整個系統的開發過程中大量使用了Java相關的知識以及前端開發使用的html和javascript等,同時涉及到了很多開源框架和組件,例如后臺系統中運用的MVVM架構、Freemarker模板引擎等,前端運用的UI框架等。
網站投入運行時,各功能均運行正常。網站的每個界面的操作符合常規邏輯,對使用者來說操作簡單,界面友好。整個網站的各個功能設計合理,體現了人性化。
但是由于自己在網站開發過程中對一些用到的相關知識和技術掌握不夠牢固,再加上自身開發經驗欠缺,因此系統在有些方面的功能還不夠完善,考慮的不夠全面,因此整個網站還有待日后逐步完善。
參考文獻
[1]陳長松. 個性化推薦民宿在線預定平臺的設計與實現[D].南昌大學,2021.
[2]吳有進.泛三亞旅游圈民宿營銷體系建設研究[J].商業文化,2021(11):16-17.
[3]劉奕.5G網絡技術對提升4G網絡性能的研究[J].數碼世界,2020(04):24.
[4]唐瑋,簡雪.探析酒店業對民宿業發展的影響[J].現代經濟信息,2020(13):356-357.
[5]王立娟.基于智能門鎖的民宿管理平臺的研發方案[J].電子測試,2020(11):96-97+78.
[6]潘玥. 傳承與特色[D].南京林業大學,2020.
[7]扈玉潔. “時養山居”民宿項目營銷策略研究[D].山東大學,2020.
[8]閔思夢.共享經濟背景下民宿旅游市場發展對策[J].邊疆經濟與文化,2020(05):26-27.
[9]易佳興,楊麗,吳青,符小青.靖港古鎮民宿開發運營策略分析[J].旅游縱覽(下半月),2020(06):127-128.
[10]張鑫. 基于智能推薦的自動售賣系統設計[D].天津工業大學,2020.
[11]廈門市集美區人民政府關于落實廈門市民宿管理暫行辦法的實施意見[J].廈門市人民政府公報,2020(03):32-34.
[12]侯玉霞,王美鈺.南嶺走廊民族村寨民宿開發研究——以湖南省勾藍瑤寨為例[J].民族論壇,2019(03):88-94.
[13]張妍. 基于Android的民宿租賃管理系統的設計與實現[D].大連海事大學,2019.
[14]薛馳宇.探究共享經濟下互聯網+民宿的現狀與對策[J].智庫時代,2019(30):294+296.
[15]沈欣黎.民宿產業市場現狀分析與發展構思——基于關聯因素與未來模式的探討[J].商場現代化,2018(13):177-178.2018.13.103.
[16]周劍.“互聯網+”下溫州民宿競爭力提升策略研究[J].商場現代化,2018(10):89-91.
[17]陳曉倩. 基于養生養老旅游與民宿資源對接的新媒體應用創新研究[D].浙江傳媒學院,2018.
[18]陳舜. “享客網”在線客棧服務平臺的管理創新與啟示研究[D].西南財經大學,2018.
[19]李琳. 民宿房屋預定系統的設計與實現[D].吉林大學,2018.
[20]程靜.一種基于云服務的酒店管理系統的設計[J].甘肅科技縱橫,2018,45(07):22-24.
[21] Hu Yujie Research on marketing strategy of "shiyangshanju" home stay project [D] Shandong University, 2020
?[22]Min Simeng Development Countermeasures of home stay tourism market under the background of sharing economy [J] Frontier economy and culture, 2020 (05): 26-27
?[23]Zhang Xin Design of automatic selling system based on Intelligent Recommendation [D] Tianjin University of technology, 2020
?[24]Hou Yuxia, Wang Meiyu Study on the development of home stay in ethnic villages in Nanling corridor -- Taking GouLan Yao village in Hunan Province as an example [J] National Forum, 2019 (03): 88-94
?[25]Xue Chiyu Explore the status quo and Countermeasures of Internet plus residential areas under the shared economy [J]. Think tank era, 2019 (30): 294 + 296
致謝
本次設計歷時3個月。在這個畢業設計中,它離不開指導教師的指導,使事情基本順利。指導老師無論是在畢業設計歷經中,還是在論文做完中都給了了我特別大的助益。另1個方面,教師認真負責的工作姿態,謹慎的教學精神厚重的理論水準都使我獲益匪淺。他勤懇謹慎的教學育人學習姿態也給我留下了特別特別深的感覺。我從老師那里學到了很多東西。在理論和實踐中,我的技能得到了特別大的提高。在此,特向教師表示由衷的感激。
經過對該畢業設計的全部研究和開發,我的系統研發經歷了從需求分析到實現詳細功能,再到最終測試和維護的特殊進展。讓我對系統研發有了更深層次的認識。如今我的動手本領單獨處理疑惑的本領也獲取到了特別大的演練學習增多,這是這次畢業設計最好的收獲。
最后,在整個系統開發過程中,我周圍的同學和朋友給了我很多意見,所以我很快就確認了系統的商業思想。在次,我由衷的向他們表示感激。
免費領取本源代碼,請關注點贊+私聊
總結
以上是生活随笔為你收集整理的(附源码)springboot民宿网站 毕业设计 221901的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: MAtlab wavefront,这是张
- 下一篇: @Resource详解