文章目录

  • @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,需要先指定类的路径再指定方法的路径;