Spring MVC中的数据绑定
引言
在实际的项目开发过程中,客户端会传递给服务器端各种不同的参数请求,那么后台是是如何绑定这些参数的呢?
基本介绍
在实行程序时,Spring MVC会根据客户端请求参数的不同,将请求消息中的信息以一定的方式转换并绑定到控制器类的方法参数中。这种将请求消息数据与后台方法参数建立连接的过程就是Spring MVC中的数据绑定。
实例
通过一个绑定POJO类型的参数,来学习Spring MVC中的数据绑定
1.用IDEA创建一个名为study-pringmvc-03的Spring MVC的web项目,详细过程在我的上一篇博客中提到了过https://blog.csdn.net/weixin_43107798/article/details/98473792。
以及完成该实例所需要的jar包,缺少的jar包可以通过https://mvnrepository.com/search?q=下载。
2.在web.xml中配置前端控制器。
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0">
<!--配置前端控制器-->
<servlet>
<servlet-name>dispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--初始化加载配置文件,当文件位置在WEB-INF下并且与web同目录时,加载配置文件代码可以不写-->
<!-- <init-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/dispatcher-servlet.xml</param-value>
</init-param>-->
<!--表示容器在启动时立即加载Servlet-->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>dispatcher</servlet-name>
<!--"/"表示会将所有的url拦截交给dispatcherservlet处置-->
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
3.创建配置文件dispatcher-servlet.xml这里IDEA已经自动创建完成了。下面需要我们自己编写里边的代码。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<!--扫描controller层代码-->
<context:component-scan base-package="com.itheima.controller"/>
<!--配置视图解析器-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!--设置前缀-->
<property name="prefix" value="/WEB-INF/jsp/"/>
<!--设置后缀-->
<property name="suffix" value=".jsp"/>
</bean>
</beans>
4.在src目录下创建一个名为com.itheima.po的包,在该包下创建一个User类来封装用户注册信息
package com.ithieima.po;
public class User {
private Integer id;
private String username;//用户名
private Integer password;//密码
@Override
public String toString() {
return "User{" +
"id=" + id +
", username='" + username + '\'' +
", password=" + password +
'}';
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public Integer getPassword() {
return password;
}
public void setPassword(Integer pussword) {
this.password = pussword;
}
}
5.创建一个名为com.ithema.controller的包,创建控制器类UserController中编写接受用户注册信息和向注册页面跳转的方法
package com.itheima.controller;
import com.itheima.vo.UserVO;
import com.ithieima.po.User;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import java.util.List;
@Controller
public class UserController {
/*
向用户注册页面跳转
*/
@RequestMapping(value = "/toRegister")
public String toRegister()
{
return "register";
}
/*
接受用户的注册信息,返回到注册成功的页面,方法中接受的参数是User类型
*/
@RequestMapping(value = "/registerUser")
public String registerUser(User user)
{
//获取用户名和密码打印在控制台上,并返回到success页面
String username=user.getUsername();
Integer password=user.getPassword();
System.out.println("username="+username);
System.out.println("password="+password);
return "success";
}
}
6.在WEB-INF下创建jsp文件夹,在文件夹中创建一个注册页面register.jsp以及一个success页面。
register.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>注册</title>
</head>
<body>
<form action="${pageContext.request.contextPath}/registerUser" method="post">
用户名:<input type="text" name="username"/><br/>
密 码:<input type="password" name="password"/><br/>
<input type="submit" value="注册"/>
</form>
</body>
</html>
success.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>结果页面</title>
</head>
<body>
ok
</body>
</html>
7.此时发布到tomcat服务器并启动,在浏览器中访问地址http://localhost:8080/study-springmvc-03/toRegister,就会跳转到注册页面。
然后在文本框里输入信息后,点击注册,浏览器会跳转到结果页面,并且,控制台会输出你输入的信息。
需要注意的问题
- 前端请求参数名,这里指form表单中的元素的name属性值,必须要与POJO中的属性名一样,否则后台接受的参数为null
- 在使用表单的过程中,表单中元素的属性值不能与表单的方法名相同。
- 在前端请求中难免会出现中文乱码问题,在以上程序中就会存在这样的问题。为了解决这样的问题我们可以使用Spring提供的编码过滤器来进行处理,只需要在web.xml中添加以下代码就可以了。`
<filter>
<filter-name>CharacterEncodingFilter</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>CharacterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
总结
通过对于数据绑定的学习,让我有进一步的加深了对于Spring MVC的理解,学习内容来自于《JAVA EE企业级应用开发教程》所以,我创建的包都会有itheima的字样。以上就是我对于POJO类型数据绑定的理解,如果有错误,欢迎各位批评指正,谢谢。
源码地址(包含各种类型的数据绑定):https://github.com/Melonisnotsweet/study-springmvc-03