SpringMVC

目录

SpringMVC(1)

第一章:三层架构和MVC

1. 三层架构

2. MVC模型

第二章:SpringMVC的入门案例

1. SpringMVC的概述(查看大纲文档)

2. Spring中名词

3. SpringMVC和Struts2框架的对比

4. SpringMVC的入门程序

5. 入门案例的执行过程分析

6. RequestMapping注解

第三章:请求参数的绑定

第四章:常用的注解

1. RequestParam注解

2. RequestBody注解

3. PathVariable注解

4. RequestHeader注解

5. CookieValue注解

6. SessionAttributes注解

SpringMVC(2)

1. SpringMVC框架提供的转发和重定向

2. ResponseBody响应json数据

3. SpringMVC实现文件上传

 

4. SpringMVC的异常处理

5. SpringMVC框架中的拦截器

拦截器的概述

自定义拦截器步骤

HandlerInterceptor接口中的方法

配置多个拦截器


SpringMVC(1)

第一章:三层架构和MVC

1. 三层架构

  1. 咱们开发服务器端程序,一般都基于两种形式,一种C/S架构程序,一种B/S架构程序
  2. 使用Java语言基本上都是开发B/S架构的程序,B/S架构又分成了三层架构
  3. 三层架构
  • 表现层WEB层,用来和客户端进行数据交互的。表现层包括展示层和控制层:控制层负责接收请求,展示层负责结果的展示。表现层一般会采用MVC的设计模型MVC 是表现层的设计模型,和其他层没有关系)
  • 业务层:处理公司具体的业务逻辑的
  • 持久层:用来操作数据库的

2. MVC模型

 MVC全名是Model View Controller 模型视图控制器,每个部分各司其职。

  1.  Model:数据模型,JavaBean的类,用来进行数据封装。
  2.  View:指JSPHTML用来展示数据给用户,通常视图是依据模型数据创建的。
  3.  Controller:用来接收用户的请求,整个流程的控制器。用来进行数据校验等。

第二章:SpringMVC的入门案例

1. SpringMVC的概述(查看大纲文档)

    1. 是一种基于Java实现的MVC设计模型的请求驱动类型的轻量级WEB框架。

    2. Spring MVC属于SpringFrameWork的后续产品,已经融合在Spring Web Flow里面。Spring 框架提供

了构建 Web 应用程序的全功能 MVC 模块。

    3. 使用 Spring 可插入的 MVC 架构,从而在使用Spring进行WEB开发时,可以选择使用Spring

SpringMVC框架或集成其他MVC开发框架,如Struts1(现在一般不用)Struts2等。

