溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

SpringBoot2中數(shù)據(jù)與頁(yè)面響應(yīng)的示例分析

發(fā)布時(shí)間:2022-03-22 13:38:04 來(lái)源:億速云 閱讀:128 作者:小新 欄目:開(kāi)發(fā)技術(shù)

這篇文章主要介紹了SpringBoot2中數(shù)據(jù)與頁(yè)面響應(yīng)的示例分析,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

1 數(shù)據(jù)響應(yīng)

SpringBoot2中數(shù)據(jù)與頁(yè)面響應(yīng)的示例分析

??數(shù)據(jù)響應(yīng)一般分為兩種:頁(yè)面響應(yīng)和數(shù)據(jù)響應(yīng),一般來(lái)說(shuō)頁(yè)面響應(yīng)是用來(lái)開(kāi)發(fā)一些單體項(xiàng)目(也就是前后端都在一個(gè)開(kāi)發(fā)工具中),而數(shù)據(jù)響應(yīng)則是用來(lái)進(jìn)行前后端分離開(kāi)發(fā)的項(xiàng)目,前端發(fā)送過(guò)來(lái)請(qǐng)求后端響應(yīng)相應(yīng)的數(shù)據(jù)。

1.1 數(shù)據(jù)響應(yīng)(JSON為例)

??如果想讓SpringMVC響應(yīng)返回一個(gè)JSON類型的數(shù)據(jù),首先需要在項(xiàng)目的pom.xml文件中導(dǎo)入web場(chǎng)景的啟動(dòng)器

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>

<!--web場(chǎng)景的啟動(dòng)器的底層導(dǎo)入了JSON的開(kāi)發(fā)場(chǎng)景-->
<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-json</artifactId>
	<version>2.6.4</version>
	<scope>compile</scope>
</dependency>

??其次就是在controller中加入@ResponseBody注解,這樣的話就是響應(yīng)數(shù)據(jù)而不是頁(yè)面跳轉(zhuǎn),或者將controller上的@Controller注解換成@RestController,相當(dāng)于這個(gè)controller下的所有方法都自動(dòng)加上了@ResponseBody注解。

SpringBoot2中數(shù)據(jù)與頁(yè)面響應(yīng)的示例分析

1.2 數(shù)據(jù)響應(yīng)之內(nèi)容協(xié)商

內(nèi)容協(xié)商: 服務(wù)器會(huì)根據(jù)客戶端接收能力的不同,返回不同媒體類型的數(shù)據(jù)。

原理: 前端發(fā)送請(qǐng)求的時(shí)候請(qǐng)求頭攜帶Accept字段,用于服務(wù)器聲明自己(客戶端)能夠接收的數(shù)據(jù)類型。

處理流程: 首先判斷當(dāng)前響應(yīng)頭中是否已經(jīng)有之前處理時(shí)緩存的媒體類型,如果沒(méi)有的話就是第一次處理需要確定處理的媒體類型,通過(guò)Accept字段獲取客戶(PostMan、瀏覽器)支持接收的內(nèi)容類型。經(jīng)過(guò)遍歷循環(huán)所有當(dāng)前系統(tǒng)的MessageConverter看誰(shuí)支持操作這個(gè)對(duì)象(Person),找到支持操作Person的converter之后把它支持的媒體類型統(tǒng)計(jì)出來(lái)。如此操作我們就得到了客戶端支持接受的類型和服務(wù)端能夠返回的類型,再通過(guò)內(nèi)容協(xié)商的最佳匹配媒體類型,用支持將對(duì)象轉(zhuǎn)為最佳匹配媒體類型converter。

2 頁(yè)面響應(yīng)

??SpringBoot默認(rèn)的打包方式是jar包方式,但是JSP不支持在jar包(一種壓縮包)中編譯,所以SpringBoot默認(rèn)不支持JSP,于是我們需要引入第三方的模板引擎技術(shù)——Thymeleaf實(shí)現(xiàn)頁(yè)面的渲染。

2.1 模板引擎之Thymeleaf

??要想使用Thymeleaf實(shí)現(xiàn)頁(yè)面的渲染的話,首先需要在pom.xml文件里引入它的場(chǎng)景啟動(dòng)器依賴

