页面
在WEB-INF下新建文件夹page,然后新建一个页面first.jsp。
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<h1>${message}</h1>
</body>
</html>
Spring核心配置文件
这里配置一个页面的公共前后缀即可,在控制类中只需要给定视图名称即可。
<?xml version="1.0" encoding="UTF8"?>
<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:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="
http://www.springframework.org/schema/beans https://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/aop https://www.springframework.org/schema/aop/spring-aop.xsd
http://www.springframework.org/schema/tx https://www.springframework.org/schema/tx/spring-tx.xsd
http://www.springframework.org/schema/mvc https://www.springframework.org/schema/mvc/spring-mvc.xsd">
<bean id="internalResourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/page/"/>
<property name="suffix" value=".jsp"/>
</bean>
</beans>
另外个人整理了一些资料,有需要的朋友可以直接点击领取。
Web.xml配置文件
这一段是固定的,不需要单独注册每一个Servlet,只需要注册一个前端控制器DispatcherServlet即可。
<?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>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:SpringMVC-Servlet.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
Controller
SpringMVC提供了很多种方式将一个类标记为控制类;可以通过实现Controller接口、也可以通过Controller注解完成。
Controller接口
编写一个控制类然后实现Controller接口,重写handleRequest方法实现会请求的接受处理、最后返回一个ModelAndView类。
package com.controller;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.Controller;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class InterfaceController implements Controller {
@Override
public ModelAndView handleRequest(HttpServletRequest request, HttpServletResponse response) throws Exception {
ModelAndView mv = new ModelAndView();
/*
1. 调用业务层
2. 封装数据、以及给出需要响应的视图名
3. 返回ModelAndView对象交给适配器
*/
mv.addObject("message","实现Controller接口"); //数据
mv.setViewName("first"); //响应的视图名
return mv;
}
}
将控制类进行注册,并且给定一个访问路径。最后访问localhost:8080/项目名/inter/first;就能进行访问了。
<bean id="/inter/first" class="com.controller.InterfaceController"/>
Controller注解
最开始了解这个注解是在Spring的时候,当时只是粗略的了解他能用来注册bean,并不知道它能将一个类标记为控制类的功能。Controller注解能够注册bean是因为它被Component注解修饰了,Component注解具有注册的bean能力。
package com.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class AnnotationController {
@RequestMapping("/Annota/first") //注册映射路径
private String firstServlet(Model model){
model.addAttribute("message", "Controller注解"); //封装数据
return "first"; //给出视图名
}
}
使用Controller注解就能将类标记为一个控制类、并且其中的每一个方法都可以认为是一个Servlet。相比实现Controller接口,注解版的功能更强大。当有多个Servlet时只需要写多个方法!
SpringMVC核心配置文件中只需要扩展一点注解驱动、以及MVC注解支持即可。
<!-- 扫描包注解 -->
<context:component-scan base-package="com.controller"/>
<!-- mvc注解驱动 -->
<mvc:annotation-driven/>
<!-- 默认处理器、过滤器 -->
<mvc:default-servlet-handler/>
RequestMapping注解
RequestMapping注解相当于去注册Servlet - 路径的一个映射,表示访问/xxx路径会交给哪个方法处理仅此而已;使用这个注解就可以摆脱核心配置文件,每次配置文件中放入固定的模板代码。控制类中使用Controller注解 + RequestMapping注解。
RequestMapping注解修饰类
当修饰类的时候表示旗下的每个方法都需要加一个前缀路径;
@Controller
@RequestMapping("/father")
public class RequestMappingController {
@RequestMapping("/test1")
private String test1(){
return "test1";
}
@RequestMapping("/test2")
private String test2(){
return "test2";
}
}
test1真实路径: localhost:8080/项目名/father/test1
test2真实路径: localhost:8080/项目名/father/test2
修饰方法
当修饰方法时是只具体的路径。
@Controller
public class RequestMappingController {
@RequestMapping("/test1")
private String test1(){
return "test1";
}
@RequestMapping("/father/test2")
private String test2(){
return "test2";
}
}
最后
感谢你能看到这里,觉得文章对你有帮助的话记得点个赞,感谢你的支持!
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。