2021-04-16

SpringMVC

1. 什么是SpringMVC?

Spring MVC属于SpringFrameWork的后续产品,已经融合在Spring Web Flow里面

Spring 框架提供的web模块,包含了开发Web 应用程序的全功能 MVC 模块从而在使用Spring进行WEB开发时,可以选择使用Spring的SpringMVC框架集成其他WEB MVC开发框架,如Struts(现在一般不用),Struts2(一般老项目使用)等。

SpringMVC是web层的mvc开发框架,属于Spring框架WEB模块中的一个部分。

2.开发一个基于SpringMVC的程序

1.创建项目

2. 完善项目结构

3. 导入依赖

<!-- 配置开发SpringMVC所以来的jar包 -->
<!-- https://mvnrepository.com/artifact/org.springframework/spring-webmvc -->
<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-webmvc</artifactId>
    <version>5.1.5.RELEASE</version>
</dependency>
<!-- 配置ServletAPI依赖 -->
<!-- https://mvnrepository.com/artifact/javax.servlet/javax.servlet-api -->
<dependency>
    <groupId>javax.servlet</groupId>
    <artifactId>javax.servlet-api</artifactId>
    <version>3.0.1</version>
    <scope>provided</scope>
</dependency>
<!--配置JSP依赖包-->
<!-- https://mvnrepository.com/artifact/javax.servlet.jsp/javax.servlet.jsp-api -->
<dependency>
    <groupId>javax.servlet.jsp</groupId>
    <artifactId>javax.servlet.jsp-api</artifactId>
    <version>2.2.1</version>
    <scope>provided</scope>
</dependency>
<!--配置JSTL的依赖-->
<!-- https://mvnrepository.com/artifact/javax.servlet/jstl -->
<dependency>
    <groupId>javax.servlet</groupId>
    <artifactId>jstl</artifactId>
    <version>1.2</version>
</dependency>

4.在web.xml文件中配置中央处理器【DispatcherServlet】

DispatcherServlet本身就是一个Servlet,因此在web.xml文件中配置中央处理器用servlet/servlet-mapping配置

<servlet>
    <servlet-name>dispatcherServle</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
</servlet>
<servlet-mapping>
    <servlet-name>dispatcherServle</servlet-name>
    <url-pattern>/</url-pattern>
</servlet-mapping>

注意:<url-pattern>/</url-pattern>/”后面没有*

5.创建处理请求的控制器

package com.wangxing.springmvc.controller;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.Controller;
//控制器类【处理用户请求】
public class HelloController implements Controller {
    //用户请求处理方法
    @Override
    public ModelAndView handleRequest(javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response) throws Exception {
        String info="hello,网星软件";
        ModelAndView mav=new ModelAndView();
        mav.addObject("info",info);
        mav.setViewName("test.jsp");
        return mav;
    }
}

6.在resources中创建springMVC的配置文件。

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       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">
    <!--配置URL解析器-->
    <!--org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping-->
    <bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"></bean>
    <!--配置控制器适配器-->
    <!--org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter-->
    <bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"></bean>
    <!--配置自定义的控制器-->
    <!--name:自定义的控制器的访问路径-->
    <!--class:自定义的控制器的包名+类名-->
    <bean name="/hello" class="com.wangxing.springmvc.controller.HelloController"></bean>
    <!--配置视图解析器-->
    <!--org.springframework.web.servlet.view.InternalResourceViewResolver-->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/"></property>
        <property name="suffix"  value=""></property>
    </bean>
</beans>
7.web.xml文件中配置加载springmvc的配置文件
<servlet>
  <servlet-name>dispatcherServle</servlet-name>
  <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  <!--配置加载springmvc的配置文件-->
  <init-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:springmvc.xml</param-value>
  </init-param>
</servlet>

8.创建jsp文件

<%@page language="java" pageEncoding="UTF-8" isELIgnored="false" %>
<html>
<body>
<h2>${info}</h2>
</body>
</html>

9.配置服务器部署程序

10.浏览器测试http://localhost:8080/SpringMVCDemo1_war/hello

