【Java EE】從零開始寫專案【總結】

Java3y發表於2018-03-31

從零開發專案概述

最近這一直在複習資料結構和演算法,也就是前面發出去的排序演算法八大基礎排序總結Java實現單向連結串列棧和佇列就是這麼簡單十道簡單演算法題等等...

被虐得不要不要的,即使是非常簡單有時候繞半天,想不明白。

本來這篇博文是想留到我最後Java基礎複習完再寫出來的,鑑於公眾號有的同學想看看郵箱登陸的案例,想看看Java開發後臺是怎麼的,於是我就提前寫了這篇博文

這個專案是我自己手寫的第一個SSM專案(畢竟學了當然得搞點事情,對吧),是上年寫的小東西。當然了,現在回過頭去看這個專案是有很多的不足的,僅供參考。用的也不是新技術,只是把我之前當時所學的一些東西做一個總結...如果想學新知識的同學看到這裡就可以留步啦~

所以說,你可能會看到比較舊的技術,寫得不好的地方都會有~如果是寫過專案的同學而言,這個僅僅是一個Demo。對於沒寫過專案的同學可以適當的參考一下,因為用的是非常簡單的技術,都是耳熟能詳的技術,不會有什麼難懂的地方~

PS:希望各位大佬不要攻擊它,我沒有做任何的安全措施。即使留了評論的功能,XSS攻擊防範也沒做,請手下留情啊~

地址:

編寫記錄:

從零開始寫專案第一篇【搭建環境】

從零開始寫專案第二篇【登陸註冊、聊天、收藏夾模組】

從零開始寫專案第三篇【線上聊天和個人收藏夾】

從零開始寫專案第四篇【搭建Linux環境】

從零開始寫專案第五篇【評論功能、備忘錄】

從零開始寫專案終極【維護網站、修復Bug】

一、功能介紹

巴巴拉拉地說了一大堆東西,我們來看一下這個專案有什麼功能~

這是首頁,會根據當地給出三天的天氣預報:

【Java EE】從零開始寫專案【總結】

很簡單的註冊頁面,通過郵箱來進行註冊~

【Java EE】從零開始寫專案【總結】

2018年3月30日15:51:23,好吧,寫這篇博文的時候也出錯了.....

org.springframework.mail.MailAuthenticationException: Authentication failed

我懷疑是授權傳送郵箱的密碼錯了(過時),於是我去更新了一下,果然就行了~

此時點選註冊,就會要郵箱校驗了~

【Java EE】從零開始寫專案【總結】

【Java EE】從零開始寫專案【總結】

去自己的郵箱檢視一下郵件:

【Java EE】從零開始寫專案【總結】

點選校驗它即可完成註冊(如果不校驗的話,那麼是不允許登陸的):

該專案用Shiro做了許可權認證的,如果沒在登陸的狀態下點選以下的選單都會跳轉到登陸頁面~:

【Java EE】從零開始寫專案【總結】


網站說明:

這個網站的功能並不複雜,開發的功能都是為了方便使用而已。

  • 一、個人收藏夾:將常用的網站新增進去,值得注意的地方就是:url(網址)最好是從瀏覽器複製下來,這是最方便也是最安全的做法
  • 二、個人備忘錄:新增個人備忘錄,設定好時間、在郵件傳送出去之前都能夠修改時間

【Java EE】從零開始寫專案【總結】

【Java EE】從零開始寫專案【總結】

傳送郵件好像會有點延遲~~~~

【Java EE】從零開始寫專案【總結】


接下來是個人收藏夾了,新增一些常用的網址進去,並給它命名,當輸入命名部分的字元時,即會提示

【Java EE】從零開始寫專案【總結】

【Java EE】從零開始寫專案【總結】

【Java EE】從零開始寫專案【總結】

用鍵盤上下鍵選中按回車即可跳轉到對應的頁面了~

二、技術介紹

網站用到的技術:

  • 一、全站頁面佈局:前端是使用Bootstrap來進行佈局的、背景是使用了GitHub的一個開源專案:particles-js。導航條來源於一個國外網站:http://toolofna.com/
  • 二、首頁:天氣預報功能來源於高德地圖API和和風天氣API組合而成,能夠檢視當前IP地址所在地的近三日天氣
  • 三、個人收藏夾:使用了Elasticsearch全文搜尋引擎工具。
  • 四、線上聊天:使用了GoEasy的服務推送和jquery.barrager.js構建彈幕。目前該功能並未完善,敬請期待。
  • 五、註冊和登陸:使用了BootstrapValidation進行表單校驗、JavaMail傳送郵件的功能、Gif動態驗證碼
  • 六、個人備忘錄:使用了Quartz任務排程工具來定時傳送郵件

