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";
}
}