Spring MVC---Controller配置总结(二)

(一)配置Controller的方式

参考:Spring MVC官方文档

1.注解配置Controller类最为常用

1.Controller注解类型

@Controller注解一个java控制类不需要再实现jController接口,并且注解后的控制类可以通过Spring扫描机制可以找到
标注@Controller的控制类。

HelloWeb-servlet.xml配置文件添加以下元素:

<!--扫描com.wamg包下的所有类的注解-->
<context:component-scan base-package="com.wang" />

2.@RequestMapping注解的使用

@RequestMapping(value="/hello")等价@RequestMapping("/hello")

方式一:标注在类上时,该类所有的方法请求都将映射为相对于类级别的请求,
       表示该控制器所处理的所有请求都被映射到value属性所指定的路径。

方式二:标注在一个方法上意思直接请求控制类的这个方法来处理。

3.组合注解:简化代码

传统方式: @RequestMapping(value="/hello1", method = RequestMethod.GET)
组合注解:@GetMapping(value="/hello1")这样就少写了 method = RequestMethod.GET

4.组合注解类型

注解 说明
@GetMapping 匹配Get方式的请求
@PostMapping 匹配Post方式的请求
@PutMapping 匹配Put方式的请求
@DeleteMapping 匹配Delete方式的请求
@PatchMapping 匹配Patch方式的请求

5.处理结果返回类型

1.redirect重定向
 //请求映射一下方法
   @RequestMapping(value="/hello1", method = RequestMethod.GET)

   //将数据显示在前端页面使用ModelMap类,该类不需要配置试图解析器
   public String printHello(ModelMap model) {

      //在model中设值数据以便前端页面使用EL表达式获取数据
      model.addAttribute("message", "Hello Spring MVC Framework!");

      //默认跳转方式为:转发
      return "redirect:hello";
   }



----------
2.forward请求转发
 //请求映射一下方法
   @RequestMapping(value="/hello1", method = RequestMethod.GET)

   //将数据显示在前端页面使用ModelMap类,该类不需要配置试图解析器
   public String printHello(ModelMap model) {

      //在model中设值数据以便前端页面使用EL表达式获取数据
      model.addAttribute("message", "Hello Spring MVC Framework!");

      //默认跳转方式为:转发,可以不写forward
      return "forward:hello";
   }

HelloController.java

package com.wang;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.ui.ModelMap;

//使用@Controller声明HelloController类是一个控制类
@Controller

//请求映射URL
@RequestMapping("/one")
public class HelloController{

   //请求映射一下方法
   @RequestMapping(value="/hello1", method = RequestMethod.GET)

   //将数据显示在前端页面使用ModelMap类,该类不需要配置试图解析器
   public String printHello(ModelMap model) {

      //在model中设值数据以便前端页面使用EL表达式获取数据
      model.addAttribute("message", "Hello Spring MVC Framework!");

      //默认跳转方式为:转发
      return "hello";
   }

}

HelloWeb-servlet.xml

 <?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
   xmlns:context="http://www.springframework.org/schema/context"
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation="
   http://www.springframework.org/schema/beans     
   http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
   http://www.springframework.org/schema/context 
   http://www.springframework.org/schema/context/spring-context-3.0.xsd">

   <!--扫描com.wamg包下的所有类-->
   <context:component-scan base-package="com.wang" />

   <!--配置视图解析器-->
   <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">

      <!--前缀是/WEB-INF/jsp/-->
      <property name="prefix" value="/WEB-INF/jsp/" />

      <!-- 后缀以.jsp结尾 -->
      <property name="suffix" value=".jsp" />
   </bean>

</beans>

2.通过URL对应Bean(使用于小型应用系统)

HelloController.java

package com.wang;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.Controller;
public class HelloController implements Controller{
    @Override
    public ModelAndView handleRequest(HttpServletRequest req,
            HttpServletResponse resp) throws Exception {
        //创建一个ModelAndView对象  该对象最后被视图渲染器渲染为指定视图
        ModelAndView mv = new ModelAndView();
        //设置视图名称 ----最后解析为指定的页面
        mv.setViewName("hello");
        //添加结果数据  该数据可以在页面中通过el表达式获取
        mv.addObject("user", "first spring mvc app");
        return mv;
    }
}

HelloWeb-servlet.xml

 <?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:p="http://www.springframework.org/schema/p"
    xsi:schemaLocation="
        http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans.xsd">

    <bean class="org.springframework.web.servlet.mvc.support.ControllerClassNameHandlerMapping"/>  

    <!-- 配置handerAdapter适配器,用于追加后缀比如.do -->
    <bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/>
    <!-- 配置视图渲染器 -->
    <bean id="jspViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
        <!-- 将视图名 渲染后视图的前缀 -->
        <property name="prefix" value="/WEB-INF/jsp/"/>
        <!-- 渲染后视图的后缀 -->
        <property name="suffix" value=".jsp"/>
        <!-- 例:视图名为:hello   渲染后:/WEB-INF/jsp/hello.jsp 该页面-->
     </bean>
     <!-- 请求的url为hello1对应的bean为HelloController-->
     <bean name="hello1" class="com.wang.HelloController"/>
</beans>

3.为URL分配Bean

HelloController.java

package com.wang;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.Controller;
public class HelloController implements Controller{
    @Override
    public ModelAndView handleRequest(HttpServletRequest req,
            HttpServletResponse resp) throws Exception {
        //创建一个ModelAndView对象  该对象最后被视图渲染器渲染为指定视图
        ModelAndView mv = new ModelAndView();
        //设置视图名称 ----最后解析为指定的页面
        mv.setViewName("hello");
        //添加结果数据  该数据可以在页面中通过el表达式获取
        mv.addObject("user", "first spring mvc app");
        return mv;
    }
}

HelloWeb-servlet.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:p="http://www.springframework.org/schema/p"
    xsi:schemaLocation="
        http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans.xsd">
    <!-- 配置handlerMapper  映射器-->
    <bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>  
     <!--  配置Controller  自定义控制器 -->
    <bean name="/he.do" class="com.wang.HelloController"/>
    <bean id="jspViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
        <!-- 将视图名 渲染后视图的前缀 -->
        <property name="prefix" value="/WEB-INF/jsp/"/>
        <!-- 渲染后视图的后缀 -->
        <property name="suffix" value=".jsp"/>
        <!-- 例:视图名为:hello   渲染后:/WEB-INF/jsp/hello.jsp 该页面-->
    </bean>
    <bean id="helloController" class="com.wang.HelloController"/>  
    <bean class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">  
         <property name="mappings">  
              <props>  
                 <!--  key 对应url   value对应 自定义控制器的id -->
                <prop key="/hello*.do">helloController</prop>  
              </props>  
         </property>  
    </bean>  
</beans>

4.URL匹配Bean(不推荐)

HelloWeb-servlet.xml

<bean class="org.springframework.web.servlet.mvc.support.
ControllerClassNameHandlerMapping"/> 
<bean id="helloController" class="com.wang.HelloController"></bean>

web.xml

<servlet>
    <servlet-name>springmvc</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

    <init-param>
        <param-name>contextConfigLocation</param-name>
        <!--HelloWeb-servlet.xml可以在src目录下-->
        <param-value>classpath:HelloWeb-servlet.xml</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
  </servlet>

  <servlet-mapping>
    <servlet-name>springmvc</servlet-name>
    <url-pattern>*.do</url-pattern>
  </servlet-mapping>

猜你喜欢

转载自blog.csdn.net/weixin_36279318/article/details/79874287