SpringMVC教程5[数据回写和异常处理及JSON操作]

简介: 一、数据回写 数据回写:在做数据更新的时候服务端查询的数据自动填充到表单中。

SpringMVC教程4[服务器端校验]

一、数据回写

   数据回写:在做数据更新的时候服务端查询的数据自动填充到表单中。

1.1默认方式

   通过前面讲解的 Map Mode ModelMap绑定数据

  @RequestMapping("/doLogin")
  public String doLogin(String username, String password, Model model) {
    if ("zhangsan".equals(username) && "123".equals(password)) {
      return "index";
    }
    model.addAttribute("username", username);
    model.addAttribute("password", password);
    return "forward:/login";
  }

页面中回写

<form action="/doLogin" method="post">
      <table>
        <tr>
          <td>用户名</td>
          <td><input type="text" name="username" value="${username}"></td>
        </tr>
        <tr>
          <td>密码</td>
          <td><input type="password" name="password" value="${password}"></td>
        </tr>
        <tr>
          <td><input type="submit" value="登录"></td>
        </tr>
      </table>
    </form>

2.通过Model方式

   如果使用对象去接收客户端传来的数据,那么对象默认会被自动放到model中,在前端页面可以直接使用对象中的数据。

   表单代码如下:

  /**
   *
   * 请求地址:
   * http://localhost:8080/SpringMVC-06-backvalue/
   * add1?username=a13&password=11111
   */
  @RequestMapping("/add1")
  public String add1(Book book) {
    System.out.println(book);
    return "/user.jsp";
  }

页面中

  <form action="add1" method="post">
    <table>
      <tr>
        <td>用户名</td>
        <td><input type="text" name="username"
          value="${book.username }"></td>
      </tr>
      <tr>
        <td>用户密码</td>
        <td><input type="text" name="password"
          value="${book.password }"></td>
      </tr>
      <tr>
        <td><input type="submit" value="注册"></td>
      </tr>
    </table>
  </form>

效果

image.png

3.@ModelAttribute注解实现

3.1 修改参数回显变量名

在需要回传的对象前添加@ModelAttribute(“bb”)注解,在界面中就可以通过bb前缀来获取回写信息。

image.pngimage.pngimage.png

3.2 配置全局变量名

   给接口中的每个方法统一返回一份数据

@Controller
public class UserController {
  /**
   *
   * 请求地址: http://localhost:8080/SpringMVC-06-backvalue/
   * add1?username=a13&password=11111
   */
  @RequestMapping("/add1")
  public String add1(@ModelAttribute("bb") Book book) {
    System.out.println(book);
    return "/user.jsp";
  }
  /**
   * 该类中的其他方法处理请求后都会绑定返回List集合,
   * 在页面中可以通过"as"作为key获取
   * @return
   */
  @ModelAttribute("as")
  public List<String> getAllAddress() {
    List<String> as = new ArrayList<>();
    as.add("深圳");
    as.add("广州");
    as.add("海口");
    return as;
  }
}

页面中获取

<body>
  获取全局配置返回的信息:<span style="color:red">${as}</span>
  <form action="add1" method="post">
    <table>
      <tr>
        <td>用户名</td>
        <td><input type="text" name="username"
          value="${bb.username }"></td>
      </tr>
      <tr>
        <td>用户密码</td>
        <td><input type="text" name="password"
          value="${bb.password }"></td>
      </tr>
      <tr>
        <td><input type="submit" value="注册"></td>
      </tr>
    </table>
  </form>
</body>

测试效果:

image.png

二、异常处理

   项目中的异常需要统一处理,正常情况下,需要提前准备好一个错误页面,当项目出错了,将该页面展示给用户。

   步骤:

2.1创建自定义异常类(可选)

/**
 * 自定义异常
 * 
 * @author dpb【波波烤鸭】
 *
 */
public class CustomException extends Exception {
  private String message;
  public CustomException(String message) {
    super(message);
    this.message = message;
  }
  @Override
  public String getMessage() {
    return message;
  }
  public void setMessage(String message) {
    this.message = message;
  }
}

2.2定义异常处理器

/**
 * 自定义异常处理器
 * @author dpb【波波烤鸭】
 *
 */
@Component //注意该类需要交给Spring容器管理
public class MyExceptionResolver implements HandlerExceptionResolver {
  @Override
  public ModelAndView resolveException(HttpServletRequest req
      , HttpServletResponse resp, Object obj,
      Exception ex) {
    System.out.println(ex.getMessage());
    ModelAndView mv = new ModelAndView();
    mv.setViewName("/error.jsp");
    return mv;
  }
}

