欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java后端接收前端數(shù)據(jù)的五種方法

 更新時(shí)間:2025年08月24日 11:07:52   作者:hqxstudying  
本文概述了前后端分離中Vue與Java的數(shù)據(jù)交互方式,包括JSON、表單、URL參數(shù)、文件上傳及路徑參數(shù),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

在前后端分離的開(kāi)發(fā)模式中,前端(Vue)與后端(Java)的數(shù)據(jù)交互有多種格式,下面詳細(xì)介紹幾種常見(jiàn)的格式以及后端對(duì)應(yīng)的接收方式。

一、JSON 格式

前端傳輸

在 Vue 里,可借助 axios 把數(shù)據(jù)以 JSON 格式發(fā)送給后端,示例如下:

axios.post('/api/user', {
  username: 'john',
  age: 30
})

后端接收

后端的 Java 代碼可以使用 Spring MVC 框架,通過(guò)@RequestBody注解來(lái)接收 JSON 數(shù)據(jù),示例如下:

@PostMapping("/api/user")
public User createUser(@RequestBody User user) {
    // 處理接收到的user對(duì)象
    return user;
}

這里需要有一個(gè)與 JSON 數(shù)據(jù)結(jié)構(gòu)相匹配的 Java 類,例如:

public class User {
    private String username;
    private Integer age;
    
    // getters and setters
}

二、表單數(shù)據(jù)(Form Data)

前端傳輸

在 Vue 中,可通過(guò)表單或者 FormData 對(duì)象來(lái)發(fā)送表單數(shù)據(jù),示例如下:

const formData = new FormData();
formData.append('username', 'john');
formData.append('age', 30);
 
axios.post('/api/user', formData, {
  headers: {
    'Content-Type': 'multipart/form-data'
  }
})

后端接收

后端的 Java 代碼同樣可以使用 Spring MVC 框架,通過(guò)@RequestParam注解來(lái)接收表單數(shù)據(jù),示例如下:

@PostMapping("/api/user")
public User createUser(
    @RequestParam("username") String username,
    @RequestParam("age") Integer age
) {
    User user = new User();
    user.setUsername(username);
    user.setAge(age);
    return user;
}

三、URL 編碼參數(shù)

前端傳輸

在 Vue 中,可以將參數(shù)附加在 URL 后面進(jìn)行傳輸,示例如下:

axios.get('/api/user?username=john&age=30') 

后端接收

后端的 Java 代碼還是使用 Spring MVC 框架,通過(guò)@RequestParam注解來(lái)接收 URL 編碼參數(shù),示例如下:

@GetMapping("/api/user")
public User getUser(
    @RequestParam("username") String username,
    @RequestParam("age") Integer age
) {
    User user = new User();
    user.setUsername(username);
    user.setAge(age);
    return user;
}

四、文件上傳

前端傳輸

在 Vue 中,可使用 FormData 對(duì)象來(lái)上傳文件,示例如下:

const formData = new FormData();
formData.append('file', file); // file是文件對(duì)象
 
axios.post('/api/upload', formData, {
  headers: {
    'Content-Type': 'multipart/form-data'
  }
})

后端接收

后端的 Java 代碼使用 Spring MVC 框架,通過(guò)@RequestParamMultipartFile來(lái)接收文件,示例如下:

@PostMapping("/api/upload")
public String handleFileUpload(@RequestParam("file") MultipartFile file) {
    if (!file.isEmpty()) {
        try {
            // 處理文件上傳
            byte[] bytes = file.getBytes();
            // 保存文件等操作
            return "上傳成功";
        } catch (Exception e) {
            return "上傳失敗: " + e.getMessage();
        }
    } else {
        return "上傳失敗,因?yàn)槲募榭?;
    }
}

五、路徑參數(shù)

前端傳輸

在 Vue 中,可將參數(shù)嵌入 URL 路徑中進(jìn)行傳輸,示例如下:

axios.get('/api/user/123') 

后端接收

后端的 Java 代碼使用 Spring MVC 框架,通過(guò)@PathVariable注解來(lái)接收路徑參數(shù),示例如下:

@GetMapping("/api/user/{id}")
public User getUser(@PathVariable("id") Long id) {
    // 根據(jù)id獲取用戶
    User user = userService.getUserById(id);
    return user;
}

總結(jié)

前端格式后端接收方式適用場(chǎng)景
JSON@RequestBody復(fù)雜對(duì)象傳輸
表單數(shù)據(jù)@RequestParam 或 MultipartFile表單提交、文件上傳
URL 編碼參數(shù)@RequestParam簡(jiǎn)單參數(shù)查詢
文件上傳MultipartFile上傳文件
路徑參數(shù)@PathVariableRESTful API 中的資源標(biāo)識(shí)

在實(shí)際開(kāi)發(fā)過(guò)程中,要依據(jù)具體的業(yè)務(wù)場(chǎng)景來(lái)挑選合適的數(shù)據(jù)傳輸格式和接收方式。同時(shí),還需要處理好異常情況,像數(shù)據(jù)驗(yàn)證、錯(cuò)誤處理等,以確保接口的穩(wěn)定性和安全性。

