SpringMVC入门学习(一)
SpringMVC入门学习(一)
SpringMVC是一个Java WEB框架,现在我们知道Spring了,那么,何为MVC呢?
MVC是一种设计模式,其分为3个方面
- model 模型:dao层和service层
- view 视图:例如jsp和Html
- controller 控制器
SpringMVC原理
SpringMVC工作的原理图如下【图来自于网络,侵删】:
过程如下:
-
http请求:客户端提交请求到DispatcherServlet。
-
寻找处理器:DispatcherServlet是一个Spring提供的前端控制器,所有请求都是他来发放的。但是它需要HandlerMapping定位到具体的Controller。
-
调用处理器:在DispatcherServlet通过HandlerMapping找到控制器后,它就将http请求提交到Controller。
-
调用模型处理业务:Controller执行相关的逻辑代码。
-
ModelAndView:在Controller执行完相关的处理后,返回ModelAndView。
-
处理视图映射:ViewResolver是视图解析器,将一个逻辑上面的视图名称机械为一个真正的视图同时取出model。(ps:例如:将user解析为:/WEB-INF/jsp/user.jsp【下面的例子】)
-
将模型数据传给View显示:将model数据放入view中。
环境搭建配置
-
首先使用maven包快速构建web-app
项目结构图:
-
maven jar包导入:
<dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>5.1.1.RELEASE</version> </dependency>
-
然后将web.xml文件进行更改,使用3.1的版本:
<?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_3_1.xsd" version="3.1"> </web-app>
-
配置web.xml文件
首先,先配置前段控制器
<!-- 配置 Spring MVC DispatchcerServlet 前端控制器 这里写的这个名字是有讲究的,如果我们不去修改spring配置文件默认的位置,那么SpringMVC他会去WEB-INF下面找一个叫springmvc-servlet.xml的文件 --> <servlet> <servlet-name>springmvc</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <!--<init-param>--> <!--可以重新声明配置文件的名字--> <!--<param-name>namespace</param-name>--> <!--将名字变成mvc--> <!--<param-value>mvc</param-value>--> <!--</init-param>--> <init-param> <!--上下文配置的位置的制定--> <param-name>contextConfigLocation</param-name> <!--此时是在类路径下面spring文件夹去寻找,也就是resources/spring--> <param-value>classpath:spring/springmvc.xml</param-value> </init-param> </servlet>
然后进行映射配置:
在web.xml文件中,进行映射配置
<!--servlet的映射配置--> <servlet-mapping> <!-- 将所有的请求都交给springmvc处理,即处理方式在springmvc.xm文 件中 --> <servlet-name>springmvc</servlet-name> <!--这里统一写/--> <url-pattern>/</url-pattern> </servlet-mapping>
关于
url-pattern
的写法问题- / 处理所有的请求,但是他不会像/*一样,将这个girl.jsp当成一个新的请求,而是直接将渲染结果给浏览器
- /* (永远不要这样写):请求/helloController过去的时候,他的视图名称是girl,girl.jsp页面,(出去的时候)它将其当成了一个叫做girl.jsp的请求,去尝试请求对应的controller
- *.do 例如:/helloController.do
关于前段控制器的解释:
springMVC设置的理念是希望我们开发者远离原生的servletAPI【太繁琐了】,希望将操作尽量简化。它将很多东西责任进行了拆分。不希望我们将技术点绑定死,可以做到任意切换。其本身还是基于servlet设计的,分发的servlet。
-
配置springmvc.xml文件
springmvc.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:aop="http://www.springframework.org/schema/aop" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"> </beans>
首先先配置视图解析器和控制器:
<!--配置一个视图解析器 常用内部资源视图解析器 这里面的意思是:加入此时viewName为hello,那么它会到WEB-INF/jsp/hello.jsp中去寻找 --> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <!--1. 前缀--> <property name="prefix" value="/jsp/"/> <!--2. 后缀--> <property name="suffix" value=".jsp"/> </bean> <!-- 注解扫描 --> <context:component-scan base-package="com.weno.controller"/>
书写第一份代码
Controller的写法有两种:
-
接口式
的写法:是一个传统式的写法,类implement一个接口,然后实现接口方法,在modle中填充元素,返回ModelAndView。public class HelloController implements org.springframework.web.servlet.mvc.Controller { @Override public ModelAndView handleRequest(javax.servlet.http.HttpServletRequest httpServletRequest, javax.servlet.http.HttpServletResponse httpServletResponse) throws Exception { ModelAndView mav = new ModelAndView(); mav.addObject("hello","世界"); // 寻找web-inf目录下的jsp/hello.jsp文件 mav.setViewName("hello"); return mav; } }
当然这种方法还要在springmvc中配置bean。
<!-- 此时name相当于URI --> <bean class="com.weno.controller.HelloController" name="/hello"/>
-
注解式
写法:注解式写法要配置注册扫描【前面已经配置】。将前面的换一种写法:
@org.springframework.stereotype.Controller public class HelloController { //URI @RequestMapping("hello") public String hello(Model model){ model.addAttribute("hello","世界"); // 寻找web-inf目录下的jsp/hello.jsp文件 return "hello"; } }
jsp文件
<%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>Title</title> </head> <body> 你好:${requestScope.hello} </body> </html>
结果:
简单的注意点
- @RequestMapping可以同时写在类的上面【模块】和方法的上面【业务】
@org.springframework.stereotype.Controller @RequestMapping("product") public class HelloController { @RequestMapping("add") public String add(Model model){ return ""; } @RequestMapping("del") public String del(Model model){ return ""; } }
/product/add
完成add方法执行,/product/del
完成del方法执行,这样更好的有利于模块化的执行。