springmvc(四)之参数绑定

1.绑定简单类型

当请求的参数名称和处理器形参名称一致时会将请求参数与形参进行绑定

@RequestMapping("/testSimple")
public String testSimple(Integer id) {
	System.out.println(id);
	return SUCCESS;
}

接收前台传过来的参数id值

访问:

<a href="test/testSimple?id=1">Test Simple</a>
1.1支持的数据类型

SpringMVC框架支持的数据类型有:

  • 整形:Integer、int
  • 字符串:String
  • 单精度:Float、float
  • 双精度:Double、double
  • 布尔型:Boolean、boolean

【注意】参数类型推荐使用包装数据类型,因为基础数据类型不可以为null。

2.绑定pojo类型

        提交的表单中的内容很多的时候可以使用pojo接收数据。要求pojo对象中的属性名和表单中input的name属性一致

        springmvc会按请求参数名和POJO属性名进行自动匹配,自动为该对象填充属性值,支持级联属性

Address.java

public class Address {

	private String province;
	private String city;
	...
}

地址类

User.java

public class User {

	private String username;
	private String password;
	
	private Address address;
	...
}

Address是User类的一个变量成员

后台接收:

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

前台用form表单提交User属性且含有级联

<form action="test/testPojo" method="post">
	UserName:<input type="text" name="username" />
	Password:<input type="password" name="password" />
	Province:<input type="text" name="address.province" />
	City:<input type="text" name="address.city" />
	<input type="submit" value="提交" />
</form>

name属性一定要和pojo属性对应

如果POST提交,出现中文乱码
在web.xml文件中加入一个过滤器,如下:

	<!-- POST提交中文乱码 -->
	<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>

如果GET提交,出现中文乱码
解决方案1:
修改tomcat配置文件添加编码与工程编码一致,如下:

<Connector URIEncoding="utf-8" connectionTimeout="20000" 
		port="8080" protocol="HTTP/1.1" redirectPort="8443"/>

解决方案2:
对参数进行重新编码:

String username = 
	new String(username.getBytes("ISO8859-1"),"utf-8");

3.绑定Servlet原生API

处理器形参中添加如下类型的参数,处理适配器会默认识别并进行赋值。

  • HttpServletRequest:通过request对象获取请求信息。
  • HttpServletResponse:通过response处理响应信息。
  • HttpSession:通过session对象得到session中存放的对象。
  • Model/ModelMap:ModelMap是Model接口的实现类,我们可通过Model或ModelMap向页面传递数据
  • java.security.Principal
  • Local
  • InputStream
  • OutputStream
  • Reader
  • Writer

前端访问:

<a href="test/testAPI?id=1">testAPI</a>

3.1HttpServletRequest、HttpServletResponse

@RequestMapping("/testAPI")
public String testAPI(HttpServletRequest request, HttpServletResponse response) {
	String id = request.getParameter("id");
	System.out.println(id);
	return SUCCESS;
}

3.2Writer

@RequestMapping("/testAPI")
public void testAPI(HttpServletRequest request, HttpServletResponse response, Writer out) throws IOException {
	String id = request.getParameter("id");
	out.write("hello springmvc");
}

写给前端一个字符串

4.绑定数组

前端:

html代码:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8" isErrorPage="true"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>springmvc入门</title>
<script type="text/javascript" src="/springmvc-01-helloworld/js/jquery-3.2.1.js"></script>
<script type="text/javascript">

	....
	
</script>
</head>
<body>
	<p>
		<input type="checkbox" name="ids" value="1">Read
		<input type="checkbox" name="ids" value="2">Sleep
		<input type="checkbox" name="ids" value="3">Run
		<input type="button" id="btn" value="提交" />
	</p>
</body>
</html>

上述定义了一个复选框,可以多选。

js代码:

	$(document).ready(function() {
		
		$("#btn").click(function() {
			var inputs = document.getElementsByName("ids");
			var j = 0;
			var ids = new Array();
			for(var i = 0;i < inputs.length; i++){
				if(inputs[i].checked){
					ids[j] = inputs[i].value;
					j++;
				}
			}
			
			var url = "test/testArray"
			$.post(url, {"ids": ids}, function(json){
				
			})
		})
	})

通过向后台发送ajax请求(发送一个数组:数组中的元素是被选中的复选框的值)

由于之前springmvc.xml配置中拦截了所有请求,故上述引入的jquery.js文件被拦截,所以还需要再次配置不拦截静态文件。

修改springmvc.xml:

<?xml version="1.0" encoding="UTF-8"?>
	...

	<!-- 配置自动扫描包 -->
	<context:component-scan base-package="com.zzc.controller"></context:component-scan>
	
	<!-- 不拦截静态资源 -->
	<mvc:annotation-driven />
	<mvc:resources location="js/" mapping="js/**" />
	
	<!-- 配置视图解析器:如何把 handler 方法返回值解析为实际的物理视图 -->
	<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
		<property name="prefix" value="/WEB-INF/views/" ></property>
		<property name="suffix" value=".jsp"></property>
	</bean>
	
</beans>
  • 配置不拦截静态资源

location元素表示webContent目录下以 / Xxx开头的静态文件;
mapping元素表示以/Xxx 开头的请求路径;
所以该配置的作用是:DispatcherServlet不会拦截以/js开头的所有请求路径,并当作静态资源交由Servlet处理。

后台接收:

@Controller
@RequestMapping("/test")
public class TestController {
	private static final String SUCCESS = "success";
	
	@RequestMapping("/testArray")
	public String testArray(@RequestParam(value = "ids[]") Integer[] ids) {
		for(Integer id : ids) {
			System.out.println(id);
		}
		return SUCCESS;
	}
	...
}
发布了78 篇原创文章 · 获赞 2 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/Lucky_Boy_Luck/article/details/100060058