到此這篇關(guān)于Java后端接收前端數(shù)據(jù)的吳種方法的文章就介紹到這了,更多相關(guān)Java后端接收前端數(shù)據(jù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java中的CAS和自旋鎖詳解

    Java中的CAS和自旋鎖詳解

    這篇文章主要介紹了Java中的CAS和自旋鎖詳解,CAS算法(Compare And Swap),即比較并替換,是一種實(shí)現(xiàn)并發(fā)編程時(shí)常用到的算法,Java并發(fā)包中的很多類都使用了CAS算法,需要的朋友可以參考下
    2023-10-10
  • Struts2學(xué)習(xí)筆記(6)-簡(jiǎn)單的數(shù)據(jù)校驗(yàn)

    Struts2學(xué)習(xí)筆記(6)-簡(jiǎn)單的數(shù)據(jù)校驗(yàn)

    這篇文章主要介紹Struts2中的數(shù)據(jù)校驗(yàn),通過(guò)一個(gè)簡(jiǎn)單的例子來(lái)說(shuō)明,希望能給大家做一個(gè)參考。
    2016-06-06
  • SpringCloud 如何使用feign時(shí)的復(fù)雜參數(shù)傳遞

    SpringCloud 如何使用feign時(shí)的復(fù)雜參數(shù)傳遞

    這篇文章主要介紹了SpringCloud 如何使用feign時(shí)的復(fù)雜參數(shù)傳遞方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • Spring cloud gateway設(shè)置context-path服務(wù)路由404排查過(guò)程

    Spring cloud gateway設(shè)置context-path服務(wù)路由404排查過(guò)程

    這篇文章主要介紹了Spring cloud gateway設(shè)置context-path服務(wù)路由404排查過(guò)程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • Java實(shí)現(xiàn)俄羅斯方塊游戲的示例代碼

    Java實(shí)現(xiàn)俄羅斯方塊游戲的示例代碼

    俄羅斯方塊是一個(gè)最初由阿列克謝帕吉特諾夫在蘇聯(lián)設(shè)計(jì)和編程的益智類視頻游戲。本文將利用Java實(shí)現(xiàn)這一經(jīng)典的小游戲,感興趣的可以動(dòng)手試一試
    2022-03-03
  • Java無(wú)界阻塞隊(duì)列DelayQueue詳細(xì)解析

    Java無(wú)界阻塞隊(duì)列DelayQueue詳細(xì)解析

    這篇文章主要介紹了Java無(wú)界阻塞隊(duì)列DelayQueue詳細(xì)解析,DelayQueue是一個(gè)支持時(shí)延獲取元素的無(wú)界阻塞隊(duì)列,隊(duì)列使用PriorityQueue來(lái)實(shí)現(xiàn),隊(duì)列中的元素必須實(shí)現(xiàn)Delayed接口,在創(chuàng)建元素時(shí)可以指定多久才能從隊(duì)列中獲取當(dāng)前元素,需要的朋友可以參考下
    2023-12-12
  • java實(shí)現(xiàn)將字符串中首字母轉(zhuǎn)換成大寫(xiě),其它全部轉(zhuǎn)換成小寫(xiě)的方法示例

    java實(shí)現(xiàn)將字符串中首字母轉(zhuǎn)換成大寫(xiě),其它全部轉(zhuǎn)換成小寫(xiě)的方法示例

    這篇文章主要介紹了java實(shí)現(xiàn)將字符串中首字母轉(zhuǎn)換成大寫(xiě),其它全部轉(zhuǎn)換成小寫(xiě)的方法,涉及java字符串遍歷、轉(zhuǎn)換、拼接等相關(guān)操作技巧,需要的朋友可以參考下
    2019-06-06
  • SpringBoot項(xiàng)目docker容器部署實(shí)現(xiàn)

    SpringBoot項(xiàng)目docker容器部署實(shí)現(xiàn)

    本文主要介紹了SpringBoot項(xiàng)目docker容器部署實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-03-03
  • Springboot中實(shí)現(xiàn)策略模式+工廠模式的方法

    Springboot中實(shí)現(xiàn)策略模式+工廠模式的方法

    這篇文章主要介紹了Springboot中實(shí)現(xiàn)策略模式+工廠模式,具體策略模式和工廠模式的UML我就不給出來(lái)了,使用這個(gè)這兩個(gè)模式主要是防止程序中出現(xiàn)大量的IF ELSE IF ELSE....,接下來(lái)咱們直接實(shí)現(xiàn)Springboot策略模式工廠模式
    2022-03-03
  • Java 中的字符串替換方法之replace, replaceAll 和 replaceFirst示例詳解

    Java 中的字符串替換方法之replace, replaceAll 和 rep

    在Java中,字符串的替換是一種常見(jiàn)的操作,特別是在處理文本和格式化輸出時(shí),本文將詳細(xì)討論這些方法的用法、區(qū)別以及示例,感興趣的朋友一起看看吧
    2024-12-12

最新評(píng)論