chapter05_构建Spring Web应用程序_3_接受请求的输入

本文详细介绍了SpringMVC中三种主要的参数接收方式:查询参数、路径参数和表单参数。阐述了@RequestParam和@PathVariable注解的使用,以及如何处理form提交参数,包括直接获取同名参数和用同名参数填充对象。同时,文章还讨论了如何进行参数校验和处理校验错误。
  • 接受请求的输入在SpringMVC中一共有3种方式

    (1) 查询参数

    (2) 路径参数

    (3) 表单参数

  • 处理查询参数

    (1) 在url中添加查询参数

    示例

      "/spittles?max=238900&count=50"
    

    (2) 处理方式:添加 @RequestParam注解

    示例

      @Controller
      @RequestMapping("/spittles")
      public class SpittleController {
    
          ...
    
          private static final String MAX_LONG_AS_STRING = "9223372036854775807";
    
          @RequestMapping(method = RequestMethod.GET)
          public String spittles(
              @RequestParam(value = "max", defaultValue = MAX_LONG_AS_STRING) long max,
              @RequestParam(value = "count", defaultValue = "20") int count,
              Model model) {
    
              model.addAttribute("spittleList", spittleRepository.findSpittles(max, count));
    
              return "spittles";
          }
    
          ...
      }
    

    @RequestParam的value属性用来指定参数名称(url和value要对应);

    @RequestParam的defaultValue属性用来指定默认值,由于查询参数都是String类型的,所以defaultValue的值一定要是String

  • 通过路径参数接受输入

    (1) 需求:根据id查询历史输入

    (2) 如果使用查询参数的方法@RequestParam,则会有如下代码

      @Controller
      @RequestMapping("/spittles")
      public class SpittleController {
    
          ...
    
          private static final String MAX_LONG_AS_STRING = "9223372036854775807";
    
          @RequestMapping(value="/show", method = RequestMethod.GET)
          public String spittle(
              @RequestParam(value = "spittle_id") long spittleId,
              Model model) {
    
              model.addAttribute("spittle", spittleRepository.findOne(spittleId));
    
              return "spittles";
          }
    
          ...
      }
    

    此时url应该为 "/spittles/show?spittle_id=xxx?",但是这样不好,我们希望的是做到 "/spittles/xxx"

    (3) 处理方式:添加@PathVariable注解

    示例

      @Controller
      @RequestMapping("/spittles")
      public class SpittleController {
    
          ...
    
          private static final String MAX_LONG_AS_STRING = "9223372036854775807";
    
          @RequestMapping(value = "/{spittleId}", method = RequestMethod.GET)
          public String spittle(
              @PathVariable("spittleId") long spittleId,
              Model model) {
    
              model.addAttribute("spittle", spittleRepository.findOne(spittleId));
    
              return "spittle";
          }
    
          ...
      }
    

    @PathVariable中的代表URL中/xxx的xxx部分,在方法上方的@RequestMapping中使用了占位符{}

  • 表单输入

    (1) 如果请求中包含大量数据,那么就不能使用查询参数路径参数

    (2) 当form中没有指定action属性时,代表提交表单的目标是当前页面本身

    (3) 在处理post类型的请求时,在请求处理完成后,最好进行一下重定向,这样浏览器的刷新就不会重复提交表单了

    示例

      @Controller
      @RequestMapping("/spitter")
      public class SpitterController {
    
          @RequestMapping(value = "/register", method = POST)
          public String processRegistration(
              String username, String password, String firstName, String lastName, String email) {
    
              ...
    
              return "redirect:/spitter/" + spitter.getUsername();
         }
      }
    

    (4) 接受form提交参数的两种方式(一):直接获取同名参数

    示例

    registerForm.jsp

      <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
      <%@ page session="false" %>
      <html>
        <head>
          <title>Spitter</title>
          <link rel="stylesheet" type="text/css" href="<c:url value="/resources/style.css" />" >
        </head>
        <body>
          <h1>Register</h1>
    
          <form method="POST">
            First Name: <input type="text" name="firstName" /><br/>
            Last Name: <input type="text" name="lastName" /><br/>
            Email: <input type="email" name="email" /><br/>
            Username: <input type="text" name="username" /><br/>
            Password: <input type="password" name="password" /><br/>
            <input type="submit" value="Register" />
          </form>
        </body>
      </html>
    

    SpitterController.java

      @Controller
      @RequestMapping("/spitter")
      public class SpitterController {
    
          @RequestMapping(value = "/register", method = POST)
          public String processRegistration(
              String username, String password, String firstName, String lastName, String email) {
    
              // If parameters check failed, go back to registerForm.jsp
              if (Spitter.checkIfInputParametersHaveErrors(username, password, firstName, lastName, email)) {
    
                  return "registerForm";
              }
    
              Spitter spitter = new Spitter(username, password, firstName, lastName, email);
    
              spitterRepository.save(spitter);
    
              return "redirect:/spitter/" + spitter.getUsername();
         }
      }
    

    其中,username, password, firstName, lastName, email几个参数在jsp文件和Controller文件中是一一对应的。这种方式比较直观,但是写起来繁琐,特别是要进行输入参数检查的时候

    (5)接受form提交参数的两种方式(一):用同名参数填充对象

    示例

    registerForm.jsp 同上个示例

    SpitterController.java

      @Controller
      @RequestMapping("/spitter")
      public class SpitterController {
    
          @RequestMapping(value = "/register", method = POST)
          public String processRegistration(Spitter spitter) {
    
              spitterRepository.save(spitter);
    
              return "redirect:/spitter/" + spitter.getUsername();
          }
      }
    

    Spitter.java

      public class Spitter {
    
          ...
    
          public Spitter(String username, String password, String firstName, String lastName, String email) {
              this(null, username, password, firstName, lastName, email);
          }
    
          public Spitter(Long id, String username, String password, String firstName, String lastName, String email) {
       
              this.id = id;
              this.username = username;
              this.password = password;
              this.firstName = firstName;
              this.lastName = lastName;
              this.email = email;
          }
    
          ...
      }
    

    直接使用同名的参数填充进Spitter的构造函数中

    (6) 校验form

    可以不使用Java的校验API自己手动编写代码校验,但是这样比较麻烦;

    比较好的方式是在Spitter类中添加Java的校验API,从Spring3.0起添加了对Java校验API的支持

    示例 Spitter.java

      import javax.validation.constraints.NotNull;
      import javax.validation.constraints.Size;
      import org.hibernate.validator.constraints.Email;
    
      public class Spitter {
    
          private Long id;
    
          @NotNull
          @Size(min = 5, max = 16)
          private String username;
    
          @NotNull
          @Size(min = 5, max = 25)
          private String password;
    
          @NotNull
          @Size(min = 2, max = 30)
          private String firstName;
    
          @NotNull
          @Size(min = 2, max = 30)
          private String lastName;
    
          @NotNull
          @Email
          private String email;
    
          public Spitter() {
          }
    
          public Spitter(String username, String password, String firstName, String lastName, String email) {
              this(null, username, password, firstName, lastName, email);
          }
    
          public Spitter(Long id, String username, String password, String firstName, String lastName, String email) {
          
              this.id = id;
              this.username = username;
              this.password = password;
              this.firstName = firstName;
              this.lastName = lastName;
              this.email = email;
          }
    
          ...
      }
    

    (7) Java API提供的几个常用校验注解

    @AssertTrue

    @Digits

    @Max

    @Min

    @NotNull

    @Size

    @Pattern

    (8) 在Controller中启用校验功能: @Valid + Errors

    示例

    SpitterController.java

      @Controller
      @RequestMapping("/spitter")
      public class SpitterController {
    
          @RequestMapping(value = "/register", method = POST)
          public String processRegistration(@Valid Spitter spitter, Errors errors) {
    
              // If parameters check failed, go back to registerForm.jsp
              if (errors.hasErrors()) {
                  return "registerForm";
              }
    
              spitterRepository.save(spitter);
    
              return "redirect:/spitter/" + spitter.getUsername();
          }
      }
    

    在方法的参数上添加 @Valid注解会告知Spring对这个对象进行参数校验,如果校验出现错误的话,可以通过Errors对象访问到

    注意方法的参数顺序必须是 @Valid Mytype myType, Errors error不能改变

  • 重定向

      return "redirect:/xxx";
    
  • 转发

      return "forward:/xxx";
    