2. SpringMVC的执行流程

  1. 启动服务器的时候配置在web.xml文件中的中央控制器【DispatcherServlet】被初始化完成,并且加载配置的springMVC的配置文件。
  2. 客户端浏览器发送http请求。
  3. http请求被中央控制器【DispatcherServlet】拦截,转交给url解析器解析。
  4. Url解析器解析http请求,得到具体的请求路径。
  5. Url解析器将解析得到的具体的请求路径返回给中央控制器【DispatcherServlet】
  6. 中央控制器【DispatcherServlet】将得到的具体的请求路径转交给控制器适配器。
  7. 控制器适配器根据具体的请求路径在springmvc配置文件中查找与之对应的请求处理类【控制器类】。
  8. 请求处理类【控制器类】就执行具体的请求处理,得到ModelAndView对象【1.数据。2.跳转地址】,将ModelAndView对象交给控制器适配器,控制器适配器将ModelAndView对象返回给中央控制器【DispatcherServlet】。
  9. 中央控制器【DispatcherServlet】将ModelAndView对象转交给视图解析器去解析。
  10. 视图解析器解析ModelAndView对象,得到一个具体的数据显示路径,将这个具体的数据显示路径返回给中央控制器【DispatcherServlet】。
  11. 中央控制器【DispatcherServlet】得到具体的数据显示路径之后,将路径所代表的资源转换执行成一个html数据。
  12. 将转换执行后的html数据返回给客户端浏览器。
  1. SpringMVC请求的访问路径配置

3.1web.xml文件中DispatcherServlet配置的<url-pattern>

1. <url-pattern>/</url-pattern>

与之对应的spring配置文件的控制器bean元素的name属性值“/xxxx

对应 http://127.0.0.1:8080/springmvc1/add

2. <url-pattern>*.do</url-pattern>

与之对应的spring配置文件的控制器bean元素的name属性值“/xxxx.do

对应  http://127.0.0.1:8080/springmvc1/add.do