總概要:

  •    1. Maven構建專案
  •    2. 使用Mysql資料庫
  •    3. Tomcat作用應用伺服器
  •    4. Dao層採用Mybatis,Controller層採用SpringMVC,Spring對Mybatis和SpringMVC進行整合和事務管理
  •    5. Shiro許可權管理框架控制登陸以及對個人收藏夾、線上聊天功能進行認證的管理
  •    6. 使用FreeMarker來渲染頁面和配置傳送郵箱的模版
  •    7. 使用Quartz和Spring整合,完成個人備忘錄的功能。
  •    8. 使用Nginx作為代理伺服器,對靜態資源處理,代理轉發

可以看到的是,網站的功能並不多,就幾個小模組,我就建立了三張表而已:

【Java EE】從零開始寫專案【總結】

三、談談編寫過程

其實所有的初學者都一樣:怎麼使用Java編寫一個網站?資料庫設計感覺好難,設計錯了就很麻煩了。Web前端好煩啊,自己寫的頁面不好看。這個功能感覺好難實現哦,應該是挺高深的技術吧。我的基礎還不夠紮實,等我學好了再寫吧,等等等..就一直有想寫網站的念頭,但一直沒開始動手。

上面的問題我都有想過,不過我還是寫了這麼一個小東西....

當時寫的練手專案都是視訊教程給出的題目,比如我之前發過的:移動商城專案總結納稅服務系統總結,jar包或者maven的座標都是有給出來的,專案的前臺頁面和資料庫標也大都是設計好的,我只需要補補填填寫Java程式碼。而這一次,前端頁面,資料庫設計,Maven座標等等全由自己包辦

從開始到編寫結束大概花了我一個月的時間,期間要去上課呀,回家呀,一些瑣事呀等等才拖了那麼久。如果自己從來沒寫過專案的同學建議自己折騰一下搞一個,期間能學到很多很多東西的。也不要怕自己寫得不好(只要像我一樣不要臉,不也將這麼一個小東西發到公眾號上來,發到其他的部落格平臺了麼)

那麼我自己折騰這麼一個小玩意能學到什麼了呢?

3.1搭建環境收穫

  • 在搭建環境的時候,不要覺得最新的版本就是牛逼,我要用最新的,不做過時的男人!我當時就是撘環境是用Spring5.0,Mysql驅動包6.x,jdk1.8,能用最新就用最新的,覺得自己賊牛逼。然後撘完專案就啟不動了~~~
  • 其實沒必要用最新的,最新的一般都會有bug,沒bug的也不一定相容其他的版本。要知道,Spring可不單單有Spring的東西,還依賴很多其他的jar包的。同樣Mysql用最新的驅動包,逆向工程時也不好使(我在SegementFault已經見過幾次跟我一樣遇到的坑)
  • 一般最新的東西資料都挺少的,除了官方文件,出了什麼問題都只能自己解決了。較老的版本就不一樣了,很多人都會遇到的問題,解決方案也會相當多~

當時我在圖書館撘了一個晚上,得出的教訓:

【Java EE】從零開始寫專案【總結】

3.2登陸與註冊收穫

登陸與註冊這個功能只要學過JavaWeb基礎的同學,肯定做過。反正我是做了很多很多次的了,學Servlet做一次,學JSP做一次,學AJAX做一次,學xxx系統做一次,學XXX商城做一次。反正每次都會有新的東西補充上去

一開始我本來想做的是可以使用微信登陸,也可以使用賬戶(郵箱)登陸,也可以使用簡訊登陸的。

後來發現微信登陸要企業認證,做不了。簡訊登陸要錢,不想給。

所以最後就只有用郵箱登陸了~~~當然了,該有的基本功能是有的

  • 加密密碼
  • 前臺校驗和後臺校驗引數
  • 忘記密碼,記住我功能
  • 驗證碼

由於之前是簡單學過Shiro的,當時覺得Shiro做許可權很方便,於是自己也想體驗一把~實際上用起來並沒有我當時學的時候那麼簡單!

在Shiro這一塊也耽誤了不少時間,因為我當時想的是使用AJAX來提交,如果正確則跳轉到首頁,如果密碼(引數..)等錯誤就返回JSON給使用者一個友好的提示。可是,Shiro的表單認證起預設返回的是一個頁面,在這裡就卡住了挺久的(有的時候沒bug,有的時候又有bug),百思不得其解...最後查閱了很多資料才將FormAuthenticationFilter改寫好,Shiro很多東西都是要自己重寫來進行控制的,當時理解後畫的流程圖:

