宅男在线永久免费观看网直播,亚洲欧洲日产国码无码久久99,野花社区在线观看视频,亚洲人交乣女bbw,一本一本久久a久久精品综合不卡

全部
常見問題
產品動態(tài)
精選推薦

Spring Boot 2.x基礎教程:快速入門

管理 管理 編輯 刪除

在您第1次接觸和學習Spring框架的時候,是否因為其繁雜的配置而退卻了?在你第n次使用Spring框架的時候,是否覺得一堆反復黏貼的配置有一些厭煩?那么您就不妨來試試使用Spring Boot來讓你更易上手,更簡單快捷地構建Spring應用!

Spring Boot讓我們的Spring應用變的更輕量化。我們不必像以前那樣繁瑣的構建項目、打包應用、部署到Tomcat等應用服務器中來運行我們的業(yè)務服務。通過Spring Boot實現(xiàn)的服務,只需要依靠一個Java類,把它打包成jar,并通過java -jar命令就可以運行起來。這一切相較于傳統(tǒng)Spring應用來說,已經變得非常的輕便、簡單。

總結一下Spring Boot的主要優(yōu)點:

  • 為所有Spring開發(fā)者更快的入門
  • 開箱即用,提供各種默認配置來簡化項目配置
  • 內嵌式容器簡化Web項目
  • 沒有冗余代碼生成和XML配置的要求

快速入門

本文我們將學習如何快速的創(chuàng)建一個Spring Boot應用,并且實現(xiàn)一個簡單的Http請求處理。通過這個例子對Spring Boot有一個初步的了解,并體驗其結構簡單、開發(fā)快速的特性。

一、創(chuàng)建基礎項目

Spring官方提供了非常方便的工具Spring Initializropen in new window來幫助我們創(chuàng)建Spring Boot應用。

1、使用Spring Initializr頁面創(chuàng)建

第一步:訪問Spring Initializr:https://start.spring.io/

3496d202412101633599805.png

如圖所示,幾個選項說明:

  • Project:使用什么構建工具,Maven還是Gradle;本教程將采用大部分Java人員都熟悉的Maven,以方便更多讀者入門學習。
  • Language:使用什么編程語言,Java、Kotlin還是Groovy;本教程將采用Java為主編寫,以方便更多讀者入門學習。
  • Spring Boot:選用的Spring Boot版本;這里將使用當前最新的2.1.3版本。
  • Project Metadata:項目的元數據;其實就是Maven項目的基本元素,點開More options可以看到更多設置,根據自己組織的情況輸入相關數據,比如:

debd1202412101634502180.png

  • Dependencies:選擇要加入的Spring Boot組件;本文將實現(xiàn)一個Http接口,所以可以選擇Web組件,只需要輸入Web,頁面會自動聯(lián)想顯示匹配的可選組件:

64123202412101635169336.png

點擊”+“之后,就如下圖所示:

5d65a20241210163526764.png

第二步:點擊”Generate Project“按鈕生成項目;此時瀏覽器會下載一個與上面Artifact名稱一樣的壓縮包。

第三步:解壓項目包,并用編譯器以Maven項目導入,以IntelliJ IDEA為例:

  • 菜單中選擇:File –> New –> Project from Existing Sources...

4895f202412101636278737.png

  • 選擇解壓后的項目文件夾,點擊OK
  • 點擊:Import project from external model,并選擇Maven,點擊Next到底為止。
  • 若你的環(huán)境有多個版本的JDK,注意到選擇Java SDK的時候請選擇Java 8(具體根據你在第一步中選擇的Java版本為準)

2、使用IntelliJ IDEA創(chuàng)建

如果是使用IntelliJ IDEA來寫Java程序的話,那么還可以直接在編譯器中創(chuàng)建Spring Boot應用。

第一步:菜單欄中選擇:File => New => Project..,我們可以看到如下圖所示的創(chuàng)建功能窗口。

988df202412101636589113.png

其中Initial Service Url指向的地址就是Spring官方提供的Spring Initializr工具地址,所以這里創(chuàng)建的工程實際上也是基于它的Web工具來實現(xiàn)的。

第二步:點擊Next,等待片刻后,我們可以看到如下圖所示的工程信息窗口:

320f9202412101637066435.png

其實內容就跟我們用Web版的Spring Initializr是一模一樣的,跟之前在頁面上一樣填寫即可。

第三步:繼續(xù)點擊Next,進入選擇Spring Boot版本和依賴管理的窗口:

54b6b202412101637148350.png

在這里值的我們關注的是,它不僅包含了Spring Boot Starter POMs中的各個依賴,還包含了Spring Cloud的各種依賴。

第四步:點擊Next,進入最后關于工程物理存儲的一些細節(jié)。最后,點擊Finish就能完成工程的構建了。

Intellij中的Spring Initializr雖然還是基于官方Web實現(xiàn),但是通過工具來進行調用并直接將結果構建到我們的本地文件系統(tǒng)中,讓整個構建流程變得更加順暢,還沒有體驗過此功能的Spring Boot/Cloud愛好者們不妨可以嘗試一下這種不同的構建方式。

二、項目結構解析

d35e1202412101637294964.png

通過上面步驟完成了基礎項目的創(chuàng)建。如上圖所示,Spring Boot的基礎結構共三個文件(具體路徑根據用戶生成項目時填寫的Group所有差異):

  • src/main/java下的程序入口:Chapter11Application
  • src/main/resources下的配置文件:application.properties
  • src/test/下的測試入口:Chapter11ApplicationTests

生成的Chapter11ApplicationChapter11ApplicationTests類都可以直接運行來啟動當前創(chuàng)建的項目,由于目前該項目未配合任何數據訪問或Web模塊,程序會在加載完Spring之后結束運行。


三、項目依賴解析

