Look My Eyes 最新IDEA快速搭建Java Web工程的兩種方式

Java Web 系列文章:

前言

創建Java Web工程屬于入門的知識,網上的文章也很多。本次基于最新的IDEA來闡述如何快速創建Java Web工程,并部署到本地最終通過瀏覽器訪問,希冀通過本篇文章讓大家對Java Web有個最直觀的認識。
通過本篇文章,你將了解到:

  1. 什么是Java Web?
  2. Java項目轉為Java Web
  3. 通過Maven創建Java Web
  4. 如何部署服務到Tomcat中?
  5. 總結

1. 什么是Java Web?

用三張圖說明:


image.png

我們手機上的App各式各樣,他們的共同點之一是隨時能夠刷新內容,靠的就是每個App都接上了互聯網,可以從網上獲取最新內容。
對應到代碼術語里的是:前端<--->服務端交互。
當前最常用的交互協議是TCP/IP,使用的應用層協議是HTTP協議,如下:


image.png

前端作為Http Client,服務端作為Http Server,共同為用戶提供服務。
繼續演變如下圖:


image.png

客戶端引入Http SDK,服務端引用Http SDK,通信交由該SDK負責。
對于服務端來說,只需要專注于寫具體的業務邏輯代碼,并根據計算得的數據渲染出前端頁面,最后返回給客戶端,我們通常稱此類的應用為Web應用。

而Java Web 是指使用 Java 技術構建 Web 應用程序的開發領域,它通常包括如下內容:

  1. Servlet:用于處理網絡請求和生成響應
  2. JSP:用于動態生成網頁的內容
  3. Tomcat:用于運行Servlet并提供Http 基礎服務(Http Server)
  4. 數據庫:用于持久化數據

因此一個最簡單的Web應用運行流程為:

接收客戶端請求-->處理請求-->讀寫數據庫-->返回處理后的數據-->渲染到頁面-->生成響應給客戶端

接下來我們探索如何快速創建Java Web項目,主要有兩種方式:

  1. Java項目轉為Java Web
  2. 通過Maven創建Java Web

2. Java 項目轉為Java Web

IDEA 版本:IntelliJ IDEA 2024.3.2 (Ultimate Edition)

  1. 新建項目,選擇Java,輸入項目名,此處使用的是Maven方式依賴


    image.png
  2. 創建成功后,查看Java項目結構


    image.png

    有一個入口函數,就是熟悉的Main函數,當我們運行該函數就可以看到打印,如此一個最簡單的Java工程搭建完成。

  3. 引入Web依賴
    上述步驟僅僅只是創建了純Java項目,現在需要使它變為Java Web項目,需要添加對應的依賴。
    打開項目結構:


    image.png

選擇添加Web模塊:


image.png

選擇之后點確定即可。


image.png

此時再來查看項目的結構。


image.png

可以看出,多出了個web的目錄,不過沒有視圖文件。

在web目錄上右鍵,選擇新建JSP文件:


image.png

新建后修改內容:


image.png

可以看出,JSP和HTML結構差不多,只是它里面可以插入Java代碼進行動態修改界面。

  1. 引入Tomcat
    經過上述步驟,我們創建好了Java Web項目,現在想讓這個項目跑起來。根據之前的分析,我們現在只是搭建好了服務,還需要借助Http Server來幫助我們收發Http請求,此處使用最常用的Web 容器:Tomcat。
    先下載Tomcat:
    官網:https://tomcat.apache.org/index.html
    根據不同的平臺下載對應的包,解壓即可。

編輯運行配置:


image.png

選擇本地的Tomcat:


image.png

找到之前下載的Tomcat,設置為Server,其他可暫時不用動。


image.png

可以看到右下角有個提示,點擊fix按鈕。


image.png

跳轉后選擇新建artifacts:
image.png

image.png

最后一路點擊確定按鈕。

回到工程后就會發現配置構建多了Tomcat選項:


image.png

此時我們直接點擊運行按鈕,項目就會部署到Tomcat里,自動跳轉到瀏覽器訪問:


image.png

如此一來,最簡單的沒有任何邏輯的Java Web搭建并運行成功,后續就可以完善數據的輸入輸出,完善頁面的顯示。

3. 通過Maven創建Java Web

上面的步驟還是有點繁瑣,現在我們的目的很明確,直接創建Java Web項目,而不是通過Java項目再轉Java Web項目。

  1. 新建項目,選擇Maven Archetype


    image.png

確定后查看項目結構:


image.png

此時Java Web目錄已經生成,可以看出此種方式比上一種方式快捷很多。

  1. 引入Tomcat
    與上一種方式類似:指定Tomcat與Deployment。


    image.png

此時運行項目:


image.png

成功展示頁面。

通過比較創建Java Web的兩種方式,第二種方式便捷了許多,推薦大家使用第二種方式創建Java Web項目。

4. 如何部署服務到Tomcat中?

上述我們都是直接點擊IDEA里的運行按鈕直接部署,觀察項目編譯產物:


image.png

產物放在target目錄下,當我們點擊IDEA的運行按鈕時,Tomcat將會加載target下的文件。
當客戶端發起請求時,Tomcat將會尋找到此處最終將UI返回給客戶端。

可以看出,此時的target目錄并沒有在Tomcat目錄下,那如何把target放在Tomcat目錄下呢?
分兩步:

  1. 構建War包


    image.png
image.png

構建之后查看target目錄,多了一個.war包。


image.png
  1. 將War包放到Tomcat目錄下
    找到Tomcat安裝目錄下的webapps,比如我的目錄:/usr/local/apache-tomcat-9.0.96/webapps
    將war包拷貝到該目錄下。

  2. 啟動Tomcat
    找到Tomcat安裝目錄下的,比如我的目錄:/usr/local/apache-tomcat-9.0.96/bin
    執行命令啟動tomcat(可能需要管理員權限):

mac/linux 下命令:./startup.sh
windows 下命令:./startup.bat

啟動后查看webapps目錄:


image.png

可以看出,.war包被自動解壓了。

  1. 通過瀏覽器訪問Java Web


    image.png

    注意此時的路徑是webapps下對應的.war包解壓后的目錄名。

5. 總結

以上我們實現了最簡單的Java Web項目的創建到部署的功能,接下來我們會往里面添加實現邏輯,比如接收客戶端的傳值、接收客戶端拉取數據等功能,讓大家逐漸了解Java Web開發流程。

下篇將重點分析Servlet的編寫、運行過程,敬請期待。
如果您覺得有幫助,記得一鍵三連哦~ 感謝感謝再感謝~

項目地址 持續維護中。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,119評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,382評論 3 415
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,038評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,853評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,616評論 6 408
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,112評論 1 323
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,192評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,355評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,869評論 1 334
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,727評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,928評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,467評論 5 358
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,165評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,570評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,813評論 1 282
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,585評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,892評論 2 372

推薦閱讀更多精彩內容