内容概要:本文档是一份关于交换路由配置的学习笔记,系统地介绍了网络设备的远程管理、交换机与路由器的核心配置技术。内容涵盖Telnet、SSH、Console三种远程控制方式的配置方法;详细讲解了VLAN划分原理及Access、Trunk、Hybrid端口的工作机制,以及端口镜像、端口汇聚、端口隔离等交换技术;深入解析了STP、MSTP、RSTP生成树协议的作用与配置步骤;在路由部分,涵盖了IP地址配置、DHCP服务部署(接口池与全局池)、NAT转换(静态与动态)、静态路由、RIP与OSPF动态路由协议的配置,并介绍了策略路由和ACL访问控制列表的应用;最后简要说明了华为防火墙的安全区域划分与基本安全策略配置。; 适合人群:具备一定网络基础知识,从事网络工程、运维或相关技术岗位1-3年的技术人员,以及准备参加HCIA/CCNA等认证考试的学习者。; 使用场景及目标:①掌握企业网络中常见的交换与路由配置技能,提升实际操作能力;②理解VLAN、STP、OSPF、NAT、ACL等核心技术原理并能独立完成中小型网络搭建与调试;③通过命令示例熟悉华为设备CLI配置逻辑,为项目实施和故障排查提供参考。; 阅读建议:此笔记以实用配置为主,建议结合模拟器(如eNSP或Packet Tracer)动手实践每一条命令,对照拓扑理解数据流向,重点关注VLAN间通信、路由选择机制、安全策略控制等关键环节,并注意不同设备型号间的命令差异。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值