1、springMVC 工作原理
-
客户端发送HTTP请求到dispatcherservlet (前置控制器)
-
dispatcherservlet 根据适配器的规则 Handlermapper 找到控制器 controller
-
diaparcherservlet 将请求提交到controller 进行处理
-
controller 调用service 进行业务处理返回modelandview 到前置控制器
-
前置控制器根据viewresolver 前端适配器 把modelandview 和视图进行匹配
-
视图返回到客户端
2、springmvc 工作模式
1、引入springjar 包 ,spring web 相关的两个包,使用注解引入aop 包
2、在web.xml 文件配置前置控制器
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!-- 表示容器再启动时立即加载servlet -->
<load-on-startup>1</load-on-startup>
</servlet>
3、创建web 页面
4、创建对应的controller 处理类,继承controller接口
5、在web-inf 目录下创建 springmvc-servlet.xml 配置文件,配置映射关系
<bean name="/login" class="controller.LoginController"/>
<!-- LoginController控制器类,映射到"/register" -->
<bean name="/register" class="controller.RegisterController"/>
3、ViewResolver 视图解析器, 制定重定向Url 地址规则
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" >
<!--前缀-->
<property name="prefix" value="/WEB-INF/jsp/"/>
<!--后缀-->
<property name="suffix" value=".jsp"/>
</bean>
制定的规则是页面前缀是/WEB-INF/jsp/ ,后缀是.jsp
为安全起见jsp 页面放置在web-INF 目录下,request 请求是请求不到此目录下的内容,InternalResourceView 在服务器跳转的方式可以很好的解决这个问题
4、注解控制器对比配置文件控制器有点
1、配置文件控制器需要配置文件配置映射关系,注解不需要
2、注解控制器可以有多个处理方法,配置文件控制器只能有一个方法
方法级别注解
package controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
/**
* “@Controller”表示 IndexController 的实例是一个控制器
*
* @Controller相当于@Controller(@Controller) 或@Controller(value="@Controller")
*/
@Controller
public class IndexController {
@RequestMapping(value = "/index/login")
public String login() {
/**
* login代表逻辑视图名称,需要根据Spring MVC配置
* 文件中internalResourceViewResolver的前缀和后缀找到对应的物理视图
*/
return "login";
}
@RequestMapping(value = "/index/register")
public String register() {
return "register";
}
}
类级别注解的
package controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
@RequestMapping("/index")
public class IndexController {
@RequestMapping("/login")
public String login() {
return "login";
}
@RequestMapping("/register")
public String register() {
return "register";
}
}
5、 获取参数几种方法
1、通过bean实体类get方法获取,要求是属性名跟页面参数名一致
2、通过处理方法的形参获取参数,要求是形参与请求参数名称完成相同,适用于get post方法
3、通过HttpServletRequest 类获取请求参数
public String register(HttpServletRequest request,Model model) {
String uname = request.getParameter("uname");
String upass = request.getParameter("upass");
if ("zhangsan".equals(uname)
&& "123456".equals(upass)) {
logger.info("成功");
return "login"; // 注册成功,跳转到 login.jsp
4、通过@PathVariable注解获取参数
public String register(@PathVariable String uname,@PathVariable String upass,Model model) {
if ("zhangsan".equals(uname)
&& "123456".equals(upass)) {
logger.info("成功");
return "login"; // 注册成功,跳转到 login.jsp
5、通过@RequestParam 注解获取参数,当请求参数跟形参名称不一致时会报404 ,处理方法形参不会
public String register(@RequestParam String uname,
@RequestParam String upass, Model model) {
if ("zhangsan".equals(uname) && "123456".equals(upass)) {
logger.info("成功");
return "login"; // 注册成功,跳转到 login.jsp
6、通过@ModelAttribute 注解获取,多个请求参数封装到实体类中,自动暴露数据,视图展示使用,通过实体类不行
public String register(@ModelAttribute("user") UserForm user) {
if ("zhangsan".equals(uname) && "123456".equals(upass)) {
logger.info("成功");
return "login"; // 注册成功,跳转到 login.jsp
6、重定向与转发
@RequestMapping("/login")
public String login() {
//转发到一个请求方法(同一个控制器类可以省略/index/)
return "forward:/index/isLogin";
}
@RequestMapping("/isLogin")
public String isLogin() {
//重定向到一个请求方法
return "redirect:/index/isRegister";
}
7、@Autowired和@Service 注解
Autowired 注解是对象注入到属性中,此对象必须使用service 注解声明
8、json 数据交互
使用@Requestbody 注解获取请求参数绑定到方法的形参中
使用 Responsebody 注解 直接返回到 return 对象中
@ResponseBody
public Person testJson(@RequestBody Person user) {
// 打印接收的JSON格式数据
System.out.println("pname=" + user.getPname() + ",password="
+ user.getPassword() + ",page" + user.getPage());
;
// 返回JSON格式的响应
return user;
}
9、拦截器两种实现方式
1、 实现HandlerInterceptor接口 翻译:拦截器
2、实现 WebRequestInterceptor 接口
HandlerInterceptor 三个方法不同时段拦截
-
preHandle 方法:该方法在控制器的处理请求方法前执行,其返回值表示是否中断后续操作,返回 true 表示继续向下执行,返回 false 表示中断后续操作。
-
postHandle 方法:该方法在控制器的处理请求方法调用之后、解析视图之前执行,可以通过此方法对请求域中的模型和视图做进一步的修改。
-
afterCompletion 方法:该方法在控制器的处理请求方法执行完成后执行,即视图渲染结束后执行,可以通过此方法实现一些资源清理、记录日志信息等工作。、
配置文件
<mvc:interceptor>
<!-- 配置拦截器作用的路径 -->
<mvc:mapping path="/gotoTest" />
<!-- 定义在<mvc: interceptor>元素中,表示匹配指定路径的请求才进行拦截 -->
<bean class="interceptor.Interceptor2" />
</mvc:interceptor>