SpringMVC 中的Controller

本文介绍了SpringMVC中控制器的两种实现方式:实现Controller接口和使用@Controller注解。实现接口的方式较为传统,每个Controller类只能有一个方法,配置相对繁琐。而注解方式更现代,允许一个类包含多个处理方法,通过@Component扫描实现自动化配置,降低了耦合性。示例展示了如何使用@RequestMapping注解映射URL并处理请求。
摘要由CSDN通过智能技术生成

你好! 这是你第一次使用 Markdown编辑器 所展示的欢迎页。如果你想学习如何使用Markdown编辑器, 可以仔细阅读这篇文章,了解一下Markdown的基本语法知识。

控制器Contorller

  • 控制器负责提供访问应用程序的行为,通常通过接口或注解定义两种方式实现
  • 控制器负责解析用户的请求并将其转换为一个模型。
  • 在Spring MVC中,一个控制类可以包含多个方法
  • 在Spring MVC中,对于Controller的配置方式有很多种

实现Controller接口

Controller是一个接口,在org.springframework.web.servlet.mvc包下,接口中只有一个方法;

//导入Controller接口就可以活动控制功能
public class HelloController  implements Controller {
    public ModelAndView handleRequest(HttpServletRequest request, HttpServletResponse response) throws Exception {
        //ModelAndView 模型和视图
        ModelAndView mv = new  ModelAndView();
        //封装对象  ,放在ModelAndView中。
        mv.addObject("msg","HelloSpringMVC!");
        mv.setViewName("hello");    //WEB-INF/JSP/hello.jsp
        return mv;
    }
}
说明
  • 实现接口Controller定义控制器是较老的方法。
  • 缺点是:一个控制器中只有一个方法,如果多个方法则需要定义多个Controller;定义的方式比较麻烦

使用注解@Controller

  • @Controller注解类型用于声明Spring类的实列是一个控制器(额外还有3个注解)

@Compoen ----组件
@Service -------service
@Controller ----contorller
@Repository —dao

  • Spring可以使用扫描机制找到应用程序中所有基于注解的控制类,为了保证Spring能找到你的控制器,需要在配置文件中声明组件扫描。
<!--自动扫描包,让指定包下注解生效,由IOC容器统一管理-->
<context:component-scan base-package="com.qinShan.controller"/>
  • 增加一个HelloController,使用注解实现
@Controller	//代表这个类会被spring接管,被这个注解的类,中的所有方法,如果返回值是spring,并且有具体页面可以跳转,那么就会被视图解析器解析
@RequestMapping("/hello")
public class HelloController {
    @RequestMapping("/h1")
    public String hello(Model model){
        model.addAttribute("msg","HelloSpringMVCAnnotation!");
        return "hello";
    }
}

视图可以被复用,而控制器与视图之间是若耦合关系
注解是平时使用最多的方式参考

RequestMapping

@RequestMapping

  • @RequestMapping注解用于映射url到控制器类或一个特定的处理程序方法,可用于类或方法上,用于类上,表示类中的所有方法都是以该地址作为父路径
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

青山`

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值