SpringMVC 学习笔记01:简单介绍下MVC以及回顾Servlet

一、什么是MVC?

      MVC是模型(Model)、视图(View)、控制器(Controller)的简写,是一种架构模式,主要作用是降低视图与业务逻辑间的双向耦合。如下图所示就是一个SpringMVC的典型闭环结构:
      大致流程:其实就是一个JSP+servlet+javabean模式,用户在jsp页面进行输入,然后Controller层利用servlet获取用户输入的指令和数据,传递给Model层,模型层包含业务层service和dao持久层,用于处理业务和与数据库进行数据交互处理。最后结果同样是通过servlet返回到view视图层,通过JSP显示给用户。整个过程形成一个闭环系统,不仅提高的代码的复用率与项目的扩展性,且大大降低了项目的维护成本。
在这里插入图片描述

二、回顾下Servlet

2.1 准备工作

      1.新建一个maven项目工程,方便导入依赖包,命名为:SpringMVC,新建完成后,可以删除项目工程下的src文件夹,因为没有实际作用。(在做下面的工作之前,需要提前配置maven,参考下面博客:https://blog.csdn.net/huo920/article/details/82082403)
在这里插入图片描述
在这里插入图片描述
      2.在pom.xml中导入相关依赖,包括单元测试junit,springmvc,servlet,jsp,jstl。代码如下所示:

<dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <type>maven-plugin</type>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>5.1.9.RELEASE</version>
            <type>maven-plugin</type>
        </dependency>
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>servlet-api</artifactId>
            <version>2.5</version>
            <type>maven-plugin</type>
        </dependency>
        <dependency>
            <groupId>javax.servlet.jsp</groupId>
            <artifactId>jsp-api</artifactId>
            <version>2.2</version>
            <type>maven-plugin</type>
        </dependency>
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>jstl</artifactId>
            <version>1.2</version>
            <type>maven-plugin</type>
        </dependency>

正常情况下maven会自动导入依赖包,如下图所示:
在这里插入图片描述
      3.新建普通maven工程,取名为SpringMVC_01_servlet,然后更改为web工程。正常情况下,子Module下会自动导入相关依赖。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.2 编写相关程序

      1.编写View视图层
      index.jsp:运行Tomcat后首先进入的jsp界面,这个界面需要写一个提交的表单,表单里填写method名称

<%--
  Created by IntelliJ IDEA.
  User: Administrator
  Date: 2020/12/25
  Time: 11:08
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
  <head>
    <title>主界面</title>
  </head>
  <body>
    <form action="/SpringMVC/hello"  method="post">   <!--注意这里的第一个/表示端口路径-->
        <input id="my" type="text" name="method">
        <input type = "submit">
    </form>
  </body>
</html>


      Hello.jsp:业务逻辑处理后的跳转界面,用于显示servlet处理后的数据,这里显示的是session域中的msg

<%--
  Created by IntelliJ IDEA.
  User: Administrator
  Date: 2020/12/25
  Time: 11:13
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>回顾Servlet</title>
</head>
<body>
    ${msg}    <!--得到Session域中的数据并显示-->
</body>
</html>

      2.编写HelloServlet业务处理层

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

public class HelloServlet  extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //取得参数
        String method = req.getParameter("method");   //这个method后面通过input输入
        if (method.equals("add")){
            req.getSession().setAttribute("msg","执行了add方法");  //保存在Session域中
        }
        if (method.equals("delete")){
            req.getSession().setAttribute("msg","执行了delete方法"); //保存在Session域中
        }
        //业务逻辑
        //视图跳转
        req.getRequestDispatcher("/WEB-INF/Hello.jsp").forward(req,resp);
    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        doGet(req,resp);    //通过POST请求调用Get请求
    }
}


      3.在web.xml中配置servlet

<?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>HelloServlet</servlet-class>
</servlet>

<servlet-mapping>
    <servlet-name>hello</servlet-name>
    <url-pattern>/hello</url-pattern>    <!--注意这里的第一个/表示到工程路径-->
</servlet-mapping>


</web-app>

工程目录如下图所示:
在这里插入图片描述

2.3配置Tomcat

      首先需要电脑安装了Tomcat,然后在IDEA里配置Tomcat,
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.4测试

      运行Tomcat程序:
1.地址:http://localhost:8080/SpringMVC/
显示(index.jsp界面):
在这里插入图片描述
2.输入方法名,提交表单(add为例):
地址:http://localhost:8080/SpringMVC/hello
显示(Hello.jsp界面):
在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值