打開pom.xml,一起來看看Spring Boot項目的依賴:



    4.0.0
    
        org.springframework.boot
        spring-boot-starter-parent
        2.1.3.RELEASE
         
    
    com.didispace
    chapter1-1
    0.0.1-SNAPSHOT
    chapter1-1
    Demo project for Spring Boot

    
        1.8
    

    
        
            org.springframework.boot
            spring-boot-starter-web
        

        
            org.springframework.boot
            spring-boot-starter-test
            test
        
    

    
        
            
                org.springframework.boot
                spring-boot-maven-plugin
            
        
    

如上所示,主要有四個部分:

  • 項目元數據:創(chuàng)建時候輸入的Project Metadata部分,也就是Maven項目的基本元素,包括:groupId、artifactId、version、name、description等
  • parent:繼承spring-boot-starter-parent的依賴管理,控制版本與打包等內容
  • dependencies:項目具體依賴,這里包含了spring-boot-starter-web用于實現(xiàn)HTTP接口(該依賴中包含了Spring MVC);spring-boot-starter-test用于編寫單元測試的依賴包。更多功能模塊的使用我們將在后面的教程中逐步展開。
  • build:構建配置部分。默認使用了spring-boot-maven-plugin,配合spring-boot-starter-parent就可以把Spring Boot應用打包成JAR來直接運行。


四、編寫一個HTTP接口

  • 創(chuàng)建package命名為com.didispace.web(根據實際情況修改)
  • 創(chuàng)建HelloController類,內容如下:
@RestController
public class HelloController {

    @RequestMapping("/hello")
    public String index() {
        return "Hello World";
    }

}
  • 啟動主程序,使用PostMan等工具發(fā)起請求:http://localhost:8080/hello,可以看到頁面返回:Hello World

五、編寫單元測試用例

打開的src/test/下的測試入口Chapter11ApplicationTests類。下面編寫一個簡單的單元測試來模擬http請求,具體如下:

import static org.hamcrest.Matchers.equalTo;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.content;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;


@RunWith(SpringRunner.class)
@SpringBootTest
public class Chapter11ApplicationTests {

    private MockMvc mvc;

    @Before
    public void setUp() throws Exception {
        mvc = MockMvcBuilders.standaloneSetup(new HelloController()).build();
    }

    @Test
    public void getHello() throws Exception {
        mvc.perform(MockMvcRequestBuilders.get("/hello").accept(MediaType.APPLICATION_JSON))
                .andExpect(status().isOk())
                .andExpect(content().string(equalTo("Hello World")));
    }

}

使用MockServletContext來構建一個空的WebApplicationContext,這樣我們創(chuàng)建的HelloController就可以在@Before函數中創(chuàng)建并傳遞到MockMvcBuilders.standaloneSetup()函數中。

注意引入下面內容,讓status、content、equalTo函數可用

import static org.hamcrest.Matchers.equalTo;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.content;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;

至此已完成目標,通過Maven構建了一個空白Spring Boot項目,再通過引入web模塊實現(xiàn)了一個簡單的請求處理。

注:本文轉載自“程序猿DD”,如有侵權,請聯(lián)系刪除!

請登錄后查看

哈哈哈醬 最后編輯于2024-12-18 15:08:50

快捷回復
回復
回復
回復({{post_count}}) {{!is_user ? '我的回復' :'全部回復'}}
排序 默認正序 回復倒序 點贊倒序

{{item.user_info.nickname ? item.user_info.nickname : item.user_name}} LV.{{ item.user_info.bbs_level || item.bbs_level }}

作者 管理員 企業(yè)

{{item.floor}}# 同步到gitee 已同步到gitee {{item.is_suggest == 1? '取消推薦': '推薦'}}
{{item.is_suggest == 1? '取消推薦': '推薦'}}
沙發(fā) 板凳 地板 {{item.floor}}#
{{item.user_info.title || '暫無簡介'}}
附件

{{itemf.name}}

{{item.created_at}}  {{item.ip_address}}
打賞
已打賞¥{{item.reward_price}}
{{item.like_count}}
{{item.showReply ? '取消回復' : '回復'}}
刪除
回復
回復

{{itemc.user_info.nickname}}

{{itemc.user_name}}

回復 {{itemc.comment_user_info.nickname}}

附件

{{itemf.name}}

{{itemc.created_at}}
打賞
已打賞¥{{itemc.reward_price}}
{{itemc.like_count}}
{{itemc.showReply ? '取消回復' : '回復'}}
刪除
回復
回復
查看更多
打賞
已打賞¥{{reward_price}}
1277
{{like_count}}
{{collect_count}}
添加回復 ({{post_count}})

相關推薦

快速安全登錄

使用微信掃碼登錄
{{item.label}} 加精
{{item.label}} {{item.label}} 板塊推薦 常見問題 產品動態(tài) 精選推薦 首頁頭條 首頁動態(tài) 首頁推薦
取 消 確 定
回復
回復
問題:
問題自動獲取的帖子內容,不準確時需要手動修改. [獲取答案]
答案:
提交
bug 需求 取 消 確 定
打賞金額
當前余額:¥{{rewardUserInfo.reward_price}}
{{item.price}}元
請輸入 0.1-{{reward_max_price}} 范圍內的數值
打賞成功
¥{{price}}
完成 確認打賞

微信登錄/注冊

切換手機號登錄

{{ bind_phone ? '綁定手機' : '手機登錄'}}

{{codeText}}
切換微信登錄/注冊
暫不綁定
CRMEB客服

CRMEB咨詢熱線 咨詢熱線

400-8888-794

微信掃碼咨詢

CRMEB開源商城下載 源碼下載 CRMEB幫助文檔 幫助文檔
返回頂部 返回頂部
CRMEB客服