Java后端接收前端数据的五种方法

 更新时间:2025年08月24日 11:07:52   作者:hqxstudying  
本文概述了前后端分离中Vue与Java的数据交互方式,包括JSON、表单、URL参数、文件上传及路径参数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

在前后端分离的开发模式中,前端(Vue)与后端(Java)的数据交互有多种格式,下面详细介绍几种常见的格式以及后端对应的接收方式。

一、JSON 格式

前端传输

在 Vue 里,可借助 axios 把数据以 JSON 格式发送给后端,示例如下:

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

后端接收

后端的 Java 代码可以使用 Spring MVC 框架,通过@RequestBody注解来接收 JSON 数据,示例如下:

@PostMapping("/api/user")
public User createUser(@RequestBody User user) {
    // 处理接收到的user对象
    return user;
}

这里需要有一个与 JSON 数据结构相匹配的 Java 类,例如:

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

二、表单数据(Form Data)

前端传输

在 Vue 中,可通过表单或者 FormData 对象来发送表单数据,示例如下:

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 框架,通过@RequestParam注解来接收表单数据,示例如下:

@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 编码参数

前端传输

在 Vue 中,可以将参数附加在 URL 后面进行传输,示例如下:

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

后端接收

后端的 Java 代码还是使用 Spring MVC 框架,通过@RequestParam注解来接收 URL 编码参数,示例如下:

@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 对象来上传文件,示例如下:

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

后端接收

后端的 Java 代码使用 Spring MVC 框架,通过@RequestParamMultipartFile来接收文件,示例如下:

@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 "上传失败,因为文件为空";
    }
}

五、路径参数

前端传输

在 Vue 中,可将参数嵌入 URL 路径中进行传输,示例如下:

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

后端接收

后端的 Java 代码使用 Spring MVC 框架,通过@PathVariable注解来接收路径参数,示例如下:

@GetMapping("/api/user/{id}")
public User getUser(@PathVariable("id") Long id) {
    // 根据id获取用户
    User user = userService.getUserById(id);
    return user;
}

总结

前端格式后端接收方式适用场景
JSON@RequestBody复杂对象传输
表单数据@RequestParam 或 MultipartFile表单提交、文件上传
URL 编码参数@RequestParam简单参数查询
文件上传MultipartFile上传文件
路径参数@PathVariableRESTful API 中的资源标识

在实际开发过程中,要依据具体的业务场景来挑选合适的数据传输格式和接收方式。同时,还需要处理好异常情况,像数据验证、错误处理等,以确保接口的稳定性和安全性。

到此这篇关于Java后端接收前端数据的吴种方法的文章就介绍到这了,更多相关Java后端接收前端数据内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java中的CAS和自旋锁详解

    Java中的CAS和自旋锁详解

    这篇文章主要介绍了Java中的CAS和自旋锁详解,CAS算法(Compare And Swap),即比较并替换,是一种实现并发编程时常用到的算法,Java并发包中的很多类都使用了CAS算法,需要的朋友可以参考下
    2023-10-10
  • Struts2学习笔记(6)-简单的数据校验

    Struts2学习笔记(6)-简单的数据校验

    这篇文章主要介绍Struts2中的数据校验,通过一个简单的例子来说明,希望能给大家做一个参考。
    2016-06-06
  • SpringCloud 如何使用feign时的复杂参数传递

    SpringCloud 如何使用feign时的复杂参数传递

    这篇文章主要介绍了SpringCloud 如何使用feign时的复杂参数传递方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • Spring cloud gateway设置context-path服务路由404排查过程

    Spring cloud gateway设置context-path服务路由404排查过程

    这篇文章主要介绍了Spring cloud gateway设置context-path服务路由404排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • Java实现俄罗斯方块游戏的示例代码

    Java实现俄罗斯方块游戏的示例代码

    俄罗斯方块是一个最初由阿列克谢帕吉特诺夫在苏联设计和编程的益智类视频游戏。本文将利用Java实现这一经典的小游戏,感兴趣的可以动手试一试
    2022-03-03
  • Java无界阻塞队列DelayQueue详细解析

    Java无界阻塞队列DelayQueue详细解析

    这篇文章主要介绍了Java无界阻塞队列DelayQueue详细解析,DelayQueue是一个支持时延获取元素的无界阻塞队列,队列使用PriorityQueue来实现,队列中的元素必须实现Delayed接口,在创建元素时可以指定多久才能从队列中获取当前元素,需要的朋友可以参考下
    2023-12-12
  • java实现将字符串中首字母转换成大写,其它全部转换成小写的方法示例

    java实现将字符串中首字母转换成大写,其它全部转换成小写的方法示例

    这篇文章主要介绍了java实现将字符串中首字母转换成大写,其它全部转换成小写的方法,涉及java字符串遍历、转换、拼接等相关操作技巧,需要的朋友可以参考下
    2019-06-06
  • SpringBoot项目docker容器部署实现

    SpringBoot项目docker容器部署实现

    本文主要介绍了SpringBoot项目docker容器部署实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-03-03
  • Springboot中实现策略模式+工厂模式的方法

    Springboot中实现策略模式+工厂模式的方法

    这篇文章主要介绍了Springboot中实现策略模式+工厂模式,具体策略模式和工厂模式的UML我就不给出来了,使用这个这两个模式主要是防止程序中出现大量的IF ELSE IF ELSE....,接下来咱们直接实现Springboot策略模式工厂模式
    2022-03-03
  • Java 中的字符串替换方法之replace, replaceAll 和 replaceFirst示例详解

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

    在Java中,字符串的替换是一种常见的操作,特别是在处理文本和格式化输出时,本文将详细讨论这些方法的用法、区别以及示例,感兴趣的朋友一起看看吧
    2024-12-12

最新评论