2. Spring中名词

  • 前端控制器(DispatcherServlet)
  • 请求到处理器映射(HandlerMapping
  • 处理器适配器(HandlerAdapter
  • 视图解析器(ViewResolver
  • 处理器或页面控制器(Controller
  • 验证器( Validator
  • 命令对象(Command 请求参数绑定到的对象就叫命令对象)
  • 表单对象(Form Object 提供给表单展示和提交到的对象就叫表单对象)。

3. SpringMVCStruts2框架的对比

共同点:

  • 它们都是表现层框架,都是基于 MVC 模型编写的。
  • 它们的底层都离不开原始 ServletAPI
  • 它们处理请求的机制都是一个核心控制器。

区别:

  • Spring MVC 的入口是 Servlet, Struts2 Filter
  • Spring MVC 是基于方法设计的,而 Struts2 是基于类,Struts2 每次执行都会创建一个动作类。所
  • Spring MVC 会稍微比 Struts2 快些。
  • Spring MVC 使用更加简洁,同时还支持 JSR303, 处理 ajax 的请求更方便(JSR303 是一套 JavaBean 参数校验的标准,它定义了很多常用的校验注解,我们可以直接将这些注解加在我们 JavaBean 的属性上面,就可以在需要校验的时候进行校验了。)
  • Struts2 OGNL 表达式使页面的开发效率相比 Spring MVC 更高些,但执行效率并没有比 JSTL 升,尤其是 struts2 的表单标签,远没有 html 执行效率高。

4. SpringMVC的入门程序

1. 创建WEB工程,引入开发的jar包,具体的坐标如下

<!-- 版本锁定 -->

<properties>

<spring.version>5.0.2.RELEASE</spring.version>

</properties>

<dependencies>

<dependency>

<groupId>org.springframework</groupId>

<artifactId>spring-context</artifactId>

<version>${spring.version}</version>

</dependency>

<dependency>

<groupId>org.springframework</groupId>

<artifactId>spring-web</artifactId>

<version>${spring.version}</version>

</dependency>

<dependency>

<groupId>org.springframework</groupId>

<artifactId>spring-webmvc</artifactId>

<version>${spring.version}</version>

</dependency>

<dependency>

<groupId>javax.servlet</groupId>

<artifactId>servlet-api</artifactId>

<version>2.5</version>

<scope>provided</scope>

</dependency>

<dependency>

<groupId>javax.servlet.jsp</groupId>

<artifactId>jsp-api</artifactId>

<version>2.0</version>

<scope>provided</scope>

</dependency>

</dependencies>

2. 配置核心的控制器(配置DispatcherServlet) 在web.xml配置文件中核心控制器DispatcherServlet

<!-- SpringMVC的核心控制器 -->

<servlet>

<servlet-name>dispatcherServlet</servlet-name>

<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-

class>

<!-- 配置Servlet的初始化参数,读取springmvc的配置文件,创建spring容器 -->

<init-param><param-name>contextConfigLocation</param-name>

<param-value>classpath:springmvc.xml</param-value>

</init-param>

<!-- 配置servlet启动时加载对象 -->

<load-on-startup>1</load-on-startup>

</servlet>

<servlet-mapping>

<servlet-name>dispatcherServlet</servlet-name>

<url-pattern>/</url-pattern>

</servlet-mapping>

3. 编写springmvc.xml的配置文件

<?xml version="1.0" encoding="UTF-8"?>

<beans xmlns="http://www.springframework.org/schema/beans"

xmlns:mvc="http://www.springframework.org/schema/mvc"

xmlns:context="http://www.springframework.org/schema/context"

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

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

<!-- 配置spring创建容器时要扫描的包 -->

<context:component-scan base-package="com.itheima"></context:component-scan>

<!-- 配置视图解析器 -->

<bean id="viewResolver"

class="org.springframework.web.servlet.view.InternalResourceViewResolver">

<property name="prefix" value="/WEB-INF/pages/"></property>

<property name="suffix" value=".jsp"></property>

</bean>

<!-- 配置spring开启注解mvc的支持

<mvc:annotation-driven></mvc:annotation-driven>-->

</beans>

4. 编写index.jspHelloController控制器类

1. index.jsp

<body>

<h3>入门案例</h3>

<a href="${ pageContext.request.contextPath }/hello">入门案例</a>

</body>

2. HelloController

package cn.itcast.controller;

import org.springframework.stereotype.Controller;

import org.springframework.web.bind.annotation.RequestMapping;

/**

* 控制器

* @author rt

*/

@Controller

public class HelloController {

/**

* 接收请求

* @return

*/

@RequestMapping(path="/hello")

public String sayHello() {

System.out.println("Hello SpringMVC!!");

return "success";

}

}

5. WEB-INF目录下创建pages文件夹,编写success.jsp的成功页面

6. 启动Tomcat服务器,进行测试

5. 入门案例的执行过程分析

1. 入门案例的执行流程

  1. 当启动Tomcat服务器的时候,因为配置了load-on-startup标签,所以会创建DispatcherServlet对象,就会加载springmvc.xml配置文件
  2. 开启了注解扫描,那么HelloController对象就会被创建
  3. index.jsp发送请求,请求会先到达DispatcherServlet核心控制器,根据配置@RequestMapping注解找到执行的具体方法
  4. 根据执行方法的返回值,再根据配置的视图解析器,去指定的目录下查找指定名称的JSP文件
  5. Tomcat服务器渲染页面,做出响应

2. SpringMVC官方提供图形

3. 入门案例中的组件分析

  • 前端控制器(DispatcherServlet)

    用户请求到达前端控制器,它就相当于 mvc 模式中的 cdispatcherServlet 是整个流程控制的中心,由它调用其它组件处理用户的请求,dispatcherServlet 的存在降低了组件之间的耦合性。

  • 处理器映射器(HandlerMapping)

    HandlerMapping 负责根据用户请求找到 Handler 即处理器,SpringMVC 提供了不同的映射器实现不同的映射方式,例如:配置文件方式,实现接口方式,注解方式等。

  • 处理器(Handler)

    它就是我们开发中要编写的具体业务控制器。由 DispatcherServlet 把用户请求转发到 Handler。由 Handler 对具体的用户请求进行处理。

  • 处理器适配器(HandlAdapter)

    通过 HandlerAdapter 对处理器进行执行,这是适配器模式的应用,通过扩展适配器可以对更多类型的处理器进行执行。

  • 视图解析器(View Resolver)

    View Resolver 负责将处理结果生成 View 视图,View Resolver 首先根据逻辑视图名解析成物理视图名,即具体的页面地址,再生成 View 视图对象,最后对 View 进行渲染将处理结果通过页面展示给用户。

  • 视图(View)

    SpringMVC 框架提供了很多的 View 视图类型的支持,包括:jstlViewfreemarkerView、pdfView 等。我们最常用的视图就是 jsp。 一般情况下需要通过页面标签或页面模版技术将模型数据通过页面展示给用户,需要由程序员根据业务需求开 发具体的页面。

6. RequestMapping注解

1. RequestMapping注解的作用是建立请求URL和处理方法之间的对应关系

2. RequestMapping注解可以作用在方法和类上 作用在类上:第一级的访问目录 作用在方法上:第二级的访问目录

3. 细节:路径可以不编写 / 表示应用的根目录开始

4. 细节:${ pageContext.request.contextPath }也可以省略不写,但是路径上不能写 /

RequestMapping的属性

  • path 指定请求路径的url
  • value value属性和path属性是一样的
  • mthod 指定该方法的请求方式
  • params 指定限制请求参数的条件
  • headers 发送的请求中必须包含的请求头

第三章:请求参数的绑定

  1. 请求参数的绑定说明

    1. 绑定机制

      1. 表单提交的数据都是k=v格式的 username=haha&password=123

      2. SpringMVC的参数绑定过程是把表单提交的请求参数,作为控制器中方法的参数进行绑定的

      3. 要求:提交表单的name和参数的名称是相同的

    2. 支持的数据类型

      1. 基本数据类型和字符串类型

      2. 实体类型(JavaBean)

      3. 集合数据类型(List、map集合等)

  2. 基本数据类型和字符串类型

    1. 提交表单的name和参数的名称是相同的

    2. 区分大小写

  3. 实体类型(JavaBean)

    1. 提交表单的name和JavaBean中的属性名称需要一致

    2. 如果一个JavaBean类中包含其他的引用类型,那么表单的name属性需要编写成:对象.属性 例如: address.name

  4. 给集合属性数据封装

    1. JSP页面编写方式:list[0].属性

        请求参数中文乱码的解决

  1.         在web.xml中配置Spring提供的过滤器类

    <!-- 配置过滤器,解决中文乱码的问题 -->
    
    <filter>
    
    <filter-name>characterEncodingFilter</filter-name>
    
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-
    
    class>
    
    <!-- 指定字符集 -->
    
    <init-param>
    
    <param-name>encoding</param-name>
    
    <param-value>UTF-8</param-value>
    
    </init-param>
    
    </filter>
    
    <filter-mapping>
    
    <filter-name>characterEncodingFilter</filter-name>
    
    <url-pattern>/*</url-pattern>
    
    </filter-mapping>

    自定义类型转换器

  2.         表单提交的任何数据类型全部都是字符串类型,但是后台定义Integer类型,数据也可以封装上,说明Spring框架内部会默认进行数据类型转换。如果想自定义数据类型转换,可以实现Converter的接口

 

  1. 自定义类型转换器
    package cn.itcast.utils;
    
    import java.text.DateFormat;
    
    import java.text.SimpleDateFormat;
    
    import java.util.Date;
    
    import org.springframework.core.convert.converter.Converter;
    
    /**
    
    * 把字符串转换成日期的转换器
    
    * @author rt
    
    */
    
    public class StringToDateConverter implements Converter<String, Date>{
    
    /**
    
    * 进行类型转换的方法
    
    */
    
    public Date convert(String source) {
    
    // 判断
    
    if(source == null) {
    
    throw new RuntimeException("参数不能为空");
    
    }try {
    
    DateFormat df = new SimpleDateFormat("yyyy-MM-dd");
    
    // 解析字符串
    
    Date date = df.parse(source);
    
    return date;
    
    } catch (Exception e) {
    
    throw new RuntimeException("类型转换错误");
    
    }
    
    }
    
    }

     

  2. 注册自定义类型转换器,在springmvc.xml配置文件中编写配置
    <!-- 注册自定义类型转换器 -->
    
    <bean id="conversionService"
    
    class="org.springframework.context.support.ConversionServiceFactoryBean">
    
    <property name="converters">
    
    <set>
    
    <bean class="cn.itcast.utils.StringToDateConverter"/>
    
    </set>
    
    </property>
    
    </bean>
    
    <!-- 开启Spring对MVC注解的支持 -->
    
    <mvc:annotation-driven conversion-service="conversionService"/>

 

 

       在控制器中使用原生的ServletAPI对象,只需要在控制器的方法参数定义HttpServletRequestHttpServletResponse对象

第四章:常用的注解

1. RequestParam注解

1. 作用:把请求中的指定名称的参数传递给控制器中的形参赋值

2. 属性

1. value:请求参数中的名称

2. required:请求参数中是否必须提供此参数,默认值是true,必须提供

3. 代码如下

/**

* 接收请求

* @return

*/

@RequestMapping(path="/hello")

public String sayHello(@RequestParam(value="username",required=false)String name) {

System.out.println("aaaa");

System.out.println(name);

return "success";

}

2. RequestBody注解

1. 作用:用于获取请求体的内容(注意:get方法不可以)

2. 属性

1. required:是否必须有请求体,默认值是true

3. 代码如下

/**

* 接收请求

* @return

*/

@RequestMapping(path="/hello")

public String sayHello(@RequestBody String body) {

System.out.println("aaaa");

System.out.println(body);

return "success";

}

3. PathVariable注解

1. 作用:拥有绑定url中的占位符的。例如:url中有/delete/{id}{id}就是占位符

2. 属性

1. value:指定url中的占位符名称

3. Restful风格的URL,请求路径一样,可以根据不同的请求方式去执行后台的不同方法
4. 代码如下

<a href="user/hello/1">入门案例</a>

/**

* 接收请求

* @return

*/

@RequestMapping(path="/hello/{id}")

public String sayHello(@PathVariable(value="id") String id) {

System.out.println(id);

return "success";

}

4. RequestHeader注解

1. 作用:获取指定请求头的值

2. 属性

1. value:请求头的名称

3. 代码如下

@RequestMapping(path="/hello")

public String sayHello(@RequestHeader(value="Accept") String header) {

System.out.println(header);

return "success";

}

5. CookieValue注解

1. 作用:用于获取指定cookie的名称的值

2. 属性

1. valuecookie的名称

3. 代码

@RequestMapping(path="/hello")

public String sayHello(@CookieValue(value="JSESSIONID") String cookieValue) {

System.out.println(cookieValue);

return "success";

}

6. SessionAttributes注解

1. 作用:用于多次执行控制器方法间的参数共享

2. 属性

1. value:指定存入属性的名称

3. 代码如下

@Controller

@RequestMapping(path="/user")

@SessionAttributes(value= {"username","password","age"},types=

{String.class,Integer.class}) // 把数据存入到session域对象中 public class HelloController {

/**

*向session中存入值

*@return

*/

@RequestMapping(path="/save")

public String save(Model model) {

System.out.println("向session域中保存数据");

model.addAttribute("username", "root");

model.addAttribute("password", "123");

model.addAttribute("age", 20);

return "success";

}

/**

*从session中获取值

*@return

*/

@RequestMapping(path="/find")

public String find(ModelMap modelMap) {

String username = (String) modelMap.get("username"); String password = (String) modelMap.get("password"); Integer age = (Integer) modelMap.get("age"); System.out.println(username + " : "+password +" : "+age); return "success";

}

/**

*清除值

*@return

*/

@RequestMapping(path="/delete")

public String delete(SessionStatus status) {

status.setComplete();

return "success";

}

}

SpringMVC(2)

1. SpringMVC框架提供的转发和重定向

forward请求转发

/**

使用forward关键字进行请求转发

"forward:转发的JSP路径",不走视图解析器了,所以需要编写完整的路径

\@return

\@throws Exception

*/

\@RequestMapping("/delete")

public String delete() throws Exception {

System.out.println("delete方法执行了...");

return "forward:/WEB-INF/pages/success.jsp"; return "forward:/user/findAll";

}

 redirect重定向

 

/**

重定向

\@return

\@throws Exception */

\@RequestMapping("/count")

public String count() throws Exception {

System.out.println("count方法执行了...");

return "redirect:/add.jsp";

// return "redirect:/user/findAll";

}

 

2. ResponseBody响应json数据

  1. DispatcherServlet会拦截到所有的资源,导致一个问题就是静态资源(img、css、js)也会被拦截到,从而不能被使用。解决问题就是需要配置静态资源不进行拦截,在springmvc.xml配置文件添加如下配置

    1. [mvc:resources]标签配置不过滤

      1. location元素表示webapp目录下的包下的所有文件

      2. mapping元素表示以/static开头的所有请求路径,如/static/a 或者/static/a/b

        <!-- 设置静态资源不过滤 -->				
        <mvc:resources location="/css/" mapping="/css/**"/>	<!	-- 样式	-->	
        <mvc:resources location="/images/" mapping="/images/**"/>  <!--	图片	-->
        <mvc:resources location="/js/" mapping="/js/**"/>	<!--	javascript --	>

         

  2. 使用\@RequestBody获取请求体数据

  3. 使用@ResponseBody注解把JavaBean对象转换成json字符串,直接响应

 

3. SpringMVC实现文件上传

  1. SpringMVC框架提供了MultipartFile对象,该对象表示上传的文件,要求变量名称必须和表单file标签的name属性名称相同。
  2. 代码如下:
    @Controller
    @RequestMapping("/file")
    public class UserController {
    
        @RequestMapping("/fileload1")
        public String fileload1(HttpServletRequest request, MultipartFile upload) throws IOException {
            System.out.println("springmvc上传文件...");
    
            //上传文件路径
            String path = request.getSession().getServletContext().getRealPath("/uploads");
            File file = new File(path);
            if (!file.exists()){
                file.mkdirs();
            }
    
            //获取到上传文件的名称
            String filename = upload.getOriginalFilename();
            filename = UUID.randomUUID().toString().replaceAll("-","")+"_"+filename;
            //上传文件
            upload.transferTo(new File(path,filename));
    
            return "success";
        }
    }
  3. 配置文件解析器对象
    <!-- 配置文件解析器对象,要求id名称必须是multipartResolver -->
        <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
            <property name="maxUploadSize" value="10485760"/>
        </bean>

     

4. SpringMVC的异常处理

  1. 自定义异常处理器
    public class SysExceptionResolver implements HandlerExceptionResolver {
        @Override
        public ModelAndView resolveException(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) {
            ModelAndView mv = new ModelAndView();
            mv.addObject("errorMessage",e.getMessage());
            mv.setViewName("error");
            return mv;
        }
    }
  2. 自定义异常处理器
    <!--配置异常处理器-->
    <bean id="sysExceptionResolver" class="cn.itcast.exception.SysExceptionResolver"></bean>

5. SpringMVC框架中的拦截器

拦截器的概述

    1. SpringMVC框架中的拦截器用于对处理器进行预处理和后处理的技术。

    2. 可以定义拦截器链,连接器链就是将拦截器按着一定的顺序结成一条链,在访问被拦截的方法时,拦截器链中的拦截器会按着定义的顺序执行。

    3. 拦截器和过滤器的功能比较类似,有区别

      1. 过滤器是Servlet规范的一部分,任何框架都可以使用过滤器技术。

      2. 拦截器是SpringMVC框架独有的。

      3. 过滤器配置了/*,可以拦截任何资源。

      4. 拦截器只会对控制器中的方法进行拦截。

    4. 拦截器也是AOP思想的一种实现方式

    5. 想要自定义拦截器,需要实现HandlerInterceptor接口。

    6.  

自定义拦截器步骤

  1. 创建类,实现HandlerInterceptor接口,重写需要的方法

  2. 在springmvc.xml中配置拦截器类

HandlerInterceptor接口中的方法

  1. preHandle方法是controller方法执行前拦截的方法

    1. 可以使用request或者response跳转到指定的页面

    2. return true放行,执行下一个拦截器,如果没有拦截器,执行controller中的方法。

    3. return false不放行,不会执行controller中的方法。

  2. postHandle是controller方法执行后执行的方法,在JSP视图执行前。

    1. 可以使用request或者response跳转到指定的页面

    2. 如果指定了跳转的页面,那么controller方法跳转的页面将不会显示。

  3. postHandle方法是在JSP执行后执行

    1. request或者response不能再跳转页面了

配置多个拦截器

  1. 再编写一个拦截器的类

  2. 配置2个拦截器

 

 

 

 

 

 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值