SpringMVC框架学习 day01 SpringMVC的入门案例与RequestMapping注解使用

一、案例

案例实现简单的发送请求控制台输出打印案例
(基于 黑马课程 学习的资料与图片)

1.创建maven的WEB工程

在这里插入图片描述

2.引入开发的jar包 (坐标)

具体的坐标如下:

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <maven.compiler.source>1.8</maven.compiler.source>
    <maven.compiler.target>1.8</maven.compiler.target>
    <spring-version>5.0.2.RELEASE</spring-version>
  </properties>

  <dependencies>
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-context</artifactId>
      <version>${spring-version}</version>
    </dependency>
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-web</artifactId>
      <version>${spring-version}</version>
    </dependency>
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-webmvc</artifactId>
      <version>${spring-version}</version>
    </dependency>
    <dependency>
      <groupId>javax.servlet</groupId>
      <artifactId>servlet-api</artifactId>
      <version>2.5</version>
      <scope>provided</scope>   <!-- provided表明该jar包只在编译和测试的时候起作用。-->
    </dependency>
    <dependency>
      <groupId>javax.servlet.jsp</groupId>
      <artifactId>jsp-api</artifactId>
      <version>2.0</version>
      <scope>provided</scope>   <!-- provided表明该jar包只在编译和测试的时候起作用。-->
    </dependency>
  </dependencies>

3.配置核心的控制器(配置DispatcherServlet)

在web.xml配置文件中核心控制器DispatcherServlet

<!DOCTYPE web-app PUBLIC
 "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
 "http://java.sun.com/dtd/web-app_2_3.dtd" >

<web-app>
  <display-name>Archetype Created Web Application</display-name>

  <!-- 配置前端控制器 -->
  <servlet>
    <servlet-name>dispatcherServlet</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <!-- 建立与springmvc.xml联系 配置全局初始化参数让servlet加载xml文件 -->
    <init-param>
      <!-- 给DispatcherServlet类的contextConfigLocation属性传一个路径 -->
      <param-name>contextConfigLocation</param-name>
      <param-value>classpath:springmvc.xml</param-value>
    </init-param>
    <!-- 配置启动服务器创建对象加载 xml 文件 -->
    <load-on-startup>1</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>dispatcherServlet</servlet-name>
    <url-pattern>/</url-pattern>
  </servlet-mapping>

</web-app>

4. 编写springmvc.xml的配置文件

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:mvc="http://www.springframework.org/schema/mvc"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="
        http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/mvc
        http://www.springframework.org/schema/mvc/spring-mvc.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context.xsd">

    <!-- 开启spring IOC注解扫描-->
    <context:component-scan base-package="cn.itcast"></context:component-scan>

    <!-- 配置springMVC视图解析器 -->
    <bean id="internalResourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <!-- prefix 表示文件所在目录 -->
        <property name="prefix" value="/WEB-INF/pages/"></property>
        <!-- suffix 表示文件后缀名 -->
        <property name="suffix" value=".jsp"></property>
    </bean>

    <!-- 开启springMVC 注解支持 -->
    <mvc:annotation-driven conversion-service="conversionServiceFactoryBean"></mvc:annotation-driven>

</beans>

5. 编写index.jsp和HelloController控制器类

5.1 index.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>index</title>
</head>
<body>

    <h1>快速入门</h1>
    <a href="hello">快速入门</a>
    
</body>
</html>

5.2. HelloController

@Controller
@RequestMapping(path = "/user")
public class HelloController {


    @RequestMapping(path = "/hello")   //配置请求映射路径
    public String hello(){
        System.out.println("hello springMVC");
        return "success";
    }


}

5. 在WEB-INF目录下创建pages文件夹,编写success.jsp的成功页

<%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %>
<html>
<head>
    <title>success</title>
</head>
<body>

    <h1>成功</h1>

</body>
</html>

6. 启动Tomcat服务器,进行测试

二、入门案例的执行过程分析

1. 入门案例的执行流程

1.当启动Tomcat服务器的时候,因为配置了load-on-startup标签,所以会创建DispatcherServlet对象, 就会加载springmvc.xml配置文件
2.开启了注解扫描,那么HelloController对象就会被创建
3.从index.jsp发送请求,请求会先到达DispatcherServlet核心控制器,根据配置@RequestMapping注解 找到执行的具体方法
4. 根据执行方法的返回值,再根据配置的视图解析器,去指定的目录下查找指定名称的JSP文件
5. 5. Tomcat服务器渲染页面,做出响应
在这里插入图片描述

2.入门案例中的组件分析

在这里插入图片描述

三、RequestMapping注解使用

  1. RequestMapping注解的作用是 建立请求URL和处理方法之间的对应关系

  2. RequestMapping注解可以作用在方法
    2.1. 作用在上:第一级的访问目录
    2.2. 作用在方法上第二级的访问目录
    2.3. 细节:路径可以不编写 / 表示应用的根目录开始
    2.4. 细节:${ pageContext.request.contextPath }也可以省略不写,但是路径上不能写 /

  3. RequestMapping的属性 1. path 指定请求路径的url 2. value value属性和path属性是一样的 3. mthod 指定该方法的请求方式 4. params 指定限制请求参数的条件 5. headers 发送的请求中必须包含的请求头

发布了17 篇原创文章 · 获赞 0 · 访问量 138

猜你喜欢

转载自blog.csdn.net/weixin_46539792/article/details/105400703
今日推荐