SpringMvc的常用注解

@RequestMapping()

SpringMvc通过@RequestMapping注解将URL请求与业务的方法进行映射,在控制器的类定义处定义方法处都可以添加@RequestMapping,在类定义处添加相当于多了一层访问路径。

  • value :指定URL请求的地址,是@RequestMapping的默认值。
  • method:请求的method类型包括 GET POST PUT DELETE
  • params 请求的参数
• @Controller
public class HellowHandler {
@RequestMapping (value = "/index",params = {"id=1","name=tom"})
public String index(){
System.out.println("接受到了请求");
//返回逻辑视图
return  "index";
}
}

参数绑定

params是对URL请求参数进行限制,不满足的URL不能访问,需要在业务方法中获取URL的参数值。

1.在业务方法定义时声明参数列表

2.给参数列表添加@RequsetParam 注解进行绑定

@Controller
public class HellowHandler {
    @RequestMapping (value = "/index",params = {"id"})
    public String index(@RequestParam("id") double id){
        System.out.println("接受到了请求"+"id="+id);
        //返回逻辑视图
        return  "index";
    }
}

Springmvc也支持RESTful风格的URL传参

@RequestMapping (value = "/index/{id}")
public String index1(@PathVariable("id") double id){
    System.out.println("接受到了请求"+"id="+id);
    //返回逻辑视图
    return  "index";
}

映射Cookie

@RequestMapping (value = "/Cookie")
public String index2(@CookieValue("JSESSIONID") String session){
    System.out.println("接受到了请求"+"session="+session);
    //返回逻辑视图
    return  "index";
}

使用POJO绑定参数

Springmvc会自动更据请求参数与POJO的属性名匹配,自动为该对象填充属性值,并支持属性级联。

乱码

<!--    过滤器-->
<filter>
  <filter-name>encodingFilter</filter-name>
  <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
  <init-param>
    <param-name>encoding</param-name>
    <param-value>UTF-8</param-value>
  </init-param>
</filter>
<filter-mapping>
  <filter-name>encodingFilter</filter-name>
  <url-pattern>/*</url-pattern>
</filter-mapping>

User:

package com.southwind.entity;

import lombok.Data;

@Data
public class User {
    private  Integer id;
    private  String name;
    private  Address address;
}

Address;

package com.southwind.entity;

import lombok.Data;

@Data
public class Address {
    private  Integer code;
    private  String name;
}

jsp:

<%--
  Created by IntelliJ IDEA.
  User: 郝泾钊
  Date: 2022-04-06
  Time: 17:34
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
    <form action="/add">
        <table>
            <tr>
                <td>编号:</td>
                <td>
                    <input type="text" name="id">
                </td>
            </tr>
            <tr>
                <td>姓名:</td>
                <td>
                    <input type="text" name="name">
                </td>
            </tr>
            <tr>
                <td>地址编号:</td>
                <td>
                    <input type="text" name="address.code">
                </td>
            </tr>
            <tr>
                <td>地址信息:</td>
                <td>
                    <input type="text" name="address.name">
                </td>
            </tr>
            <tr>
                <td>
                    <input type="submit" value="提交">
                </td>
            </tr>
        </table>
    </form>
</body>
</html>

controller:

@RequestMapping("/add")
public String add(User user){
    System.out.println(user);
    return "addUser";
}

JSP页面的转发和重定向

转发是服务器行为,重定向是客户端行为。转发耗时比重定向少。

转发——>客户浏览器发送HTTP请求——>web服务器接受请求——>调用内部一个方法在容器内部完成请求处理和转发动作——>再将转发跳转到的那个网页资源返回给客户; 转发只能在同一个容器内完成 转发的时候浏览器地址是不会变的,在客户浏览器里只会显示第一次进入的那个网址或者路径,客户看不到这个过程,只是得到了想要的目标资源。转发行为浏览器只做了一次请求。(转发只能跳转一次)

重定向——>客户浏览器发送HTTP请求——>web服务器接受请求后发送302状态码以及新的位置给客户浏览器——>客户浏览器发现是302响应,则自动再发送一个新的HTTP请求,请求指向新的地址(302:Found 临时移动,但资源只是临时被移动。即你访问网址A,但是网址A因为服务器端的拦截器或者其他后端代码处理的原因,会被重定向到网址B。)——>服务器根据此请求寻找资源发个客户;再客户浏览器中显示的是重定向之后的路径,客户可以看到地址的变化。重定向行为浏览器做了至少两次请求。(重定向可以跳转多次

SpringMVC默认是以转发,(地址栏没有改变0

重定向:redirect

@RequestMapping("/add")
public String add(User user){
    System.out.println(user);
    return "redirect:/addUser.jsp";
}

转发;forward