2.3需要异常处理的地方抛出异常

image.png

2.4测试

image.pngimage.png

三、JSON数据交互

3.1响应JSON数据

1. 添加依赖:

   对于Gson和jackson这两个json处理依赖,直接添加即可。 除此之外,其他的json解析器如fastjson都需要手动配置HttpMessageConverter.

   实际上,在SpringMVC中,是由一个名叫HttpMessageConverter的类来提供对象到JSON字符串的转换的。而SpringMVC默认就提供了Gson和Jackson的HttpMessageConverter,分别是org.springframework.http.converter.json.GsonHttpMessageConverter和MappingJackson2HttpMessageConverter。对于其他的JSON解析器,只需要开发者手动配置一下HttpMessageConverter即可。

   本案例使用 jackson处理

<dependency>
  <groupId>com.fasterxml.jackson.core</groupId>
  <artifactId>jackson-core</artifactId>
  <version>2.5.2</version>
</dependency>
<dependency>
  <groupId>com.fasterxml.jackson.core</groupId>
  <artifactId>jackson-databind</artifactId>
  <version>2.5.2</version>
</dependency>

image.png

2.在返回对象上添加@ResponseBody注解即可

/**
 * JSON
 * 
 * @author dpb【波波烤鸭】
 *
 */
@Controller
public class UserController {
  @GetMapping("/user")
  @ResponseBody
  public User getUser() {
    User user = new User();
    List<String> favorites = new ArrayList<>();
    favorites.add("足球");
    favorites.add("篮球");
    user.setFavorites(favorites);
    user.setUsername("zhagnsan");
    user.setPassword("123");
    return user;
  }
  @GetMapping("/users")
  @ResponseBody
  public List<User> getALlUser() {
    List<User> users = new ArrayList<>();
    for (int i = 0; i < 10; i++) {
      User e = new User();
      e.setUsername("zhangsan:" + i);
      e.setPassword("pwd:" + i);
      users.add(e);
    }
    return users;
  }
  @GetMapping("/map")
  @ResponseBody
  public Map<String, Object> user() {
    HashMap<String, Object> map = new HashMap<>();
    map.put("total", 100);
    map.put("rows", "aaa");
    return map;
  }
}

3.测试

JSON对象

image.png描述JSON数组嵌套

image.png

Map返回JSON数据

image.png额外说明:

默认情况下,JSON处理的HttpMessageConverter在org.springframework.http.converter.support.AllEncompassingFormHttpMessageConverter类中,如果当前项目的classpath下有jackson或者gson的依赖,则会被该类自动加载,然后,创建相应的HttpMessageConverter。

对于fastjson,由于系统未提供自动支持,因此需要开发者手动配置fastjson的HttpMessageConverter,配置方式如下:

1.引入fastjson依赖

2.加入配置:

<mvc:annotation-driven validator="validatorFactoryBean">
    <mvc:message-converters>
      <bean
        class="com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter"></bean>
    </mvc:message-converters>
  </mvc:annotation-driven>

   HttpMessageConverter承担两个事:

   1.将请求结果转为json

   2.将浏览器发送来的json转为对象

3.2 接收JSON数据

   注意:json只能是在请求体中,因此,json只能放在post或者put请求中,注意,请勿使用get/delete请求去测试json参数传递。

   示例代码如下:

/**
 * JSON
 * 
 * @author dpb【波波烤鸭】
 *
 */
@Controller
public class UserController {
  @PostMapping("/test2")
  @ResponseBody
  public void test2(@RequestBody User user) {
    System.out.println(user);
  }
}

通过jquery的ajax发送json数据测试

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<script type="text/javascript" src="js/jquery.min.js"></script>
</head>
<body>
  <input type="button" value="提交JSON数据" onclick="fun1();">
  <script type="text/javascript">
    function fun1(){
      $.ajax({
                type: 'POST',
                url: "test2",
                contentType: "application/json",//如果想以json格式把数据提交到后台的话,这个必须有,否则只会当做表单提交
                data: JSON.stringify({"username":"sam","password":"12"}),//JSON.stringify()必须有,否则只会当做表单的格式提交
                dataType: "json",//期待返回的数据类型
                success: function(data){
                    alert("success:"+data);
                },
                error:function(data){
                    alert("error"+data); 
                }
              });
    }
  </script>
</body>
</html>

image.png服务端获取到了ajax提交的json数据

image.png在springmvc中,直接接收json参数,如果参数中有日期的话,不需要定义日期类型转换器,日期的转换由gson/jackson/fastjson来提供。



