文章目录
- @Controller
- 控制器Controller
- @RequestMapping
Spring 2.5 版本新增了 Spring MVC 注解功能,用于替换传统的基于 XML 的 Spring MVC 配置。
下面介绍在 Spring MVC 中最重要的两个注解类型:@Controller 和 @RequestMapping。
@Controller
控制器Controller
- 控制器复杂提供访问应用程序的行为,通常通过接口定义或注解定义两种方法实现。
- 控制器负责解析用户的请求并将其转换为一个模型。
- 在Spring MVC中一个控制器类可以包含多个方法
- 在Spring MVC中,对于Controller的配置方式有很多种
我们来看看有哪些方式可以实现:
实现Controller接口
Controller是一个接口,在org.springframework.web.servlet.mvc包下,接口中只有一个方法;
使用注解@Controller
- @Controller注解类型用于声明Spring类的实例是一个控制器(在讲IOC时还提到了另外3个注解);
- Spring可以使用扫描机制来找到应用程序中所有基于注解的控制器类,为了保证Spring能找到你的控制器,需要在配置文件中声明组件扫描。
@Controller
public class HelloController {
@RequestMapping("/hello")
public String hello(Model model){
//封装数据
model.addAttribute("msg", "HelloSpringMVC!");
return "hello"; //会被视图解析器解析
}
}
<!-- 自动扫描包,让指定包下的注解生效,有IOC容器统一管理-->
<context:component-scan base-package="com.kaka.controller"/>
<mvc:default-servlet-handler/>
<!-- 支持MVC注解驱动
在spring中一般采用@RequestMapping注解来完成映射关系
要想使用@RequestMapping注解生效
必须向上下文中注册DefaultAnnotationHandlerMappinng
和一个AnnotationMethodHandlerAdapter实例
这两个实例分别在类级别和方法级别处理。
而annotation-driven配置帮助我们自动完成上述两个实例的注入-->
<mvc:annotation-driven/>
@RequestMapping
@RequestMapping注解用于映射url到控制器类或一个特定的处理程序方法。可用于类或方法上。用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径。
注解在方法上面
@RequestMapping("/hello")
public String hello(Model model){
//封装数据
model.addAttribute("msg", "HelloSpringMVC!");
return "hello"; //会被视图解析器解析
}
访问路径:http://localhost:8080/项目名/ hello
同时注解类与方法
@Controller
@RequestMapping("/myweb")
public class HelloController {
@RequestMapping("/hello")
public String hello(Model model){
//封装数据
model.addAttribute("msg", "HelloSpringMVC!");
return "hello"; //会被视图解析器解析
}
}
访问路径: http://localhost:8080/项目名/ myweb /hello,需要先指定类的路径再指定方法的路径;