【Java EE】從零開始寫專案【總結】

Shiro的“記住我”功能本來以為是很好用的,實則也挺雞肋的..當時我做的記錄:

【Java EE】從零開始寫專案【總結】

反正Shiro給我的感覺就是很多東西都要自己來重寫,控制,而如果是小範圍使用我覺得自己寫url控制會方便。也可能是我的學習姿勢不對~

在登陸註冊模組期間也自己去找了不少資料。

  • 資料庫設計上也是參考了網上和自己做了些許修改
  • JavaMail我之前是沒接觸過的
  • BootStrapValidation也是看中了就用,
  • 折騰Shiro幾天就更不用說了。

所以說,未必要使用自己熟悉的東西,只要想實現一些普通、你見過的功能,總會有方案可以參考

3.3個人收藏夾收穫

這個自動補全功能是我一開始想要做自己網站的時候想做的。因為我習慣了使用鍵盤去找檔案,去找東西。

比如,在windows下,我下了一個rolan,將常用的軟體丟進去,輸入一些關鍵字即提示我,然後我通過鍵盤上下選擇就可以開啟軟體了,十分方便

在編寫之前,我學過Lucene的相關知識,知道Lucene是全文搜尋索引的始祖(沒做過相關案例)【參考博文:Lucene就是這麼簡單】,後來知道Solr和Elasticsearch在企業上是用得挺火的,而Elasticsearch又是各種火熱,各種吹(哈哈哈,無貶義,是挺好用的)。

於是我就花了幾天從零開始學Elasticsearch,當時參考的博主給出的是2.3.3版本,我也覺得沒什麼,就使用了。那是最新是5.x~就有了後來的博文:【Elasticsearch就是這麼簡單

Elasticsearch遇到很多的問題都得去翻英文的,所以可以訪問外網也挺重要的~

我英語也不咋地,就慢慢看看,弄個Chrome外掛翻譯唄,事情總得解決,也就這麼成長的~

3.4搭建Linux環境收穫

在之前只會Linux一些非常簡單的命令,ls cd vi這些,用得少就忘記了,於是又得重新去回顧一下Linux(這個學期也開了Linux的課,我打算過一陣再總結Linux的常用命令和相關要點,敬請期待~)

花了點點錢買了臺雲伺服器(學生有優惠就10塊一個月),我也建議是在校的學生也可以買來自己玩玩,熟悉一下Linux命令,還有很多軟體都在Linux下才更好地支援(例如:Elasticsearch,Nginx),尤其Elasticsearch在windows下裝它簡直麻煩!

到了Linux階段,我也去學了下Nginx了。在沒學Nginx時我就經常聽說過這個HTTP伺服器了,但一直不知道它是幹嘛用的。它的最常見作用就兩個:

  • 處理靜態資源
  • 動態資源轉發到Web伺服器(Tomcat)

學學Nginx的配置檔案相關知識,是如何配置的,配置有什麼用~就可以使用了

3.5評論功能和備忘錄收穫

評論功能在資料庫設計上也有好幾種:

  • 將回復和評論都統一當成是評論,能夠使用@XXX來當做是回覆,類似與IOS知乎的評論【此做法是最簡單的】
  • 將回復和評論分開,要麼單表就多增加一個父屬性,要麼就分兩張表【稍微複雜,一個評論可以對應多個回覆】
  • 實現評論與回覆“蓋樓”的方式,這種就是網易的評論【此種是最複雜的】

我做的只是一個留言的功能,就直接使用第一種了~

對於備忘錄就得用到Quartz時間排程框架,之前接觸過,但用的使用還是出現了Bug

  • 在Junit測試Quartz沒有反應
  • Spring不能注入物件進Quartz的Job類中

如果業務簡單的話,下次也想玩玩Spring自帶的任務排程~

四、最後

上面簡要地介紹了我的小專案的功能和編寫過程,更詳細的業務得去看我下面的博文和原始碼了~也希望大家能夠有所收穫,自己動手做一個小專案~

現在看來很多沒有寫成規範(返回JSON、JavaScript模組化)等等,但畢竟是自己學程式設計的成長經歷,看回以前的程式碼總會有這種感覺。我短時間內也不做重構了,學Java基礎去~

後面的博文幾乎都是Java基礎或演算法(少量)了,希望大家多多支援哈,在校的日子我會盡量保持日更的~

【Java EE】從零開始寫專案【總結】

如果文章有錯的地方歡迎指正,大家互相交流。習慣在微信看技術文章,想要獲取更多的Java資源的同學,可以關注微信公眾號:Java3y

相關文章