zoukankan      html  css  js  c++  java
  • springMVC3学习(十)--注解式控制器

    Spring2.5引入注解式处理器支持,通过@Controller和@RequestMapping注解定义

    我们的处理器类。而且提供了一组强大的注解

    须要通过处理器映射DefaultAnnotationHandlerMapping和处理器适配器AnnotationMethodHandlerAdapter

    来开启支持@Controller和@RequestMapping注解的处理器。



    @Controller:用于标识是处理器类。

    @RequestMapping:请求到处理器功能方法的映射规则。

    @RequestParam:请求參数到处理器功能处理方法的方法參数上的绑定;

    @ModelAttribute:请求參数到命令对象的绑定;

    @InitBinder:自己定义数据绑定注冊支持,用于将请求參数转换到命令对象属性的相应类型;

    一、简单样例

    1、控制器实现

    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    import org.springframework.stereotype.Controller;
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.servlet.ModelAndView;
    @Controller                                        //①将一个POJO类声明为处理器
    public class Login{
    	
    	@RequestMapping(value="/login.do")              //②请求URL到处理器功能处理方法的映射
    	public ModelAndView hello(HttpServletRequest request,HttpServletResponse response){
    		ModelAndView mv = new ModelAndView(); 
    		mv.addObject("message", "Hello World!"); 
    		//设置逻辑视图名。视图解析器会依据该名字解析到详细的视图页面
    		mv.setViewName("login"); 
    		return mv;                                  //③模型数据和逻辑视图名
    	}
    }

    ①能够通过在一个POJO类上放置@Controller或@RequestMapping,就可以把一个POJO类变身为处理器;

    ②@RequestMapping(value="/login.do")请求URL(/login.do)到处理器的功能处理方法的映射;

    ③模型数据和逻辑视图名的返回。



    如今的处理器无需实现/继承不论什么接口/类。仅仅须要在相应的类/方法上放置相应的注讲解明下就可以。

    2、spring配置文件springMVC.xml

    <!-- 发现无需以下处理器也可 -->
    <!-- 
    <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"></bean>
    <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"></bean>
     -->
    
    <!-- 处理器 -->
    <bean class="com.itmyhome.Login"></bean>
    
    <!-- 定义跳转的文件的前后缀 -->
    <bean id="viewResolver"
    	class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    	<property name="prefix" value="/" />  <!-- 默认放在WebRoot下 -->
    	<property name="suffix" value=".jsp" />
    </bean>

    3、视图页面(login.jsp)

    <body>
      ${message }
    </body>

    二、处理器定义

    1、@Controller

    @Controller                               
    public class Login{
       ...	
    }
    推荐使用这样的方式声明处理器,它和我们的@Service、@Repository非常好的相应了我们常见的三层开发架构的组件。

    2、@RequestMapping

    @RequestMapping
    public class Login{
       ...	
    }
    这样的方式也是能够的,但假设在类上使用@RequestMapping注解通常是用于窄化功能处理方法的映射的详见以下

    3、窄化请求映射

    import org.springframework.stereotype.Controller;
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.servlet.ModelAndView;
    @Controller                                        
    @RequestMapping(value="/login.do")  //①处理器的通用映射前缀
    public class Login{
    	
    	@RequestMapping(value="/login2.do")   //②相对于①处的映射进行窄化
    	public ModelAndView hello(){
    		 ...
    	}
    }

    此时URL就应该为:http://localhost:8080/springMVC/login/login2.do

    三、请求映射

    1、普通URL路径映射

    @RequestMapping(value={"/login.do","/user/login.do"}):多个URL路径能够映射到同一个处理器的功能处理方法。



    2、URL模板模式映射

    @RequestMapping(value="/users/{userId}"):{xxx}占位符,请求的URL能够是"/users/123456"或"/users/abcd"。

    @RequestMapping(value="/users/{userId}/login.do"):这样也是能够的,请求的URL能够是"/users/123/login.do"。

    @RequestMapping(value="/users/{userId}/channel/{channelId}"):这样也是能够的,请求的URL能够是"/users/123/channel/456"。

    3、Ant风格的URL路径映射

    @RequestMapping(value="/users/**"):能够匹配"/users/abc/abc"。

    @RequestMapping(value="/model?"):可匹配"/model1"或"/modela" ,但不匹配"/model"或"/modelaa";

    @RequestMapping(value="/model*"):可匹配"/modelabc"或"/model",但不匹配"/modelabc/abc";

    @RequestMapping(value="/model/*"):可匹配"/model/abc",但不匹配"/modelabc";

    @RequestMapping(value="/model/**/{modelId}"):可匹配"/model/abc/abc/123”或"/model/123",

    也就是Ant风格和URI模板变量风格可混用;

    4、正則表達式风格的URL路径映射

    从Spring3.0開始支持正則表達式风格的URL路径映射,格式为{变量名:正則表達式}

    @RequestMapping(value="/login/{userId:\d+}.do"):能够匹配

    "/login/123.do",但不能匹配"/login/abc.do",这样能够设计更加严格的规则。

    5、组合使用是"或"的关系

    如@RequestMapping(value={"/login.do","/user/login.do"})组合使用是或的关系,即"/login.do"或

    "/user/login.do"请求URL路径都能够映射到@RequestMapping指定的功能处理方法。





  • 相关阅读:
    maven编译时错误:无效的目标发行版
    参数传递方法(用Delphi的汇编代码解释)
    Playing with coroutines and Qt
    Qt的一些开发技巧
    刘晏:大唐经济战线的英雄
    Qt的焦点策略
    高级程序员与CTO技术总监首席架构师
    Python入门机器学习
    Service Mesh(服务网格)
    自定义博客园Markdown样式.超简单!
  • 原文地址:https://www.cnblogs.com/llguanli/p/6895033.html
Copyright © 2011-2022 走看看