一,数据回写
数据回写:在做数据更新的时候服务端查询的数据自动填写到表单中
默认方式
@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>
通过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>
效果
通过@ModelAttribute注解实现
修改回写变量名
@RequestMapping("/add")
public String fun(@ModelAttribute("a") Book book) throws Custom{
System.out.println(book);
book.setName("sd");
return "/user.jsp";
}
页面
<form action="update1" method="post" >
书名:<input type="text" value="${a.name}"/></br>
年龄:<input type="text" value="${a.age} "/></br>
<input type="submit" value="注册"></br>
</form>
配置全局变量名
package com.sxt;
import java.util.ArrayList;
import java.util.List;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import com.sxt.bean.Book;
import com.sxt.bean.Custom;
import sun.management.resources.agent;
@Controller
public class Conreoller {
@RequestMapping("/add")
public String fun(@ModelAttribute("a") Book book) throws Custom{
System.out.println(book);
book.setName("sd");
return "/user.jsp";
}
@ModelAttribute("as")
public List<String>fun2(){
List<String> as = new ArrayList<>();
as.add("深圳");
as.add("广州");
as.add("海口");
return as;
}
}
页面中获取
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
获取配置全局返回的信息:${as }
<form action="update1" method="post" >
书名:<input type="text" value="${a.name}"/></br>
年龄:<input type="text" value="${a.age} "/></br>
<input type="submit" value="注册"></br>
</form>
</body>
</html>
测试
异常处理
项目中对于异常需要统一处理,需要提前准备好一个错误页面,当项目出现异常,就将该页面展示给用户看
创建自定义异常类
package com.sxt.bean;
public class Custom extends Exception{
private String message;
public Custom(String message) {
super(message);
this.message = message;
}
@Override
public String getMessage() {
return message;
}
public void setMessage(String message) {
this.message = message;
}
}
定义异常处理器
package com.sxt.thows;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerExceptionResolver;
import org.springframework.web.servlet.ModelAndView;
/**
* 自定义异常处理器
* @author Administrator
*
*/
@Component
public class MyThows implements HandlerExceptionResolver{
@Override
public ModelAndView resolveException(HttpServletRequest request, HttpServletResponse response, Object handler,
Exception ex) {
System.out.println(ex.getMessage());
ModelAndView view = new ModelAndView();
view.setViewName("/index.jsp");
return view;
}
}
响应错误页面自定义
在需要异常处理的地方抛出异常
测试
三,JSON数据
响应json数据,添加依赖
对于Gson和jackson这两个json处理依赖,直接添加即可。 除此之外,其他的json解析器如fastjson都需要手动配置HttpMessageConverter.
实际上,在SpringMVC中,是由一个名叫HttpMessageConverter的类来提供对象到JSON字符串的转换的。而SpringMVC默认就提供了Gson和Jackson的HttpMessageConverter,分别是org.springframework.http.converter.json.GsonHttpMessageConverter和MappingJackson2HttpMessageConverter。对于其他的JSON解析器,只需要开发者手动配置一下HttpMessageConverter即可。
本案例使用 jackson处理
标题在返回对象上添加@ResponseBody注解即可
package com.sxt;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.apache.catalina.User;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import com.sxt.bean.Book;
/**
* 响应json数据
* @author Administrator
*
*/
@Controller
public class Conreoller {
/**
* 对象
* @return
*/
@GetMapping("/fun")
@ResponseBody
public Book getbook(){
Book book = new Book();
book.setName("dpd");
book.setAge(12);
return book;
}
/**
* list集合
* @return
*/
@GetMapping("/fun1")
@ResponseBody
public List<Book> list(){
List<Book> book = new ArrayList<>();
for (int i = 0; i < 10; i++) {
Book e = new Book();
e.setName("zhangsan:" + i);
e.setAge(12 + i);
book.add(e);
}
return book;
}
/**
* 数组
* @return
*/
@GetMapping("/fun2")
@ResponseBody
public String[] getstring(){
return new String[]{"aa", "bb", "cc"};
}
/**
* map
* @return
*/
@GetMapping("/fun3")
@ResponseBody
public Map<String, Object> getmap(){
Map<String, Object> map=new HashMap<>();
Book book = new Book();
book.setName("dpd");
book.setAge(12);
Book book1 = new Book();
book1.setName("dpd");
book1.setAge(12);
map.put("book", book);
map.put("book1", book1);
map.put("total", 2);
return map;
}
}
测试
额外说明:
默认情况下,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转为对象
接受JSON数据
注意:json只能是在请求体中,因此,json只能放在post或者put请求中,注意,请勿使用get/delete请求去测试json参数传递。
示例代码如下:
package com.sxt;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.ResponseBody;
import com.sxt.bean.Book;
@Controller
public class Conreoller {
@PostMapping("fun1")
@ResponseBody
public void getbook(@RequestBody Book book){
System.out.println(book);
}
}
页面内通过jquery的ajax发送json数据测试
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<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数据" "fun1();">
<script type="text/javascript">
function fun1(){
$.ajax({
type: 'POST',
url: "fun1",
contentType: "application/json",//如果想以json格式把数据提交到后台的话,这个必须有,否则只会当做表单提交
data: JSON.stringify({"name":"lisi","age":"12"}),//JSON.stringify()必须有,否则只会当做表单的格式提交
dataType: "json",//期待返回的数据类型
success: function(data){
alert("success:"+data);
},
error:function(data){
alert("error"+data);
}
});
}
</script>
</body>
</html>
在springmvc中,直接接收json参数,如果参数中有日期的话,不需要定义日期类型转换器,日期的转换由gson/jackson/fastjson来提供。
解决响应中文乱码问题
在web.xml配置下面这段代码即可
<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>
这样就算接受提交的json数据是中文也不会出现乱码问题了