SpringMVC学习手稿

本文详细介绍SpringMVC在SSM框架中的应用,包括SpringMVC的六大组件、参数处理、返回值处理等内容,并深入探讨RESTful的支持及实现方法,同时讲解了如何通过SpringMVC解决跨域问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

学习目标

  • 熟悉SpringMVC六大组件的作用及使用
  • 掌握ssm开发框架
  • 掌握SpringMVC对返回值的处理
  • 掌握SpringMVC对参数的处理
  • 理解REST和RESTful,掌握SpringMVC对于RESTful的支持
  • 掌握SpringMVC拦截器的应用
  • 掌握SpringMVC中基于CORS的跨域解决方案
  • 掌握Spring中的父子容器
  • 了解SpringMVC的Mock测试
  • 了解ControllerAdvice类的开发ModelAttributeInitBinderExceptionHandler
  • 了解SpringMVC异常处理
  • 了解SpringMVC中的getpost请求乱码和响应乱码
  • 了解SpringMVC中非注解开发

依赖

  • org.springframework:spring-webmvc:5.0.7.RELEASE
  • javax.servlet:servlet-api:2.5:provided

SSM框架整合

web.xml
<!--配置前端控制器-->
    <servlet>
        <servlet-name>ssm</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:spring/springmvc.xml</param-value>
        </init-param>
        <load-on-startup>2</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>ssm</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>

    <!--指定持久层和业务层的spring配置文件路径-->
    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath:spring/applicationContext-*.xml</param-value>
    </context-param>
    
    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>
springmvc.xml
<!--配置处理Bean的读取-->
    <!--扫描controller注解,多个包中间用逗号分开-->
    <context:component-scan base-package="xct.controller"/>

    <!--配置三大组件之处理器适配器和处理器映射器-->
    <!--内置了RequestMappingHandlerMapping和RequestMappingHandlerAdapt等组件注册-->
    <mvc:annotation-driven/>

    <!--配置三大组件之视图解析器-->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/WEB-INF/jsp/"/>
        <property name="suffix" value=".jsp"/>
    </bean>
applicationContext-dao.xml
<context:property-placeholder location="classpath:db.properties"/>
    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
          destroy-method="close">
        <property name="driverClassName" value="${jdbc.driver}"/>
        <property name="url" value="${jdbc.url}"/>
        <property name="username" value="${jdbc.username}"/>
        <property name="password" value="${jdbc.password}"/>
        <property name="maxActive" value="30"/>
        <property name="maxIdle" value="5"/>
    </bean>

    <bean id="sqSessionFactory"
          class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource"/>
        <property name="typeAliasesPackage" value="xct"/>
    </bean>

返回值的处理

  • 不用注解修饰
    • 返回 ModelAndView
    • 返回 void
    • 返回 String
      • 返回视图 return "路径"
      • 重定向 return "redirect:路径"
      • 转发 return "forward:路径"
  • 使用注解修饰
    • @ResponseBody
      • 使用内置的9种HttpMessageConverter进行匹配,找到合适的Converter进行处理
      • HttpMessageConverter处理逻辑分为两步:
        • 指定HttpServletResponseContentType
        • 将转换之后的数据放到HttpServletResponse对象的响应体返回到页面

参数绑定

  • 简单类型
    • 自动绑定:形参名称与参数名保持一致
    • @RequestParam手动绑定
  • POJO类型
    • 参数名称与POJO属性名称一致
  • 集合数组
    • 批量简单类型数据:简单类型只能使用数组接收不能用List
    • 批量POJO数据:使用List接收,List必须是一个方法参数类中的属性,参数名xxxList[i].yyyxxxMap[yyy]
  • 日期类型
    • 自定义Convter
<mvc:annotation-driven conversion-service="conversionService"/>
    <bean id="conversionService" class="org.springframework.format.support.FormattingConversionServiceFactoryBean">
        <property name="converters">
            <set>
                <bean class="xct.DataConvter"/>
            </set>
        </property>
    </bean>
  • 文件类型
    • 依赖 commons-fileupload:commons-fileupload:1.3.3
    • 配置 MultipartResolver
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
    <property name="maxUploadSize" value="5242880"/>
</bean>

Restful支持

  • REST指的是一组架构约束条件和原则。满足这些约束条件和原则的应用程序或设计就是Restful
  • 特点一:用请求方法区分不同资源
  • 特点二:URL路劲变量
  • 特点三:一种资源有多种表述
    • 使用ContentNegotiationManager这个内容协商管理器来实现
      • 三种内容协商方式
        • 扩展名:比如.json返回json数据,.xml返回xml数据
        • 请求参数:默认是format
        • 请求头设置Accept参数
  • 伴随问题静态资源访问处理mvc:resource
    • 如果在DispatcherServlet中设置url-pattern/则必须对静态资源进行访问处理
<mvc:resource location="/js/" mapping="/js/"/>
<mvc:resource location="/css/" mapping="/css/"/>
<!--Spring会把mapping映射到ResourceHttpRequestHandler,这样静态资源在经过DispatcherServlet转发时就可以找到对应的Handler了。-->

配置拦截器

  • 实现HandlerInterceptor接口
  • 配置拦截器
<mvc:interceptors>
    <!--拦截所有请求-->
    <bean class="xct.MyInterceptor"/>
    <mvc:interceptor>
        <!--拦截指定路径-->
        <mvc:mapping path="/orders/**"/>
        <bean class="xct.MyInterceptor1"/>
    </mvc:interceptor>
</mvc:interceptors>

基于CORS的跨域解决方案

浏览器处于安全考虑,设置了同源策略,简单理解就是DNS域名端口号协议完全相同称为同源

  • 如何解决跨域

    • 解决跨域主要考虑两个方面
    • 一个是臂铠Ajax请求方式
    • 一个是解决同源限制问题
  • 解决跨域的方式有多种

    • 基于JavaScript标签的src方式
    • 基于Jquery的JSONP方式
    • 基于CORS的方式
  • JSONP和CORS的区别

    • JSONP只能解决GET方式提交
    • CORS支持GET、POST方式
  • CORS是一个W3C标准,全称是跨域资源共享(Cross-origin resource sharing
    它允许浏览器向跨源服务器发出XMLHttpRequest请求,从而克服了AJAX只能同源使用的限制
    需要浏览器和服务器同时支持。目前所有浏览器都支持该功能,IE浏览器不能低于IE10

  • CORS原理

    • 请求头注入Origin
    • 服务器需要向响应头注入Access-Control-Allow-Origin
    • 浏览器检测到Access-Control-Allow-Origin,则可以跨域
  • SpringMVC实现

    • @CrossOrigin加到类或方法上
<!--所有请求都支持跨域-->
<mvc:cors>
	<mvc:mapping path="/**"/>
</mvc:cors>

父子容器

  • ContextLoaderListener 加载的配置项会形成一个父容器
  • DispatcherServlet 加载的配置项会形成一个子容器
  • 子容器可依获取父容器配置项,父容器无法获取子容器配置项,例如父容器创建的类无法依赖注入子容器管理的类
  • 如果只用一个配置文件就不会出现父子容器问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值