当前位置: 首页 > 编程笔记 >

Spring MVC前后端的数据传输的实现方法

仲孙默
2023-03-14
本文向大家介绍Spring MVC前后端的数据传输的实现方法,包括了Spring MVC前后端的数据传输的实现方法的使用技巧和注意事项,需要的朋友参考一下

本篇文章主要介绍了Spring MVC中如何在前后端传输数据。具体内容如下所示:

后端——> 前端

在Spring MVC中这主要通过Model将数据从后端传送到前端,一般的写法为:

@RequestMapping(value = "/index", method = RequestMethod.POST)
public String index(Model model){
 String greeting = "Hello !"
 model.addAttribute("greetingStr", greeting);
 return "index";
}

首先需要定义一个Model,然后为Model添加属性,并绑定数据,最后将Model添加到视图。在实际开发时也可以不按照上述步骤。

不指定视图名

视图解析器会根据请求路径/index推断视图名,去掉/仍然可以得到正确的视图名index。此时的写法为:

@RequestMapping(value = "/index", method = RequestMethod.POST)
public String index(Model model){
 String greeting = "Hello !"
 return greeting;
}

不使用Model

因为Model本身就继承自LinkedHashMap类(Model本身只是一个接口类,确切的说是实例化的model所属的类继承自LinkedHashMap),因此可以将数据存储在Map中再传送到前端。此时的写法为:

@RequestMapping(value = "/index", method = RequestMethod.POST)
public String index(Map map){
 String greeting = "Hello !"
 map.put("greetingStr", greeting);
 return "index";
}

不指定模型属性

当不指定Model中填充数据的key时,Spring MVC会根据值类型推断,返回key的替代名。此时的写法为:

@RequestMapping(value = "/index", method = RequestMethod.POST)
public String index(Model model){
 String greeting = "Hello !"
 model.addAttribute(greeting);
 return "index";
}
//此时的"greeting"的key会被设置为"String",等价于map.put("String", greeting);

以上方式的结果都是一致的,均会在model中会存储一个和key对应的数据,然后将model传送到到视图中,视图可以根据key直接获取到对应的数据。

前端——> 后端

在Spring MVC中支持多种方式将数据从前端传送到后端。

查询参数

本质上是通过HTTP发起的一个带有参数的RPC请求,请求的形式为"/aa?name=deyken",后端处理形式为:

@RequestMapping(value = "/aa", method = RequestMethod.POST)
public String func(Model model, @RequestParam("name") String name) {
 ...
}

路径变量

直接请求资源,请求的形式为"/aa/deyken",后端处理的形式为:

@RequestMapping(value = "/aa/{name}", method = RequestMethod.POST)
public String func(Model model, @PathVariable("name") String name) {
 ...
}

实际使用中推荐第二种方式。

表单

在Spring MVC中同样支持表单数据的前端到后台传输。以用户登录为例,表单形式为:

<form acthtml" target="_blank">ion="/login" method="post">
 name:<input type="text" name="name"/>
 password:<input type="text" name="password"/>
 <input type="submit"/>
</form>

后端只需在方法参数列表里接收传送过来的变量,而无需再指定查询参数或路径变量:

@RequestMapping(value = "/login", method = RequestMethod.POST)
public String add(Model model, String name, String password){
 ...
}

如果已经定义过用户User类:

public User {
 String name;
 String password;
 ...Setter()
 ...Getter()
}

那么Spring MVC会将表单传送过来的数据自动封装为一个User对象,此时后端方法可以这么写:

@RequestMapping(value = "/login", method = RequestMethod.POST)
public String add(Model model, User user){
 ...
}

后记

以上仅描述了在Spring MVC中几种前后端数据交互的方式,但在实际项目中为了使前后端开发分离,一般不适用上述方式,下篇文章我将介绍使用ajax从前端读取后端数据的具体方法。

 类似资料:
  • 本文向大家介绍python实现udp数据报传输的方法,包括了python实现udp数据报传输的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Python实现UDP数据报传输的方法,非常具有实用价值。分享给大家供大家参考。具体方法分析如下: 服务端代码: 客户端代码: 结果:先运行服务端,然后运行客户端, 服务端打印出: 补充: socket.sendto(string[, flags

  • 本文向大家介绍SpringMVC 跨重定向请求传递数据的方法实现,包括了SpringMVC 跨重定向请求传递数据的方法实现的使用技巧和注意事项,需要的朋友参考一下 执行完post请求后,通常来讲一个最佳实践就是执行重定向。重定向将丢弃原始请求数据,原始请求中的模型数据和请求都会消亡。可以有效避免用户浏览器刷新或者后退等操作,直接间接地重复执行已经完成的post请求。 在控制方法中返回的视图名称中,

  • 本文向大家介绍实现前后端数据交互方法汇总,包括了实现前后端数据交互方法汇总的使用技巧和注意事项,需要的朋友参考一下 此文章适合前后端协同开发经验不足的新手阅读。 HTML赋值 输出到 Element 的 value 或 data-name 渲染结果 使用 JS 获取 优点: 不占用全局变量,由 JS 自由获取。 使用建议: 适合传递简单数据,也非常适合多个简单数据与 Element 绑定关系。 J

  • 本文向大家介绍使用post方法实现json往返传输数据的方法,包括了使用post方法实现json往返传输数据的方法的使用技巧和注意事项,需要的朋友参考一下 问题所在: 当我们想让应用层和http之间的所有接口都采用json,这样,客户端代码就可以纯碎用javascript的对象来编写,服务器打啊也可以纯粹的用Java的对象来编写。 我们使用的是post请求的方法,有些不同于get的方法! 客户端h

  • 本文向大家介绍Vue前后端不同端口的实现方法,包括了Vue前后端不同端口的实现方法的使用技巧和注意事项,需要的朋友参考一下 前端Vue 8080端口,后端Node.js 8085端口 主要记录下前后端不同端口遇到的问题 1、写服务器端程序,我的在(node_proxy/index.js)下 这段代码很重要,要是没有的话会出现 No 'Access-Control-Allow-Origin' hea

  • 本文向大家介绍微信小程序向Java后台传输参数的方法实现,包括了微信小程序向Java后台传输参数的方法实现的使用技巧和注意事项,需要的朋友参考一下 首先,微信小程序我使用的是微信web开发者工具 想要向后台传输数据,需要在js中写 在微信小程序的官方文档中可以看到一个api叫wx.request它的作用是用来发送https请求的 在js代码中,我们先使用wx.request这个api,它需要我们去