当前位置:   article > 正文

SpringMVC&Controller配置_controller xml配置

controller xml配置

Controller(控制器)

  • 控制器,通常通过接口定义或注解定义快两种方式实现。

  • SpringMVC中一个控制器类可以包含多种方法。

第一种方式(实现Controller接口):

在此种方式中Control

ler是一个接口,在org.springframework.web.servlet.mvc.Controller包下。

  1. import org.springframework.web.servlet.ModelAndView;
  2. import org.springframework.web.servlet.mvc.Controller;
  3. import javax.servlet.http.HttpServletRequest;
  4. import javax.servlet.http.HttpServletResponse;
  5. public class HelloController implements Controller {
  6. public ModelAndView handleRequest(HttpServletRequest request, HttpServletResponse response) throws Exception {
  7. //ModelAndView模型视图
  8. ModelAndView mv = new ModelAndView();
  9. //封装对象到ModelAndView中,model
  10. mv.addObject("msg","helloControllerTest");
  11. //封装要跳转的视图,放在ModelAndView中
  12. mv.setViewName("Test");//要跳转的页面路径,由视图解析器解析后:/WEB-INF/jsp/hello.jsp
  13. return mv;
  14. }
  15. }

注意:HelloController实现了Controller接口,那么它就是一个控制器了。

springMVC.xml配置文件

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://www.springframework.org/schema/beans
  5. http://www.springframework.org/schema/beans/spring-beans.xsd">
  6. <!--添加映射器-->
  7. <bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>
  8. <!--添加处理器适配器-->
  9. <bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/>
  10. <!--添加试图解析器:DispatcherServlet给他的ModeLAndView
  11. 1.获取了ModeLAndView的数据
  12. 2.解析了ModeLAndView的视图名字
  13. 3.拼接视图名字,找到对应的视图/WEB-INF/jsp/Hello.jsp
  14. 4.将数据渲染到视图上
  15. -->
  16. <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" id="internalResourceViewResolver">
  17. <!--前缀-->
  18. <property name="prefix" value="/WEB-INF/jsp/"/>
  19. <!--后缀-->
  20. <property name="suffix" value=".jsp"/>
  21. </bean>
  22. <bean id="/Hello" class="com.gao.controller.HelloController"/>
  23. </beans>

web.xml配置文件

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
  5. version="4.0">
  6. <!--注册DispatcherServlet-->
  7. <servlet>
  8. <servlet-name>springmvc</servlet-name>
  9. <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  10. <!--关联一个springmvc的配置文件-->
  11. <init-param>
  12. <param-name>contextConfigLocation</param-name>
  13. <param-value>classpath:springmvc.xml</param-value>
  14. </init-param>
  15. <!--启动级别-1 级别越小,启动越早-->
  16. <load-on-startup>1</load-on-startup>
  17. </servlet>
  18. <!--匹配所有的请求:(不包括jsp)-->
  19. <servlet-mapping>
  20. <servlet-name>springmvc</servlet-name>
  21. <url-pattern>/</url-pattern>
  22. </servlet-mapping>
  23. </web-app>

要跳转的页面Test.xml

  1. <%@ page contentType="text/html;charset=UTF-8" language="java" %>
  2. <html>
  3. <head>
  4. <title>Title</title>
  5. </head>
  6. <body>
  7. ${msg}
  8. </body>
  9. </html>

说明:

实现Controller接口定义控制器时比较老的方法,还是更推荐使用注解定义的放法,相比之下通过注解定义代码量较少,更加便捷。

缺点:一个控制器只写一个方法,如果需要多个方法则需要定义多个控制器,定义的方式比较麻烦。

第二种方式(通过注解定义):

@Controller注解类型用于声明Spring类的实例是一个控制器。

Spring利用扫描机制来找到应用程序中所有基于注解的控制器类,为了保证Spring能找到你的控制器,需要在控制器中声明组件扫描

在springMVC.xml配置文件中声明

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xmlns:context="http://www.springframework.org/schema/context"
  5. xmlns:mvc="http://www.springframework.org/schema/mvc"
  6. xsi:schemaLocation="http://www.springframework.org/schema/beans
  7. http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc https://www.springframework.org/schema/mvc/spring-mvc.xsd">
  8. <!--自动扫描包,让指定包下的注解生效,有IOC容器统一管理-->
  9. <context:component-scan base-package="com.gao.controller"/>
  10. <mvc:default-servlet-handler/>
  11. <mvc:annotation-driven/>
  12. <!--
  13. 支持mvc注解驱动
  14. 在spring中一般采用@RequestMapping注解来完成映射关系
  15. 要想使@RequestMapping生效
  16. 必须在上下文中注册DefaultAnnotationHandlerMapping
  17. 和一个AnnotationMethodHandlerMapping实例
  18. 这两个实例分别在类级别和方法级别处理。
  19. 而annotation-driven配置帮助我们自动完成上述两个实例的注入。
  20. -->
  21. <!--视图解析器-->
  22. <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" id="internalResourceViewResolver">
  23. <!--前缀-->
  24. <property name="prefix" value="/WEB-INF/jsp/"/>
  25. <!--后缀-->
  26. <property name="suffix" value=".jsp"/>
  27. </bean>
  28. </beans>

HelloController类

  1. package com.gao.controller;
  2. import org.springframework.stereotype.Controller;
  3. import org.springframework.ui.Model;
  4. import org.springframework.web.bind.annotation.RequestMapping;
  5. @Controller()
  6. @RequestMapping("/hello")
  7. public class HelloController {
  8. //http://localhost:8080/hello/h1
  9. @RequestMapping("/h1")
  10. public String hello(Model model){
  11. //封装数据
  12. model.addAttribute("msg","Hello,SpringMVCAnnotation!");
  13. return "Hello";//会被视图处理器处理
  14. }
  15. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/笔触狂放9/article/detail/302631?site
推荐阅读
相关标签
  

闽ICP备14008679号