<url-pattern>/*</url-pattern>  这是一个错误的方式  

3.2springmvc配置文件中的控制器的name属性值

控制器的name属性值设置要与web.xml文件中DispatcherServlet配置的<url-pattern>

的配置形式一致

1web.xml文件中DispatcherServlet配置的<url-pattern>/</url-pattern>那么springmvc配置文件中的控制器的name属性值应该为“/xxxx

http://127.0.0.1:8080/springmvc1/add

2web.xml文件中DispatcherServlet配置的<url-pattern>*.do</url-pattern>那么springmvc配置文件中的控制器的name属性值应该为“/xxxx.do

http://127.0.0.1:8080/springmvc1/add.do

3.3请求处理的控制器类中请求处理方法handleRequest的返回值ModelAndView

1. 创建一个普通的java类,实现org.springframework.web.servlet.mvc.Controller

接口

2. 重写handleRequest方法【处理用请求的方法】

3. 在springmvc的配置文件中配置
<!-- 与web.xml文件中的中央处理器DispatcherServlet的url-pattern的配置形式匹配-->
<bean name="/hello.do" class="com.wangxing.springmvc.controller.HelloController"></bean>

例如:

package com.wangxing.springmvc.controller;

import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.Controller;
//控制器类【处理用户请求】
public class HelloController implements Controller {
    //用户请求处理方法
    @Override
    public ModelAndView handleRequest(javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response) throws Exception {
        String info="hello,网星软件";
        ModelAndView mav=new ModelAndView();
        mav.addObject("info",info);
        mav.setViewName("test.jsp");
        return mav;
    }
}

请求处理方法handleRequest的返回值ModelAndView

1.ModelAndView--java类

2.组成ModelAndView类的第一部分是一个Model【模型】封装数据

第二部分是一个View【视图】展示数据的页面元素

3.ModelAndView类是用来封装数据,展示数据的页面元素。

4.构造方法ModelAndView()来创建ModelAndView类的对象

ModelAndView  mav=new ModelAndView();

5.封装数据的方法addObject(attributeName, attributeValue)相当于setAttribute(key,value)

mav.addObject("info",hello,网星软件);

6.设置展示数据的页面元素的名称setViewName(viewName)

      mav.setViewName("test.jsp");

      mav.setViewName("test");

      mav.setViewName("test.html");

      mav.setViewName("控制器对应的请求处理路径");

      mav.setViewName("test");---forword跳转[转发]

      mav.setViewName("forward:test.jsp");

      mav.setViewName("redirect:test.jsp");----sendRedirect跳转[重定向]

3.4视图解析器

例如:

<!--配置视图解析器-->
<!--org.springframework.web.servlet.view.InternalResourceViewResolver-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!--前缀配置:[工程访问路径“http://localhost:8080/SpringMVCDemo1_war/”]-->
    <property name="prefix" value="/"></property>
<!--后缀配置-->
    <property name="suffix"  value=""></property>
</bean>

利用请求处理类中的得到的视图名,通过视图解析器的前缀和后缀合并得到一个完整的的访问路径。

 prefix+视图名称+suffix : 完整的元素访问路径

例如:ModelAndView  mav=new ModelAndView();

        mav.setViewName("test.jsp");

<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
     <property name="prefix" value="/"></property>
     <property name="suffix" value=".jsp"></property>
</bean>

经过视图解析器解析以后的完整路径

http://localhost:8080/SpringMVCDemo1_war/test.jsp

例如:ModelAndView  mav=new ModelAndView();

    mav.setViewName("test");

     <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
     <property name="prefix" value="/"></property>
     <property name="suffix"  value=".html"></property>
  </bean>

经过视图解析器解析以后的完整路径

http://localhost:8080/SpringMVCDemo1_war/test.html

4. DispatcherServlet中央处理器设置加载SpringMVC配置文件的设置

  1. 当springMVC配置文件在resources目录下时

resources根目录

<!--配置加载springmvc的配置文件-->
	<init-param>
  		<param-name>contextConfigLocation</param-name>
  		<param-value>classpath:xxxxxxxxxxxx.xml</param-value>
    </init-param>

 resources目录的子文件夹【spring】中

<!--配置加载springmvc的配置文件-->
    <init-param>
      	<param-name>contextConfigLocation</param-name>
      	<param-value>classpath:spring/xxxxxxxxxxxx.xml</param-value>
    </init-param>

 

2.当springMVC配置文件在WEB-INF目录下

2.1 Spring配置文件的名称

中央控制器对应的servlet-name元素的值-servlet.xml

2.2 在web.xml文件中servlet配置元素中不需要出现<init-param>

1.SpringMVC的注解开发

1. 创建项目

2. 完善项目

3. 导入依赖

4. 配置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>dispatcherServle</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>classpath:springmvc.xml</param-value>
    </init-param>
  </servlet>
  <servlet-mapping>
    <servlet-name>dispatcherServle</servlet-name>
    <url-pattern>*.do</url-pattern>
  </servlet-mapping>
</web-app>

5. 配置SpringMVC配置文件

<?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:mvc="http://www.springframework.org/schema/mvc"
       xmlns:context="http://www.springframework.org/schema/context"
       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">
    <!--开启注解-->
    <mvc:annotation-driven></mvc:annotation-driven>
    <!--配置自动扫描包-->
    <context:component-scan base-package="com.wangxing.springmvc.controller"></context:component-scan>
    <!--配置视图解析器-->
    <!--org.springframework.web.servlet.view.InternalResourceViewResolver-->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/"></property>
        <property name="suffix"  value=""></property>
    </bean>
</beans>

6. 创建控制器

package com.wangxing.springmvc.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;
@Controller
public class HelloController {
    @RequestMapping("/test1.do")
    public ModelAndView  testRequest(){
        ModelAndView  mav=new ModelAndView();
        mav.addObject("info","hello,网星软件");
        mav.setViewName("test.jsp");
        return  mav;
    }
}

7. 创建jsp

8.  配置服务部署项目

9. 测试http://localhost:8080/spingmvc2/test1.do

 2. @Controller注解

@Controller---表示我们所编写的java类是一个处理请求的控制器类。

              只能作用在java类。

              可以使用@Component去代替,在javaweb程序中是分层出来的为了表名java类是一个控制器,我们才使用@Controller

@Controller中包含有@Component。

@Controller与我们在spring中学习的@Service和@Repository将应用程序标记为不同的层。

数据访问层------@Repository

业务访问层------@Service

Web层【控制层】----@Controller

webapp------------静态资源

3. @RequestMapping

设置控制器类/请求处理方法的访问路径的

@RequestMapping可以作用在java类上,表示配置这个java类的访问路径;

package com.wangxing.springmvc.controller;
import org.springframework.stereotype.Controller;
import org.springframework.stereotype.Repository;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
@Controller
@RequestMapping("/hello")
public class HelloController{
    @RequestMapping("/test1.do")
    public ModelAndView  testRequest(){
        ModelAndView  mav=new ModelAndView();
        mav.addObject("info","hello,网星软件");
        mav.setViewName("test.jsp");
        return  mav;
    }
}

http://localhost:8080/spingmvc2/hello/test1.do

如果控制器类中没有@RequestMapping("/hello"),那么我们要访问请求处理方法就可以直接使用请求处理方法上@RequestMapping("/test1.do")的访问路径。

package com.wangxing.springmvc.controller;
import org.springframework.stereotype.Controller;
import org.springframework.stereotype.Repository;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
@Controller
public class HelloController{
    @RequestMapping("/test1.do")
    public ModelAndView  testRequest(){
        ModelAndView  mav=new ModelAndView();
        mav.addObject("info","hello,网星软件");
        mav.setViewName("test.jsp");
        return  mav;
    }
}

http://localhost:8080/spingmvc2/test1.do

@RequestMapping也可以作用在请求处理方法上,表示配置这个请求处理方法的访问路径。

@RequestMapping的常用的属性

1. value表示设置访问路径[可以省略]  

@RequestMapping(value = "/test1.do")

可以省略

@RequestMapping("/test1.do")

设置访问路径的时候可以设置通配符

 ? : 匹配任何单字符 

例如:@RequestMapping("/?hello.test")

http://localhost:8080/spingmvc2/atest1.do

http://localhost:8080/spingmvc2/test1.do //错误

http://localhost:8080/spingmvc2/hhhtest1.do //错误

*  : 匹配任意数量的字符

例如:@RequestMapping("/*hello.test")

http://localhost:8080/spingmvc2/test1.do

http://localhost:8080/spingmvc2/wtest1.do

http://localhost:8080/spingmvc2/wwwtest1.do

例如:@RequestMapping("/*/hello.test")

