Spring MVC 原子学习法 之 web.xml 中的配置

简介: Spring MVC  原子学习法 之  web.xml 中的配置太阳火神的美丽人生 (http://blog.csdn.net/opengl_es)本文遵循“署名-非商业用途-保持一致”创作公用协议转载请保留此句:太阳火神的美丽人生 -  本博客专注于 敏捷开发及移动和物联设备研究:iOS、Android、Html5、Arduino、pcDuino,否则,出自本博客的文章拒绝转载或再转载,谢谢合作。

Spring MVC  原子学习法 之  web.xml 中的配置

太阳火神的美丽人生 (http://blog.csdn.net/opengl_es)

本文遵循“署名-非商业用途-保持一致”创作公用协议

转载请保留此句:太阳火神的美丽人生 -  本博客专注于 敏捷开发及移动和物联设备研究:iOS、Android、Html5、Arduino、pcDuino否则,出自本博客的文章拒绝转载或再转载,谢谢合作。


由上图可以看得出,Spring-MVC 应用的配置要从 JavaWeb 的配置文件 web.xml 开始加载各项 servlet、listener、filter、。。。

以上图最简方式来解析,一个是 Spring 上下文加载监听器,一个是 Spring-Mvc 的分发器 Servlet。

它们都有各自默认的配置文件,也可以象上图中一样,给它们指定配置文件如以 classpath 来限定和集中配置文件。


年初时曾以 Spring 3.x 为例做了一个非 Maven 的工程,彼时发现上面两者所加载的配置文件中的 bean 的上下文不一致,

导致在 Spring 监听器配置文件中配置的 bean,无法在 Spring-Mvc 的上下文中使用,而是新创建的 bean,

最终将监听器中配置文件直接由 Spring-Mvc 分发器来一同加载,这样就可以在 Spring-Mvc 中实例化的 bean 中引入到 Spring 中配置的 bean 了。

(一天后继续云)

但不知 Spring 4.x 是否解决这个问题了(或许真不知道有没有人偿试这个问题),这会儿有时间想整个景儿来试验一下,在整景儿之前,先整理一下 Spring 和 Spring-Mvc 的默认配置文件位置和可配置的配置文件位置:

Spring 默认配置文件,在 Spring 4.2 官方文档中描述如下:

http://docs.spring.io/spring/docs/current/spring-framework-reference/htmlsingle/#context-create

如果参数配置不存在的话,监听器默认使用  /WEB-INF/applicationContext.xml 。

否则可以使用 web.xml 中的如上图中的配置参数指定多个配置文件加载,可以使用空格、逗号或分号来分隔多个配置文件。也可以使用 ant 类型通配。

Spring-Mvc 的所有配置信息在官方文档中的位置:

http://docs.spring.io/spring/docs/current/spring-framework-reference/htmlsingle/#mvc-servlet

WEB-INF 目录下的 servlet 名字与配置文件位置关联,如 servlet 名字定义为 golfing,那么配置文件名为 golfing-servlet.xml ,完整路径前加 WEB-INF 。

以上默认配置文件位置,也可以用以下初始参数值为空等同配置:

如果不想使用默认的与 servlet 名字有关的配置文件及 WEB-INF 的位置,那么可以在 <param-value></param-value> 中指定配置,而且可以是多个。


以上这些事儿呢,其实老 JavaWeb 开发人员都很熟,俺也在多年前比较熟,但确从没有在官方文档中这么明确地知道,自打 2008 年开始紧随苹果、谷歌开始做 iOS、Android 开发并只能从官方英文文档开始研究起,便不断地了解到这一点,并且无论任何说法,我都要从官方英文文档中得知确切说明才肯信,因为一份英文技术资料,不同理解程度所能表达的角度是不同的,跟着这些文档玩盲人摸象,确实很累,远累过手并看英文。


进一步的 Spring 4.x 中上下文与 Spring-Mvc 是否是同一个以便共用 bean,测试场景,今天有些累就先不做了,“一咻哥,不要着急,休息休息”。


目录
打赏
0
0
0
0
25
分享
相关文章
Spring IOC—基于注解配置和管理Bean 万字详解(通俗易懂)
Spring 第三节 IOC——基于注解配置和管理Bean 万字详解!
155 26
|
1天前
|
微服务——SpringBoot使用归纳——Spring Boot集成 Swagger2 展现在线接口文档——Swagger2 的配置
本文介绍了在Spring Boot中配置Swagger2的方法。通过创建一个配置类,添加`@Configuration`和`@EnableSwagger2`注解,使用Docket对象定义API文档的详细信息,包括标题、描述、版本和包路径等。配置完成后,访问`localhost:8080/swagger-ui.html`即可查看接口文档。文中还提示了可能因浏览器缓存导致的问题及解决方法。
14 0
微服务——SpringBoot使用归纳——Spring Boot集成 Swagger2 展现在线接口文档——Swagger2 的配置
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestParam
本文介绍了 `@RequestParam` 注解的使用方法及其与 `@PathVariable` 的区别。`@RequestParam` 用于从请求中获取参数值(如 GET 请求的 URL 参数或 POST 请求的表单数据),而 `@PathVariable` 用于从 URL 模板中提取参数。文章通过示例代码详细说明了 `@RequestParam` 的常用属性,如 `required` 和 `defaultValue`,并展示了如何用实体类封装大量表单参数以简化处理流程。最后,结合 Postman 测试工具验证了接口的功能。
14 0
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestParam
【Spring】方法注解@Bean,配置类扫描路径
@Bean方法注解,如何在同一个类下面定义多个Bean对象,配置扫描路径
208 73
微服务——SpringBoot使用归纳——Spring Boot事务配置管理——Spring Boot 事务配置
本文介绍了 Spring Boot 中的事务配置与使用方法。首先需要导入 MySQL 依赖,Spring Boot 会自动注入 `DataSourceTransactionManager`,无需额外配置即可通过 `@Transactional` 注解实现事务管理。接着通过创建一个用户插入功能的示例,展示了如何在 Service 层手动抛出异常以测试事务回滚机制。测试结果表明,数据库中未新增记录,证明事务已成功回滚。此过程简单高效,适合日常开发需求。
8 0
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——MyBatis 介绍和配置
本文介绍了Spring Boot集成MyBatis的方法,重点讲解基于注解的方式。首先简述MyBatis作为持久层框架的特点,接着说明集成时的依赖导入,包括`mybatis-spring-boot-starter`和MySQL连接器。随后详细展示了`properties.yml`配置文件的内容,涵盖数据库连接、驼峰命名规范及Mapper文件路径等关键设置,帮助开发者快速上手Spring Boot与MyBatis的整合开发。
12 0
微服务——SpringBoot使用归纳——Spring Boot集成Thymeleaf模板引擎——依赖导入和Thymeleaf相关配置
在Spring Boot中使用Thymeleaf模板,需引入依赖`spring-boot-starter-thymeleaf`,并在HTML页面标签中声明`xmlns:th=&quot;http://www.thymeleaf.org&quot;`。此外,Thymeleaf默认开启页面缓存,开发时建议关闭缓存以实时查看更新效果,配置方式为`spring.thymeleaf.cache: false`。这可避免因缓存导致页面未及时刷新的问题。
13 0
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestBody
`@RequestBody` 是 Spring 框架中的注解,用于将 HTTP 请求体中的 JSON 数据自动映射为 Java 对象。例如,前端通过 POST 请求发送包含 `username` 和 `password` 的 JSON 数据,后端可通过带有 `@RequestBody` 注解的方法参数接收并处理。此注解适用于传递复杂对象的场景,简化了数据解析过程。与表单提交不同,它主要用于接收 JSON 格式的实体数据。
11 0
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@PathVariable
`@PathVariable` 是 Spring Boot 中用于从 URL 中提取参数的注解,支持 RESTful 风格接口开发。例如,通过 `@GetMapping(&quot;/user/{id}&quot;)` 可以将 URL 中的 `{id}` 参数自动映射到方法参数中。若参数名不一致,可通过 `@PathVariable(&quot;自定义名&quot;)` 指定绑定关系。此外,还支持多参数占位符,如 `/user/{id}/{name}`,分别映射到方法中的多个参数。运行项目后,访问指定 URL 即可验证参数是否正确接收。
12 0
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestMapping
@RequestMapping 是 Spring MVC 中用于请求地址映射的注解,可作用于类或方法上。类级别定义控制器父路径,方法级别进一步指定处理逻辑。常用属性包括 value(请求地址)、method(请求类型,如 GET/POST 等,默认 GET)和 produces(返回内容类型)。例如:`@RequestMapping(value = &quot;/test&quot;, produces = &quot;application/json; charset=UTF-8&quot;)`。此外,针对不同请求方式还有简化注解,如 @GetMapping、@PostMapping 等。
12 0