<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>

??在導(dǎo)入場(chǎng)景啟動(dòng)器之后,SpringBoot就會(huì)給我們?cè)赥hymeleafAutoConfiguration自動(dòng)配置類中配置好所有的相關(guān)組件,并將相關(guān)配置項(xiàng)與ThymeleafProperties.class(代碼如下)通過(guò)注解@EnableConfigurationProperties相關(guān)聯(lián),配置類中設(shè)置了默認(rèn)頁(yè)面跳轉(zhuǎn)的前綴和后綴,也就是規(guī)范了頁(yè)面存放的位置必須是templates文件夾和頁(yè)面的文件后綴必須是.html,我們只需要直接開(kāi)發(fā)頁(yè)面即可。

private String prefix = "classpath:/templates/";
private String suffix = ".html";

入門(mén)案例

第一步: templates文件夾下建個(gè)html文件 第二步: <html>標(biāo)簽引入templates命名空間,這樣的優(yōu)點(diǎn)就是在進(jìn)行頁(yè)碼編寫(xiě)的時(shí)候會(huì)有相關(guān)的提示信息

xmlns:th="http://www.thymeleaf.org"

第三步: 創(chuàng)建一個(gè)controller用于進(jìn)頁(yè)面跳轉(zhuǎn)

@Controller
public class ViewTestController {

   @GetMapping("/jump")
   public String jumpTo(Model model) {
       // 之前講過(guò)model的所有屬性值都會(huì)存儲(chǔ)在request域中,需要使用的時(shí)候直接使用
       model.addAttribute("msg", "你好,張三");
       model.addAttribute("link", "http://www.baidu.com");

       return "seccess";
   }
}

第四步: 編寫(xiě)頁(yè)面代碼獲取域中的值

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
   <meta charset="UTF-8">
   <title>Title</title>
</head>
<body>
   <h2 th:text="${msg}">哈哈</h2>

   <h3>
       <a th:href="${link}" rel="external nofollow" >點(diǎn)擊進(jìn)入百度</a>
       <a th:href="@{link}" rel="external nofollow" >點(diǎn)擊進(jìn)入百度</a>
   </h3>
</body>
</html>

SpringBoot2中數(shù)據(jù)與頁(yè)面響應(yīng)的示例分析

? ?頁(yè)面中兩種符號(hào)區(qū)別:${}是直接獲取到link屬性的值作為鏈接地址,而@{}是拼裝項(xiàng)目的訪問(wèn)路徑+符號(hào)里的值,對(duì)本案例而言:第一個(gè)鏈接是打開(kāi)百度,第二個(gè)是發(fā)送http://localhost:8080/link的請(qǐng)求

2.2 攔截器

??用戶登陸成功之后,再發(fā)送任意請(qǐng)求的時(shí)候都應(yīng)該是有個(gè)登錄判斷的過(guò)程(判斷session中是否有正確的用戶名和密碼),這個(gè)功能可以在每個(gè)controller使用代碼進(jìn)行判斷,但是這個(gè)過(guò)程是重復(fù)的會(huì)大大增加代碼的冗余,于是我們可以將判斷功能放在攔截器中,將登陸成功后的所有從頁(yè)面發(fā)送的請(qǐng)求攔截住進(jìn)行用戶判斷,成功則放行失敗則返回登錄。 以上述例子為例講解攔截器的使用: 第一步: 自定義攔截器(實(shí)現(xiàn)HandlerInterceptor接口,重寫(xiě)內(nèi)置方法在相應(yīng)的方法內(nèi)編寫(xiě)判斷邏輯)

public class LoginInterceptor implements HandlerInterceptor {
    // 在目標(biāo)方法執(zhí)行之前執(zhí)行的方法
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        // 實(shí)現(xiàn)登錄檢查的邏輯
        HttpSession session = request.getSession();
        Object user = session.getAttribute("loginUser");
        if (user != null) {
            // 已經(jīng)登錄,放行
            return true;
        }
        // 未登錄,重定向到登錄頁(yè)面
        request.setAttribute("msg", "請(qǐng)先登錄之后再進(jìn)行相關(guān)操作");
        request.getRequestDispatcher("/").forward(request, response);
        return false;
    }

    // 在目標(biāo)方法執(zhí)行之后執(zhí)行的方法
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {

    }

    // 頁(yè)面渲染之后執(zhí)行的方法
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {

    }
}

