五、Spring Web应用程序构建

内容

  • 映射请求到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";
	}

}

  1. @Controller:注解来声明控制器类,这是一个构造器的注解,也是基于@Component注解。但是,它的目的就是辅助实现组件扫描,组件扫描器会自动找到@Controller,并将其注解的类声明为Spring上下文中的一个bean。
  2. @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";
}
  1. 假如路径为/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()

	}
}

  1. 返回值发现重定向字符,就会跳转到重定向加后缀的路径,eg:/home/jobs
  2. 除了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()

	}

  1. 添加@Valid注解,需要确保这个对象满足校验限制。

5.5 总结

总体来说,Spring MVC还是很灵活和强大的一个框架,通过自动注解的确减少了很多的工作,更好的开发。这是对于Spring MVC基础知识的记录笔记,后续会对其他的模块进行不断地学习和丰富。

posted @ 2020-05-29 23:48  #司南  阅读(247)  评论(0编辑  收藏  举报