SpringMVC第一课(基础)

SpringMVC第一课

1、添加依赖

<dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-webmvc</artifactId>
      <version>5.1.5.RELEASE</version>
</dependency>
<dependency>
     <groupId>javax.servlet</groupId>
     <artifactId>javax.servlet-api</artifactId>
     <version>3.1.0</version>
</dependency>

2、配置web.xml

<!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>dispatcher</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <!-- 指定SpringMVC 配置文件位置,DispatcherServlet初始化时会初始化Spring上下文(WebApplicationContext) -->
    <!-- 默认配置文件寻找位置:/WEB-INF/{servlet-name}-servlet.xml,如果名字符合默认寻找规则,可以不指定配置文件路径 -->
    <init-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>/WEB-INF/dispatcher-servlet.xml</param-value>
    </init-param>
    <!-- 配置容器启动时初始化DispatcherServlet -->
    <load-on-startup>1</load-on-startup>
  </servlet>
  
  <servlet-mapping>
    <servlet-name>dispatcher</servlet-name>
    <url-pattern>/</url-pattern>
  </servlet-mapping>

  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
</web-app>

3、配置dispatcher-servlet.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:mvc="http://www.springframework.org/schema/mvc"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans.xsd
       http://www.springframework.org/schema/context
       http://www.springframework.org/schema/context/spring-context.xsd
       http://www.springframework.org/schema/mvc
       http://www.springframework.org/schema/mvc/spring-mvc.xsd">
    <!-- 注解扫描 -->
    <context:component-scan base-package="com.lanou3g.springmvc"/>
    <!-- 如果WEB-INF目录(私有目录)下有不需要后台数据的页面需要通过浏览器直接访问,我们可以通过配置view-controller解决 -->
    <!-- path:对应浏览器访问的路径, view-name:对应视图名称(会通过viewResolver解析成真正的view给调用方(浏览器)) -->
    <mvc:view-controller path="/index" view-name="index"/>

    <!-- 如果配置了上面的view-controller,那默认用于处理@RequestMapping注解的RequestMappingHandlerMapping就会被覆盖掉,
        导致我们在Controller中写的@RequestMapping方法无法处理请求。
        解决办法:添加如下一行,重新启用RequestMappingHandlerMapping
     -->
    <mvc:annotation-driven/>
        

  <!-- 配置视图解析器,用于将Handler方法中返回的视图名解析成真正可展示的页面 -->
<mvc:view-resolvers>
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <property name="prefix" value="/"/>
    <property name="suffix" value=".jsp"/>
</bean>
</mvc:view-resolvers>
</beans>

4、写handler类

地址栏中的地址和@RequestMapping中的相同时就会被这个handler方法拦截处理,return返回到jsp页面

package com.lanou3g.springmvc.web;

import com.lanou3g.springmvc.web.bean.Student;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.servlet.ModelAndView;

import java.util.HashMap;
import java.util.Map;

/**
 * @author hmt
 * @date 2019/6/28 17:07
 */
/**
 * 通过@Controller标注的类会被SpringIOC容器扫描和管理
 */
@Controller
public class HelloAction {
  /**
     * 定义一个Handler, 可以处理http://localhost:8080/springmvc/test/hello这个请求
     * @return
     */
    @RequestMapping("/test/hello")
    public String hello(){
        System.out.println("通过/test/hello进来的");
        return "hello";
    }
    
    @RequestMapping("/test/hello2")
    public String hello2() {
        System.out.println("进入HelloAction.hello2()方法");
        return "hello";
    }
   /**
     * 处理请求,并携带数据跳转到页面
     * @param mv
     * @return
     */
    @RequestMapping("/test/fire")
    public ModelAndView fire(ModelAndView mv){
        System.out.println("进入fire页面");
        mv.setViewName("hello");
        mv.addObject("key","嘻嘻");
        return mv;
    }

    /**
     * 通过@ResponseBody注解标注的方法, 不会被解析成视图, 而是直接将返回的内容本身输出给调用方(浏览器、其他服务、抓包工具)
     * @return
     */
    @ResponseBody
    @RequestMapping("/test/google")
    public String test(){
         System.out.println("进入test()方法");
        return "haha";
    }
}

猜你喜欢

转载自blog.csdn.net/csdn_hmt/article/details/94545897