http://localhost:8080/spingmvc2/w/test1.do

http://localhost:8080/spingmvc2/www/test1.do

http://localhost:8080/spingmvc2/test1.do  //错误

http://localhost:8080/spingmvc2/hhhh/www/test1.do  //错误

** : 匹配多个路径

例如:@RequestMapping("/**/hello.test")

http://localhost:8080/spingmvc2/test1.do

http://localhost:8080/spingmvc2/w/test1.do

http://localhost:8080/spingmvc2/www/test1.do

http://localhost:8080/spingmvc2/hhh/www/test1.do

2. method--限制请求的访问方式【GET、POST.....】

表现形式:@RequestMapping(value = "/login.do",method = RequestMethod.POST )

Index.jsp

<%@page language="java" pageEncoding="UTF-8" %>
<html>
<body>
  <form action="test1.do" method="get">
    <input type="submit" value="测试Method属性"/>
  </form>
</body>
</html>
package com.wangxing.springmvc.controller;
import org.springframework.stereotype.Controller;
import org.springframework.stereotype.Repository;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
@Controller
public class HelloController{
    @RequestMapping(value = "/test1.do",method = RequestMethod.POST)
    public ModelAndView  testRequest(){
        ModelAndView  mav=new ModelAndView();
        mav.addObject("info","hello,网星软件");
        mav.setViewName("test.jsp");
        return  mav;
    }
}

将index.jsp页面中的表单提交放射修改成post即可成功。

只能处理get请求

@RequestMapping(value = "/gethello.do",method = RequestMethod.GET)
@GetMapping(value = "/gethello.do")

只能处理post请求

@RequestMapping(value = "/gethello.do",method = RequestMethod.POST)
@PostMapping(value = "/gethello.do")

 

猜你喜欢

转载自blog.csdn.net/weixin_53123681/article/details/115752901