Spring MVC介绍,主要是对其中一些关键注解的理解和应用

内容

  • 映射请求到Spring控制器
  • 透明地绑定表单参数
  • 校验表单提交

关键词

  • 模型-视图-控制器(Model-View-Controller,MVC)
  • 处理器映射(handle mapping)
  • 视图解析器(view resolver)
  • 前端控制器(front controller)

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="/{Id}",method=RequestMethod.GET)
public String book(@PathVariable("Id") long id,Model model) {
	model.addAttribute(libraryRespo.findOne(id));
	return "book";
}

版权声明:本文为hasz原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/hasz/p/12990245.html