第二步: 自定義配置類實(shí)現(xiàn)WebMvcConfigurer接口,重寫(xiě)addInterceptors方法將攔截器注冊(cè)進(jìn)容器中,并指定攔截規(guī)則

@Configuration
public class AdminWebConfig implements WebMvcConfigurer {

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        // 有個(gè)問(wèn)題就是,攔截器攔截的不只是動(dòng)態(tài)請(qǐng)求,還有靜態(tài)的頁(yè)面資源和樣式,所以也要將靜態(tài)資源放行
        registry.addInterceptor(new LoginInterceptor())
                // 攔截所有的請(qǐng)求
                .addPathPatterns("/**")
                // 直接放行的請(qǐng)求
                .excludePathPatterns("/", "/login", "/css/**", "/fonts/**", "/js/**", "/images/**");
    }
}

2.3 文件上傳

??文件上傳需要前后端的協(xié)調(diào)配合,前端使用一個(gè)form表單提交所有的信息,包括單文件上傳和多文件上傳,后端使用注解獲取到表單中的所有值,對(duì)他們進(jìn)行操作 前端表單:

<form role="form" th:action="@{/upload}" method="post" enctype="multipart/form-data">
	<!--email郵箱-->
    <div class="form-group">
        <label for="exampleInputEmail1">Email address</label>
        <input type="email" name="email" class="form-control" id="exampleInputEmail1" placeholder="Enter email">
    </div>
    <!--userName用戶名-->
    <div class="form-group">
        <label for="exampleInputPassword1">userName</label>
        <input type="text" name="userName" class="form-control" id="exampleInputPassword1" placeholder="Password">
    </div>
    <!--單文件上傳 頭像-->
    <div class="form-group">
        <label for="exampleInputFile">headerImg</label>
        <input type="file" name="headerImg" id="exampleInputFile">
    </div>
    <!--多文件上傳 生活照-->
    <div class="form-group">
        <label for="exampleInputFile">image of yourself</label>
        <input type="file" name="photos" multiple >
    </div>
    <div class="checkbox">
        <label>
            <input type="checkbox"> Check me out
        </label>
    </div>
    <button type="submit" class="btn btn-primary">Submit</button>
</form>

后端controller:

@PostMapping("/upload")
public String upload(@RequestParam("email") String email,
                     @RequestParam("userName") String userName,
                     @RequestPart("headerImg")MultipartFile headerImg,
                     @RequestPart("photos")MultipartFile[] photos) throws IOException {
    // 將頭像保存到本地磁盤(pán)中
    if (!headerImg.isEmpty()) {
    	// 創(chuàng)建相應(yīng)的文件夾
        File file1 = new File("E:\\bootTest\\" + userName + "\\headerImg");
        file1.mkdirs();
        // 獲取圖片名 生成存儲(chǔ)路徑
        headerImg.transferTo(new File("E:\\bootTest\\" + userName + "\\headerImg\\" + headerImg.getOriginalFilename()));
    }

    // 將生活照保存到本地磁盤(pán)中
    if (photos.length > 0) {
    	// 創(chuàng)建相應(yīng)的文件夾
        File file1 = new File("E:\\bootTest\\" + userName + "\\photos");
        file1.mkdirs();
        // 存儲(chǔ)圖片
        for (MultipartFile photo:photos) {
            if (!photo.isEmpty()) {
                // 獲取圖片名 生成存儲(chǔ)路徑
                photo.transferTo(new File("E:\\bootTest\\" + userName + "\\photos\\" + photo.getOriginalFilename()));
            }
        }
    }

    return "index";
}

文件上傳的配置:

# 文件上傳大小的設(shè)置
spring:
servlet:
multipart:
# 單個(gè)文件的最大大小
max-file-size: 50MB
# 總文件的最大大小
max-request-size: 100MB

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“SpringBoot2中數(shù)據(jù)與頁(yè)面響應(yīng)的示例分析”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI