参考资料:
SpringMVC入门学习
SpringMVC工作原理
web开发功能权限控制
填坑
1
- jdk1.8和tomcat9版本报:JSP只能处理POST GET请求的错误解决:添加@ResponseBody关键字
/**
* @RequestParam 来映射请求的参数值 @RequestHeader 映射请求头信息
* value 请求的参数名,
* required 该参数是否必须,
* defaultValue 参数的默认值
* @param name 参数name
* @param age 参数age,非必须,默认值为10
* @return
*/
@RequestMapping(value = "/testRequestParam",method = RequestMethod.PUT)
@ResponseBody//重新定义返回值的风格,json解决jsp只接受GET,POST请求的错误
//可以把返回的对象转换为json数据写进response的body区域中
public String testRequestParam(@RequestParam(value = "name") String name,
@RequestParam(value = "age",required = false,defaultValue = "10") int age){
System.out.println("name:"+name+"age:"+age);
return "hellow";
}
2
- 使用ModelAndView实现模板数据填充时报错,解决:注意ModelAndView有两个包
org.springframework.web.servlet.ModelAndView
org.springframework.web.portlet.ModelAndView
第一个才是这里需要的,不要导错包
3:ModelAttribute理解
- ModelAttribute使用注意:
put时key值应该是类名首字母小写
,也可以不写,默认为类名首字母小写
,或者在请求响应函数中也用@ModelAttribute修饰,用value来定义key值
下面例子中请求处理参数要传入一个User对象,则map.put函数的key应该是“user”
/**
* 运行流程:
* 1.接收到请求后首先执行getUser方法得到一个User对象,加入到Map中
* 2.取出map对象中的User,按照请求参数为其赋值,没有赋值的保持原值不变
* 3.SpringMVC把改变后的User对象注入请求处理函数的参数中
* @param name
* @param map
*/
@ModelAttribute
public void getUser(@RequestParam(value = "account") Integer account,
Map<String,Object> map){
User user=new User();
if(account!=null){
user=userService.selectByAccount(account);
}
map.put("user",user);//注意:put时key值应该是类名首字母小写
}
/**
* 更新用户
* @param user
* @return
*/
@RequestMapping(value = "/updateUser",method = RequestMethod.POST)
@ResponseBody
public Map<String,Object> updateUser(User user){
Map<String,Object> modelMap=new HashMap<>();
boolean result=userService.updateUser(user);
if (result) {
modelMap.put("Result", "success");
}else{
modelMap.put("Result","fail");
}
return modelMap;
}
User类
public class User {
private String name;
private String password;
private Integer type;
private Integer num;
private String introduce;
private String picture;
private Integer account;
提交数据的表单
<form action="user/updateUser" method="post">
<input type="text" name="name" value="zgggg">
<input type="text" name="type" >
<input type="text" name="num" >
<input type="text" name="introduce" >
<input type="hidden" name="account" value="10001">
<input type="submit" value="updateUser">
</form>
流程理解:在form表单中提交了name等User的部分属性,首先执行@ModelAttribute标注的gerUser方法,传入account数据,从数据库得到一个User对象,然后将request中提交的其他数据与该User对象整合,整合方法是,如果传入的数据中没有User中原本已有的属性,比如password,则保留原值,否则替换赋值。最后将user传入updateUser方法的user中
在请求响应函数中也用@ModelAttribute修饰,用value来定义key值时,这个key值也是数据响应到前台获取值时的key值
例:
@ModelAttribute
public void getUser(@RequestParam(value = "name",required = false) String name,
Map<String,Object> map){
User user=new User(name,"11111",25);
map.put("abc",user);//注意:put时key值应该是响应函数中@ModelAttribute(value = "abc")中的value
}
@RequestMapping(value = "/testModelAttribute",method = RequestMethod.POST)
public String testModelAttribute(@ModelAttribute(value = "abc") User user){
System.out.println("修改"+user);
return "hellow";
}
${requestScope.abc}//前台获取abc
4
- JSTL视图、fmt标签???
尚硅谷视屏25集
5 SpringMVC不经过Handler处理,直接请求定向的配置方法
- 例:
<!--配置直接响应转发的页面-->
<!--因为jsp在WEB-INF目录下,外界是无法直接请求定向的,这里可以通过view-controller来配置-->
<mvc:view-controller path="/hellow" view-name="hellow"/>
但是这样配置之后会导致其他
return "hellow"
的处理方法失效,所以开发会还得加上annotation-driven标签的配置
例:
<mvc:view-controller path="/hellow" view-name="hellow"/>
<mvc:annotation-driven></mvc:annotation-driven>
6:自定义视图
- 通过实现
View
接口来定义自己的视图类
public class MyView implements View {
@Override
public String getContentType() {
return "text/html";
}
@Override
public void render(Map<String, ?> map, HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws Exception {
//编写要渲染的内容
}
}
这种视图需要配置视图解析器
<!--配置视图解析器:如何把handler返回值解析为实际的物理视图-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/jsps/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
<!--配置通过View的name来解析视图的解析器-->
<bean class="org.springframework.web.servlet.view.BeanNameViewResolver">
<property name="order" value="100"></property>
</bean>
order属性来定义视图解析的使用优先级,value越大,优先级越低,InternalResourceViewResolver的order默认为最低优先级
注意:常用的视图解析器的优先级应该最低
7:请求重定向,请求转发
例:
@RequestMapping(value = "/testRedirect")
public String testRedirect(User user){
return "redirect:hellow.jsp";//请求重定向
}
8:<mvc:annotation-driven></mvc:annotation-driven>的作用
<mvc:annotation-driven></mvc:annotation-driven>会自动注册RequestMappingHandlerMapping、RequestMappingHandlerAdapter、ExceptionHandlerExceptionResolver这三个bean。
还支持:
1.支持使用ConversionService实例对表单参数进行类型转换
2.支持@NumberFormart annotation、@DataTimeFormart注解完成数据类型的格式化
3.支持使用@Valid注解对JavaBean实例进行JSR 303验证
4.支持使用@RequestBody、@ResponseBody注解
9:使用@NumberFormart和@DataTimeFormart完成数据类型格式化
例:
@NumberFormat(pattern = "#,###,###.#")
public double salary;
@DateTimeFormat(pattern = "yyyy-mm-dd")
public Date time;
10:BindingResult对象可以查看数据绑定过程的结果
11:数据校验
- 如何校验?
使用JSP303验证:参考
@NotNull 注解元素必须是非空
@Null 注解元素必须是空
@Digits 验证数字构成是否合法
@Future 验证是否在当前系统时间之后
@Past 验证是否在当前系统时间之前
@Max 验证值是否小于等于最大指定整数值
@Min 验证值是否大于等于最小指定整数值
@Pattern 验证字符串是否匹配指定的正则表达式
@Size 验证元素大小是否在指定范围内
@DecimalMax 验证值是否小于等于最大指定小数值
@DecimalMin 验证值是否大于等于最小指定小数值
@AssertTrue 被注释的元素必须为true
@AssertFalse 被注释的元素必须为false
Hibernate validator 在JSR303的基础上对校验注解进行了扩展,扩展注解如下:
@Email 被注释的元素必须是电子邮箱地址
@Length 被注释的字符串的大小必须在指定的范围内
@NotEmpty 被注释的字符串的必须非空
@Range 被注释的元素必须在合适的范围内
使用步骤:
1.为JavaBean中的属性添加上面的注解,来指定验证方式
2.在请求处理函数的参数Bean前添加@Valid注解