MVC架构:
M
model,模型== JavaBean
作用:处理数据
JavaBean的分类:
1实体类Bean:存储业务数据的业务对象(user)
2业务处理Bean:service/Dao 业务逻辑和数据访问
V:view 视图 用户层
C:Contoller 控制层 ==servlet
三层架构:
持久层+业务层+表述层
表述层:包含前端页面(jsp/html)和servlet
什么是springMVC
springMVC就是将servlet的处理请求的过程给做一个封装的框架
springMVC是基于servlet(控制器)为表述层提供完备的解决方案
重点:springMVC通过强大的前端控制器(DispatcherServlet)
对原生的获取请求以及处理请求进行封装
早期的原生MVC项目
1.导入jar包&配置tomcat
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.13.2</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.3.1</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.2</version>
</dependency>
<dependency>
<groupId>javax.servlet.jsp.jstl</groupId>
<artifactId>jstl-api</artifactId>
<version>1.2</version>
</dependency>
</dependencies>
2.在子module里添加web框架支持
3.new一个servlet类
public class HelloServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
}
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request,response);
}
}
4.注册servlet(web.xml)
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0">
<servlet>
<servlet-name>Hello</servlet-name>
<servlet-class>com.kxy.servlet.HelloServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>Hello</servlet-name>
<url-pattern>/Hello</url-pattern>
</servlet-mapping>
</web-app>
5.编写index.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>index</title>
</head>
<body>
${msg}
</body>
</html>
这里的${msg}就是一个没有被赋值的属性。
6.编写servlet
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//获取参数
String method = request.getParameter("method");
if ("add".equals(method)){
//session域里的msg属性被赋值了"执行了add方法"
request.getSession().setAttribute("msg","执行了add方法");
}
if ("delete".equals(method)){
request.getSession().setAttribute("msg","执行了delete方法");
}
//业务逻辑
//转发视图或者重定向
request.getRequestDispatcher("index.jsp").forward(request,response);
}
当参数method=add时,msg属性被赋值成"执行了add方法"。
当参数method=delete时,msg属性被赋值成"执行了delete方法"。
当我们转发视图为index.jsp的时候,以上的逻辑就在index.jsp上执行。
7.测试
理一下思路:
首先从视图出发,也就是index.jsp,找到${msg}
通过web.xml中注册的servlet,servlet标签引入servlet的类,servlet-mapping标签配置了这个servlet转发请求的路径为/Hello,所以当我们在本地服务器localhost:8080请求/Hello,服务器就会去找这个servlet。首先在servlet里通过获取url的参数method,然后根据参数method来给session域里的msg属性赋值。最后转发视图到index.jsp,这里面发现${msg},已经被servlet赋值了,最后这个视图就会展示最后的结果。
以上的解释是针对于早期mvc架构,它不是springMVC。而springMVC则是优化这个版本。通过spring做优化。具体怎么优化?请看下集 :
链接: 第一个springMVC项目:深度理解DispatcherServlet