相关文章
|
19天前
|
SQL Java 数据库连接
对Spring、SpringMVC、MyBatis框架的介绍与解释
Spring 框架提供了全面的基础设施支持,Spring MVC 专注于 Web 层的开发,而 MyBatis 则是一个高效的持久层框架。这三个框架结合使用,可以显著提升 Java 企业级应用的开发效率和质量。通过理解它们的核心特性和使用方法,开发者可以更好地构建和维护复杂的应用程序。
110 29
|
30天前
|
JSON 缓存 API
解析电商商品详情API接口系列,json数据示例参考
电商商品详情API接口是电商平台的重要组成部分,提供了商品的详细信息,支持用户进行商品浏览和购买决策。通过合理的API设计和优化,可以提升系统性能和用户体验。希望本文的解析和示例能够为开发者提供参考,帮助构建高效、可靠的电商系统。
39 12
|
1月前
|
JSON 前端开发 搜索推荐
关于商品详情 API 接口 JSON 格式返回数据解析的示例
本文介绍商品详情API接口返回的JSON数据解析。最外层为`product`对象,包含商品基本信息(如id、name、price)、分类信息(category)、图片(images)、属性(attributes)、用户评价(reviews)、库存(stock)和卖家信息(seller)。每个字段详细描述了商品的不同方面,帮助开发者准确提取和展示数据。具体结构和字段含义需结合实际业务需求和API文档理解。
|
2月前
|
设计模式 前端开发 Java
步步深入SpringMvc DispatcherServlet源码掌握springmvc全流程原理
通过对 `DispatcherServlet`源码的深入剖析,我们了解了SpringMVC请求处理的全流程。`DispatcherServlet`作为前端控制器,负责请求的接收和分发,处理器映射和适配负责将请求分派到具体的处理器方法,视图解析器负责生成和渲染视图。理解这些核心组件及其交互原理,有助于开发者更好地使用和扩展SpringMVC框架。
69 4
|
3月前
|
前端开发 Java 开发者
Spring MVC中的请求映射:@RequestMapping注解深度解析
在Spring MVC框架中,`@RequestMapping`注解是实现请求映射的关键,它将HTTP请求映射到相应的处理器方法上。本文将深入探讨`@RequestMapping`注解的工作原理、使用方法以及最佳实践,为开发者提供一份详尽的技术干货。
234 2
|
3月前
|
JSON API 数据安全/隐私保护
拍立淘按图搜索API接口返回数据的JSON格式示例
拍立淘按图搜索API接口允许用户通过上传图片来搜索相似的商品,该接口返回的通常是一个JSON格式的响应,其中包含了与上传图片相似的商品信息。以下是一个基于淘宝平台的拍立淘按图搜索API接口返回数据的JSON格式示例,同时提供对其关键字段的解释
|
3月前
|
JSON 数据格式 索引
Python中序列化/反序列化JSON格式的数据
【11月更文挑战第4天】本文介绍了 Python 中使用 `json` 模块进行序列化和反序列化的操作。序列化是指将 Python 对象(如字典、列表)转换为 JSON 字符串,主要使用 `json.dumps` 方法。示例包括基本的字典和列表序列化,以及自定义类的序列化。反序列化则是将 JSON 字符串转换回 Python 对象,使用 `json.loads` 方法。文中还提供了具体的代码示例,展示了如何处理不同类型的 Python 对象。
|
3月前
|
JSON 缓存 前端开发
PHP如何高效地处理JSON数据:从编码到解码
在现代Web开发中,JSON已成为数据交换的标准格式。本文探讨了PHP如何高效处理JSON数据,包括编码和解码的过程。通过简化数据结构、使用优化选项、缓存机制及合理设置解码参数等方法,可以显著提升JSON处理的性能,确保系统快速稳定运行。
|
4月前
|
数据采集 JSON 数据处理
抓取和分析JSON数据:使用Python构建数据处理管道
在大数据时代,电商网站如亚马逊、京东等成为数据采集的重要来源。本文介绍如何使用Python结合代理IP、多线程等技术,高效、隐秘地抓取并处理电商网站的JSON数据。通过爬虫代理服务,模拟真实用户行为,提升抓取效率和稳定性。示例代码展示了如何抓取亚马逊商品信息并进行解析。
抓取和分析JSON数据:使用Python构建数据处理管道
|
8月前
|
XML Java 数据格式
SpringMVC的XML配置解析-spring18
SpringMVC的XML配置解析-spring18