初识Spring-MVC之Controller的URL的映射规则注解版

Spring-MVC也是一种基于请求驱动的WEB框架,并且使用了前端控制器的设计模式。前端控制器就是DispatcherServlet控制器,只要满足web.xml文件中的【url-pattern】的规则,这个请求就会交给这个前端控制器(DispatcherServlet),然而前端控制器在收到请求后自己不进行任何处理,根据相应的【URL的映射规则】委托给其他的页面控制器进行处理请求。前端控制器只作为一个统一的访问点,进行全局的流程控制。

1.web.xml中的【url-pattern】的设置:例如:

    <servlet>
        <!--servlet的一个名称-->
        <servlet-name>do</servlet-name>
        <!--Dispatcherservlet所在的类路径-->
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <!--下面可以不写,他有一个默认的contextConfigLocation配置,默认的param-value是【servlet-name】的值-servlet.xml文件-->
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>/WEB-INF/do-servlet.xml</param-value>
        </init-param>
        <!--在服务器启东时,初始化改servlet-->
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>do</servlet-name>
        <url-pattern>*.do</url-pattern>
    </servlet-mapping>
其中【servlet】中配置servlet的实现类,和相应的属性参数值。在【servlet-mapping】则定义了Spring-MVC的起作用的url模式。常见的url模式有三种:

①、【/】:它会拦截所有的url,如:/test,/test1.html,/1.jpg……,但是除了以jsp结尾的url不会交给前端控制器。

②、【/*】:他是包含【/】的,可以多拦截以*.jsp结尾的url

③、【*.xxx】:这个拦截国定结尾的url请求,常见的有*.do,*.json

2.前端控制器将请求交给指定的页面控制器:

满足【web.xml】文件中的【url.pattern】的请求都会交给前端控制器,再由前端控制器转交给相应的页面控制器。那么如何将前端控制器交给相应的页面控制器。有两种方法:

①、通过注解的方式将请求交给相应的页面控制器。(本文的重点)

②、通过实现controller接口,实现handlerRequest方法,并在Spring-mvc的配置文件中添加相应的bean。

3.通过注解的方式将请求交给相应的页面控制器:

①、基于普通的url:例如:

    //@RequestMapping就是一个URL匹配模式,value就是匹配模式匹配的值
    //@ResponseBody就会将返回的结果作为页面的中的body内容显示
    @RequestMapping(value = "/ajax1")
    public @ResponseBody String test(){
        return "ajax1";
    }

注意我的【web.xml】文件中的url-pattern是【*.do】

输入【localhost:端口号/应用的上下文/ajax1.do】,就会出现ajax1的字样

也可以是多级目录:例如

@RequestMapping(value = "/ajax/myjsp_01")
    public String test(){
        return "myjsp_01";
    }
输入【localhost:端口号/应用的上下文/ajax/myjsp_01.do】,就会出现myjsp_01的字样

②、基于多个普通的url:使用【逗号】隔开。例如

    @RequestMapping(value = {"/ajax2","/ajax3","/ajax1"})
    public @ResponseBody String test1(){
        return "multiplyvalue";
    }

注意:一些规则信息:①、在Spring-mvc的配置文件中设置controller的bean会先匹配。然后再匹配注解方式的控制器

②、在不同的控制器中不可以有两个相同的【普通的url】的值,会出错。

③、基于路径变量的URL映射:

@RequestMapping(value = "/{name}")
    public @ResponseBody String test3(@PathVariable String name){
        return "test3  "+name;
    }
注意:基于路径变量的URL的级别是低的。她会先匹配普通的url地址。然后在匹配路径变量的Url如果是

输入【localhost:端口号/应用的上下文/ajax1.do】,就会出现ajax1的字样

输入【localhost:端口号/应用的上下文/hello.do】,就会出现test3 hello的字样

④、基于通配符的URL:

①、【?】:匹配任何一个单个字符:例如:

 @RequestMapping(value = "/ajax?")
    public @ResponseBody String test4(){
        return "ajax1?";
    }
localhost:8080/context/ajax2 或者localhost:8080/context/ajaxa

②、【*】:匹配零个或任意多个字符:

@RequestMapping(value="/ajax*")
    public @ResponseBody String test5(){
        return "ajaxs1*";
    }

localhost:8080/context/ajaxaaaa 或者localhost:8080/context/ajax

③、【**】:匹配零个货任意多个字符,并可可以是多个级别,例如

@RequestMapping(value="/ajax/**")
    public @ResponseBody String test6(){
        return "ant4/1**";
    }
localhost:8080/context/ajax/ 或者localhost:8080/context/ajax/aaa 或者localhost:8080/context/ajax/aaa/123

⑤、基于正则表达式:格式:{变量名:正则表达式},可以使用@PathVariable接收变量的值,例如

@RequestMapping(value="/student/{name:\\w+}-{age:\\d+}")
    public @ResponseBody String regUrl(@PathVariable String name,@PathVariable int age){
        return "name:"+name+" age:"+age;
    }
localhost:8080/context/student/wangwu-33 或者localhost:8080/context/student/zhao4-22

你可能感兴趣的:(url,spring-mvc)