内容
- 映射请求到Spring控制器
- 透明地绑定表单参数
- 校验表单提交
关键词
- 模型-视图-控制器(Model-View-Controller,MVC)
- 处理器映射(handle mapping)
- 视图解析器(view resolver)
- 前端控制器(front controller)
- Java校验API(Java Validation API,JSR-303)
5.1 请求处理流程
URL-->DispatcherServlet-->Controller-->Service-->Dao
当然上面也会反着来进行返回
第一个定义——Model(模型)
模型:控制器完成逻辑处理后,通常会产生一些信息,这些信息需要返回给用户并在浏览器上显示,这些信息就被叫做模型(model)。
视图:信息返回后,需要给用户进行格式化后展示,那么信息就需要发送一个视图(View)。
控制器最后将模型数据打包,并且标示出用于渲染输出的视图名。接下类会将请求连同模型和视图名一起发送给DispatcherServlet。
5.2 编写基本的控制器
控制器方法时添加@RequestMapping注解,这个注解声明了它所要处理的url请求。
5.2.1 定义方法级别的请求
package test
@Controller
public class HomeController() {
@RequestMapping(value='/',method=GET)
public String home() {
return "home";
}
}
- @Controller:注解来声明控制器类,这是一个构造器的注解,也是基于@Component注解。但是,它的目的就是辅助实现组件扫描,组件扫描器会自动找到@Controller,并将其注解的类声明为Spring上下文中的一个bean。
- @RequestMapping:属性value指定了这个方法所要处理的请求路径,method属性细化了它所处理的HTTP方法。
5.2.2 定义类级别的请求
package test
@Controller
@RequestMapping(value='/')
public class HomeController() {
@RequestMapping(method=GET)
public String home() {
return "home";
}
}
1.一个RequestMapping被添加在了类级别上,意味着这个注解会应用到该控制器的所有的方法上,另一个方法上的注解,则是对类级别注解的一个补充。
2. 同时RequestMapping还可以接受一个String数组@RequestMapping(value={'/','/home'})。
5.3 接受请求的输入
关键词
- 查询参数(Query Parameter)
- 表单参数(Form Parameter)
- 路径变量(Path Variable)
5.3.1 处理查询参数
@RequestParam()的DefaultValue属性可以接受参数
@RequestParam('id') long id;
但是这种方法不理想,@RequestMapping就有了占位符这个概念
@RequestMapping(value="/home/{Id}",method=RequestMethod.GET)
public String book(@PathVariable("Id") long id,Model model) {
model.addAttribute(libraryRespo.findOne(id));
return "book";
}
- 假如路径为/home/12345,则@PathVariable中的Id值为12345,且赋值给long id中的id
5.4 处理表单
提交表单,一般会使用POST请求,请求完成后,最好进行一下重定向——redirect,避免浏览器刷新而重复提交表单。
// 写一个接口,实现类略过
package spittr.data;
import spittr.Spitter;
public interface SpitterRepository {
Spitter save(Spitter spitter);
Spitter findByUsername(String username);
}
// 简单写一个Controller
package spittr.controller
import spittr.data.SpitterRepository;
import .......AutoWired;
import .......Model;
import .......RequestMapping;
import .......Controller;
import .......spittr.Spittr
@Controller
@RequestMapping('/home')
public class HomeController() {
priviate SpitterRepository spitterRepository;
@AutoWired
public HomeController(SpitterRepository spitterRepository) {
this.spitterRepository = spitterRepository;
}
@RequestMapping(value="/register",method=POST)
public String executeRegister(Spittr spittr) {
spitterRepository.save(spittr);
// 假设有一个POJO类为spittr,且有一个变量为Username,并生成一个getUsername()的方法
return "redirect:/home/" + spittr.getUsername()
}
}
- 返回值发现重定向字符,就会跳转到重定向加后缀的路径,eg:/home/jobs
- 除了redirect还有forward:前缀,请求将会前往指定的URL路径,而不再是重定向。
5.4.1 校验表单
Java校验API提供的校验注解
注解 | 描述 |
---|---|
@AssertFalse | 所注解的元素必须是Boolean类型,并且值为false |
@AssertTrue | 所注解的元素必须是Boolean类型,并且值为True |
@DecimalMax,@DecimalMin | 所注解的元素必须是数字,并且值要大于(小于)或者等于给定的BigDecimalString值 |
@Max,@Min | 所注解的元素必须是数字,并且值要大于(小于)或者等于给定的值 |
@Digits | 所注解的元素必须是数字,并且值要有指定的位数 |
@Future | 所注解的元素必须是将来的一个日期 |
@Null,@NotNull | 所注解的元素必须为Null(不为Null) |
@Past | 所注解的元素必须是已过去的一个日期 |
@Pattern | 所注解的元素必须匹配给定的正则表达式 |
@Size(min=,max=) | 所注解的元素必须是String,集合或数组,并且他的长度要符合给定的范围。 |
@RequestMapping(value="/register",method=POST)
public String executeRegister(@Valid Spittr spittr,Errors errors) {
if (errors.hasErrors()) {
return "registerForm";
}
spitterRepository.save(spittr);
// 假设有一个POJO类为spittr,且有一个变量为Username,并生成一个getUsername()的方法
return "redirect:/home/" + spittr.getUsername()
}
- 添加@Valid注解,需要确保这个对象满足校验限制。
5.5 总结
总体来说,Spring MVC还是很灵活和强大的一个框架,通过自动注解的确减少了很多的工作,更好的开发。这是对于Spring MVC基础知识的记录笔记,后续会对其他的模块进行不断地学习和丰富。