SpringMVC简介
Spring Web MVC是一种基于Java的实现了Web MVC设计模式的请求驱动类型的轻量级Web 框架,即使用了MVC架构模式的思想,将web 层进行职责解耦,基于请求驱动指的就是使用请求-响应模型,框架的目的就是帮助我们简化开发.
简单来说就是将访问jsp页面的步骤分开,模块化,开发更简单,结构更清晰。
Spring Web MVC作用:
非常简单的设计出干净的Web 层和薄薄的Web 层;
提供强大的约定大于配置的契约式编程支持;
支持灵活的URL到页面控制器的映射;
灵活的数据验证、格式化和数据绑定机制,能使用任何对象进行数据绑定,不必实现特定框架的API;
提供一套强大的JSP标签库,简化JSP开发;
支持灵活的本地化、主题等解析;
简单的异常处理;
支持Restful风格。
前端控制器的配置
配置前端控制器:
作用:拦截所有的WEB请求
<url-pattern>/</url-pattern>
/* 拦截所有的请求,一般用于开发前台网站
/ 一般用于开发普通工程
*.action *.do 一般用于开发后台管理系统
<servlet>
<servlet-name>DispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:config/applicationContext-mvc.xml</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>DispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
applicationContext-mvc.xml文件配置
<!-- 自动扫描器,扫描匹配路径下所有类文件-->
<context:component-scan base-package="com.zzxtit.spring.mvc.*.action"></context:component-scan>
<bean id="viewResolver"
class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/views/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
InternalResourceViewResolver:用于支持Servlet、JSP视图解析
prefix 和suffix:查找视图页面的前缀和后缀(前缀[逻辑视图名]后缀)
匹配成功会自动在路径加前缀后缀
@RequestMapping注解
在控制器的类定义以及方法定义处都可以标注此注解
类定义处 : 提供初步的请求映射信息,相对于WEB应用的根目录 提供进一步的细分映射信息,相对于类定义处的URL。
若类定义处未标注@ReqeustMapping,则方法处标记的URL相对于WEB应用的根目录 DispatcherServlet 截获请求后,通过控制器上@RequestMapping提供的映射信息确定请求所对应的处理方法。
MVC实例测试
此方法为一个处理器,接受前端控制器发送过来的请求,需要返回一个ModelAndView对象,
@RequestMapping("/sayHello")
public ModelAndView sayHello() {
ModelAndView mav = new ModelAndView("/hello.jsp");
mav.addObject("attName", "attValue");
System.out.println("hello 页面测试");
return mav;
}
举例访问路径 http://127.0.0.1:8080/spring.mvc/sayHello
访问hello.jsp
@Controller
@RequestMapping("/hello")
public class HelloWorldController {
@RequestMapping(value= {"/sayHello"})
public String sayHello() {
System.out.println("hello world!");
return "success";
}
@RequestMapping("/speakHello")
public String speakHello() {
return "success";
}
}
@RequestMapping 注解解既可以在类名上,也可以在方法名上添加,当我们在类上添加也在方法名上添加时,访问路径会增加一个层次
举例访问路径 http://127.0.0.1:8080/spring.mvc/hello/sayHello
jsp文件路径 views/success.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<div align="center">
<h1>SUCCESS</h1>
</div>
</body>
</html>
value 或者 path 值为数组,意味着一个handler可以定义多个访问路径
method 定义当前handler接受请求的方法(get\post\put\delete....), 当不设置method 请求方法,可以接受任何方法的请求
@RequestMapping(value= {"/sayHello", "/nihao"}, method= {RequestMethod.POST, RequestMethod.GET})
请求路径的模糊匹配:
占位符:
?表示匹配任意一个字符
*表示匹配任意字符(包含0至N个,但是不能多层次路径)
** 表示匹配任意深度路径
举例
@RequestMapping(value= {"/sayH?llo", "/nihao"})
@RequestMapping(value= {"/sayH*llo", "/nihao"})
2239

被折叠的 条评论
为什么被折叠?



