需求:不用经过controller直接从一个jsp跳转到另一个jsp
当我们发送一个请求时,如果没有找到对应的mapping
则会对配置文件当中匹配mvc:view-controller
注意: 在配置后requestMapping没法用
springMVC.xml添加
<mvc:annotation-driven />
为什么: 写了这句话之后内部会自动注册3个Bean类,其中包括requestMapping,若单纯配置view-Controller 则无requestMapping,自然没法去适配
内置form标签验证
使用前先导入标签库,<%@taglib uri="http://www.springframework.org/tags/form" prefix="fm"%>
再创建表单
处理请求后
进行页面处理
页面处理时要先绑定数据<fm:form modelAttribute="User">
从起始页传入服务器的某一个参数,依据这个参数到数据库找相应的内容并输出到结果页,
作用
第一是它会自动的绑定来自Model中的一个属性值到当前跳转页form对应的实体对象
第二是它支持我们在提交表单的时候使用除GET和POST之外的其他方法进行提交,包括DELETE和PUT等
使用场景
当编辑时, 跳转到form表单页,传统模式要在跳转前先到数据库查询数据,然后进行表单数据回显
使用form之前一定要保证有对应的bean,没有对应的bean时, 会自动以command为key到request域中查询,当找不到的时候, 会报异常
first before first: 引入标签库
first:
second: 处理请求 将该bean存到model中,key值为类名
third: 页面处理 path是与bean类的字段相对应的 modelAttribute的值是与存入model的key值相对应的,若无则是默认找key=command的
checkbox标签的使用:需求是一个user的爱好有2种 那全部爱好(复选框)有3种,那势必要做一个复选框
第一步:将个人爱好添加到bean
String[] hobby = new String[] {"篮球","足球"};
user.setHobby(hobby);
model.addAttribute("User", user);
第二步:创建全部爱好的一个数组单独存入request域(model)
ArrayList<Object> allhobby = new ArrayList<>();
allhobby.add("篮球");
allhobby.add("足球");
allhobby.add("乒乓球");
model.addAttribute("allhobby",allhobby);
第三步:页面处理
hobby:<fm:checkboxes path="hobby" items="${allhobby}"/>
第四步:对于修改之后的整个表单,我们可以用submit进行提交,而提交的action默认为刚才提交表单的原路径 , 所以要自定义一个action和requestMapping来跳转,
<fm:form modelAttribute="User" action="${pageContext.request.contextPath}/update2">
username: <fm:input path="username"/> <br>
age:<fm:input path="age"/> <br>
gender:<fm:radiobutton path="gender" value="0" label="男"/>
<fm:radiobutton path="gender" value="1" label="女"/> <br>
hobby:<fm:checkboxes path="hobby" items="${allhobby}"/> <br>
<input type="submit" value="submit">
</fm:form>
@RequestMapping("update2")
public String update2(User user) {
System.out.println(user);
return "/result2.jsp";
}
select标签的使用:
selet:下拉列表
做一个宠物的下拉列表 而宠物类也是user类的一个字段
第一步:添加宠物的ArrayList到model中,
同时
user.setPet(pet2);
第二步:
Pet:<fm:select path="pet.id" items="${petList}" itemValue="id" itemLabel="name"/> <br>
服务器表单校验
为什么后端要做表单的校验
- 如果只使用前端校验的话,浏览器把JS给禁用掉,就弯度子啦
JSR - JSR 303 是 Java 为 Bean 数据合法性校验提供的标准框架,它已经包含在 JavaEE 6.0 中
- JSR 303 通过在 Bean 属性上标注类似于 @NotNull、@Max 等标准的注解
- 指定校验规则,并通过标准的验证接口对 Bean 进行验证
Hibernate Validator
- 是 JSR 303 的一个参考实现,
- 除支持所有标准的校验注解外,它还支持以下的扩展注解
常用校验规则
Bean Validation 中内置的约束
@Null 被注释的元素必须为 null
@NotNull 被注释的元素必须不为 null
@AssertTrue 被注释的元素必须为 true
@AssertFalse 被注释的元素必须为 false
@Min(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
@Max(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
@DecimalMin(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
@DecimalMax(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
@Size(max=, min=) 被注释的元素的大小必须在指定的范围内
@Digits (integer, fraction) 被注释的元素必须是一个数字,其值必须在可接受的范围内
@Past 被注释的元素必须是一个过去的日期
@Future 被注释的元素必须是一个将来的日期
@Pattern(regex=,flag=) 被注释的元素必须符合指定的正则表达式
Hibernate Validator 附加的约束
@NotBlank(message =) 验证字符串非null,且长度必须大于0
@Email 被注释的元素必须是电子邮箱地址
@Length(min=,max=) 被注释的字符串的大小必须在指定的范围内
@NotEmpty 被注释的字符串的必须非空
@Range(min=,max=,message=) 被注释的元素必须在合适的范围内
使用Hibernate-Validator导入jar包
使用
在配置文件当中写上mvc:annotation-driven/
在模型当中添加对应的校验规则
在处理器方法的入参标记@valid注解即可
错误信息页面回显(使用原始表单错误信息写到Model中)
<fm:errors path=“username”/> 当输入信息不符合校验时将会输出所要回显的message
username: <fm:input path="username"/><fm:errors path="username"/> <br>
age: <fm:input path="age"/> <fm:errors path="age"/><br>
使用原始表单错误信息写到Model中
使用form标签(了解)