赞
踩
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
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。