SpringMVC 执行过程
- 用户发送请求至前端控制器 DispatcherServlet
- DispatcherServlet 收到请求调用 HandlerMapping 处理器映射器
- 处理器映射器找到具体的处理器(可以根据 xml 配置、注解进行查找),生成处理器对象及处理器拦截器(如果有则生成)一并返回给 DispatcherServlet
- DispatcherServlet 调用 HandlerAdapter 处理器适配器
- HandlerAdapter 经过适配调用具体的处理器(Controller,也叫后端控制器)
- Controller 执行完成返回 ModelAndView
- HandlerAdapter 将 Controller 执行结果 ModelAndView 返回给 DispatcherServlet
- DispatcherServlet 将 ModelAndView 传给 ViewReslover 视图解析器
- ViewResolver 解析后返回具体 View
- DispatcherServlet 根据 View 进行渲染视图(即将模型数据填充至视图中)
- DispatcherServlet 响应用户
SpringMVC 注解解析
@RequestMapping
作用:建立请求 URL 和处理请求方法之间的映射关系
位置:
- 类上,表示请求 URL 的第一级路径,若不写的话,则相当于应用根目录
- 方法上,表示请求 URL 的第二级路径,与第一级路径一起构成请求访问路径
@Controller
@RequestMapping("/user")
public class UserController {
@RequestMapping("/say")
public String say() {
System.out.println("喵");
return "success.jsp";
}
}
如上,则需要使用 /user/say 来访问,而此时会提示找不到 /user/success.jsp ,这是因为return 后面的 ”success.jsp“ 使用的是相对路径,当前访问的是 /user 下的资源,所以默认在该路径下查找 success.jsp ,为了避免这种情况,只需要将其改为
return "/success.jsp";
表示从根目录下查找
参数:
- value ,指定路径,若不写 value ,如上述示例,默认为 value
- method ,指定请求方法,如 @RequestMapping(value = "/say", method = RequestMethod.POST) 指定必须以 post 方式请发送请求
- param ,指定限制请求参数的条件,当条件为多个时,用字符串数组表示
- 包含某个参数:如 params = "userName" 表示请求参数中必须含有 userName
- 不包含某个参数:如 params = “!userName” 表示请求参数中不能含有 userName
- 指定某个参数必须为某个值:如 params = “userName=admin” ,表示请求参数中必须含有 userName ,且值必须为 admin
- 指定某个参数不能为某个值:如 params = ”userName!=admin“ ,表示如果有参数 userName ,那么参数 userName 不能为 admin ,也可以没有参数 userName
配置内部资源视图解析器
在 xml 文件中配置视图解析器,增加路径的前缀和后缀
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/jsp/"/>
<property name="suffix" value=".jsp"/>
</bean>
将之前的 success.jsp 放在 jsp 文件夹中
此时对于
return "success";
相当于未配置视图解析器时的
return "/jsp/success.jsp";