spring mvc
Spring MVC 是 Spring 框架中的一个重要模块,用于构建基于 Java 的 Web 应用程序。它基于 MVC(Model-View-Controller)设计模式,提供了灵活、可配置的方式来开发动态网页或 RESTful 服务
ssm
SSM 框架 是 Java Web 开发中常用的三大框架整合方案,由 Spring、Spring MVC 和 MyBatis 组成,用于构建高效、松耦合的企业级应用。
项目结构
其中,web.xml的配置文件在WEB-INF这个文件夹的根目录里
springMVC.xml配置文件在src文件夹的config包下
mybatis-config.xml文件夹在src的目录下
这是三个配置
前端
这里前端采用jsp,那么什么是jsp文件
前端就是我们运行后的登陆注册按钮,还有登录注册的输入框,是这几个东西
配置文件
<?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:tx="http://www.springframework.org/schema/tx"
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/tx
http://www.springframework.org/schema/tx/spring-tx.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<!-- 配置数据源,使用dpcp数据库连接池
由于建立传统数据库连接是一个非常耗时耗资源的行为,所以通过连接池预先同数据库建立一些连接,放在内存中,应用程序需要建立数据库连接时直接到连接池中申请一个就行-->
<bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/test?characterEncoding=utf8" />
<property name="username" value="root" />
<property name="password" value="root" />
<!-- 最大连接数 -->
<property name="maxTotal" value="30" />
<!-- 最大空闲连接数 -->
<property name="maxIdle" value="10" />
<!-- 初始化连接数 -->
<property name="initialSize" value="5" />
</bean>
<!-- 添加事务支持 -->
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource" />
</bean>
<!-- 开启事务注解 <tx:annotation-driven transaction-manager="txManager" /> -->
<!-- 配置MyBatis工厂,同时指定数据源,并与MyBatis完美整合 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<!-- configLocation的属性值为MyBatis的核心配置文件 ,用于绑定MyBatis的核心配置文件-->
<property name="configLocation" value="classpath:config/mybatis-config.xml" />
</bean>
<!--Mapper代理开发,MapperScannerConfigurer将包中所有接口自动装配为MyBatis映射接口Mapper的实现类的实例(映射器),
所有映射器都被自动注入SqlSessionFactory实例,同时扫描包中SQL映射文件(.xml)-替代实现类 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!-- 注入要扫描的包,mybatis-spring组件的扫描器,basePackage:属性可以包含多个包名,多个包名之间可以用逗号或分号隔开 -->
<property name="basePackage" value="com.dao" />
<!-- 注入 sqlSessionFactory-->
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
</bean>
</beans>
您提供的项目结构图展示了一个典型的 传统 Spring MVC + MyBatis(SSM)整合项目,这种结构是经过多年 Java Web 开发实践逐步演进而来的。以下是分阶段解析其整合逻辑和演进过程:
1. 为什么能这样整合?
(1) 技术栈的互补性
技术 | 职责 | 整合点 |
---|---|---|
Spring | 容器管理(IoC/AOP)、事务控制 | 通过 applicationContext.xml 统一管理 Bean(Service、DAO、数据源等)。 |
Spring MVC | 处理 HTTP 请求和视图渲染 | 通过 DispatcherServlet 和 springMVC.xml 配置控制器和视图解析。 |
MyBatis | 数据库持久化操作 | 通过 SqlSessionFactoryBean 与 Spring 数据源整合,Mapper 接口自动注入。 |
(2) 分层架构的清晰边界
表现层(Spring MVC) → 业务层(Spring) → 持久层(MyBatis)
• 解耦设计:各层通过接口通信,依赖 Spring 的依赖注入(DI)连接。
• 配置分离:
• web.xml
配置 Web 容器(如 Tomcat)。
• springMVC.xml
专注 MVC 相关配置。
• mybatis-config.xml
专注 SQL 映射和别名。
2. 是否是一步步进化的?
是的!这种结构是传统 Java Web 开发逐步优化的结果,以下是典型演进阶段:
阶段 1:纯 Servlet + JDBC(原始阶段)
• 结构特点:
• 所有逻辑写在 Servlet
中。
• 手动管理数据库连接(DriverManager.getConnection()
)。
• 问题:
• 代码臃肿,难以维护。
• 资源泄露风险高。
阶段 2:引入 MVC 分层(JSP + Servlet + JavaBean)
• 改进点:
• JSP 负责视图,Servlet 负责控制,JavaBean 封装数据。
• 使用连接池(如 DBCP)管理数据库连接。
• 遗留问题:
• 仍需手动编写大量 JDBC 模板代码。
阶段 3:引入框架(Spring + MyBatis)
• 关键优化:
-
Spring 整合:
◦ 通过 IoC 容器管理对象生命周期。◦ 声明式事务(
@Transactional
)替代手动事务代码。 -
MyBatis 替代 JDBC:
◦ SQL 与 Java 代码分离(Mapper XML)。◦ 动态 SQL 支持。
-
Spring MVC 替代 Servlet:
◦ 注解驱动(@Controller
)简化请求映射。◦ 视图解析器自动处理 JSP 路径。
阶段 4:配置优化(逐步精简)
• 演进示例:
• 从多个 XML 文件(如 spring-dao.xml
、spring-service.xml
)合并为统一的 applicationContext.xml
。
• 使用注解(如 @Service
、@Autowired
)替代 XML Bean 定义。
3. 项目结构图中的进化痕迹
(1) 配置文件的分布
文件 | 演进意义 |
---|---|
web.xml | 保留传统 Java EE 的部署描述符,但仅配置 DispatcherServlet (简化)。 |
springMVC.xml | 分离 MVC 相关配置,体现关注点分离思想。 |
mybatis-config.xml | 保留 MyBatis 原生配置,但通过 Spring 的 SqlSessionFactoryBean 整合。 |
(2) 包结构的组织
com.controller → com.service → com.dao (或 mapper)
• 演进逻辑:
• 早期可能所有类放在单一包下,后期按职责分层。
• config
包集中存放配置文件,体现“约定优于配置”趋势。
(3) 静态资源处理
• WebContent/static/
缺失:
早期常将静态资源(如 JS/CSS)直接放在 WebContent
根目录,后期优化为 /static/
并通过 <mvc:resources>
配置。
4. 现代替代方案(对比 Spring Boot)
传统 SSM 结构(如图) | Spring Boot 项目结构 |
---|---|
手动配置 XML(如数据源、事务)。 | 自动配置(application.yml )。 |
依赖 Tomcat 外部部署。 | 内嵌 Tomcat,一键启动。 |
显式定义视图解析器。 | 默认约定(如 src/main/resources/templates/ )。 |
适合需要深度定制的场景。 | 适合快速开发微服务或单体应用。 |
5. 总结:为什么能这样整合?
- 技术互补:
Spring 的 IoC 和 AOP 能力完美粘合 MVC 层和持久层。 - 分层演进:
从 Servlet/JDBC 到框架整合,逐步解决代码复用、维护性问题。 - 配置优化:
通过 XML 和注解的混合使用,平衡灵活性和简洁性。
您的项目结构是 传统 Java Web 开发的最佳实践,虽稍显繁琐,但为理解框架底层原理提供了清晰路径。若追求效率,可逐步迁移到 Spring Boot。
spring boot
从 Spring MVC 到 Spring Boot 的演进并非简单的“改名”,而是 Spring 生态系统为适应现代开发需求所做的全面升级。以下是核心原因和本质变化的深度解析:
一、根本区别:定位与目标
Spring MVC | Spring Boot | |
---|---|---|
定位 | Web 框架(MVC 模块) | 全栈开发脚手架(整合 Spring 全家桶) |
核心目标 | 提供灵活的 MVC 开发模式 | 实现快速启动、约定优于配置、生产就绪 |
二、为什么需要 Spring Boot?
-
解决 Spring MVC 的配置地狱
• Spring MVC 痛点:◦ 需要手动配置
web.xml
、DispatcherServlet
、视图解析器、数据源等。◦ 依赖冲突频繁(如不同版本的 Spring 和第三方库)。
• Spring Boot 方案:
◦ 自动配置:根据类路径依赖智能推断配置(如检测到
spring-boot-starter-web
自动配置 Tomcat 和 Spring MVC)。◦ 起步依赖(Starter):一键引入功能模块(如
spring-boot-starter-data-jpa
包含 Hibernate + JPA + 数据源)。 -
拥抱微服务和云原生
• Spring MVC 局限:◦ 部署依赖外部 Servlet 容器(如手动部署 WAR 到 Tomcat)。
◦ 缺乏对云原生特性(如健康检查、配置中心)的内置支持。
• Spring Boot 突破:
◦ 内嵌服务器(Tomcat/Jetty/Undertow),直接打包为可执行 JAR。
◦ 集成 Spring Cloud 实现服务发现、熔断器等微服务功能。
-
提升开发效率
• Spring MVC 开发流程:1. 手动添加依赖 → 2. 编写 XML/Java 配置 → 3. 解决依赖冲突 → 4. 部署测试
• Spring Boot 开发流程:
1. 选择 Starter → 2. 写业务代码 → 3. 运行 `main()` 方法
三、技术对比:从 MVC 到 Boot 的关键升级
技术点 | Spring MVC | Spring Boot |
---|---|---|
配置方式 | XML 或 Java Config(显式定义 Bean) | 自动配置 + application.properties/yml 覆盖 |
依赖管理 | 手动管理版本兼容性 | Starter 父工程(统一版本号) |
部署方式 | WAR 包部署到外部容器 | 可执行 JAR(内嵌容器) |
监控与运维 | 需集成 Actuator 等模块 | 内置 Actuator(提供健康检查、指标端点) |
测试支持 | 需手动配置 MockMVC | 自动配置测试切片(如 @WebMvcTest ) |
四、Spring Boot 的核心改进
-
约定优于配置
• 默认规则:◦ 静态资源放在
src/main/resources/static
◦ 模板文件放在
src/main/resources/templates
• 开发者只需:专注业务代码,无需写模板配置。
-
模块化设计
• 通过spring-boot-starter-*
按需引入功能:<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <!-- Web + MVC + Tomcat --> </dependency>
-
生产级特性开箱即用
• 内置功能:◦ 监控:
/actuator/health
◦ 外部化配置:多环境
application-{profile}.yml
◦ 安全:集成 Spring Security 基础配置
五、何时选择 Spring MVC?
- 需要精细控制:如自定义 Servlet 过滤器链。
- 遗留系统维护:已有基于 XML 配置的 Spring MVC 项目。
- 教育目的:学习底层 MVC 工作原理。
六、演进本质:从“框架”到“生态”
• Spring MVC 是 单一解决方案(解决 Web 层问题)。
• Spring Boot 是 开发生态系统(整合 Spring MVC + Spring Data + Spring Security + …),提供一站式开发体验。
总结
Spring Boot 不是 Spring MVC 的替代品,而是通过自动化配置和模块化设计,让开发者以更低成本享受 Spring 全家桶的能力。二者的关系类似于:
• Spring MVC = 发动机
• Spring Boot = 整车(含发动机、变速箱、底盘)
现代开发中,除非特殊场景,否则 Spring Boot 是更高效的选择。
spring bean
Spring Bean 详解
什么是 Bean?
在 Spring 框架中,Bean 是由 Spring IoC (Inversion of Control) 容器管理的对象。这些对象构成了应用程序的骨干,并由容器负责它们的创建、组装和管理。
Bean 的核心特性
- 由 Spring 容器管理:不是由开发者直接实例化
- 生命周期受控:容器管理 Bean 的创建、初始化和销毁
- 依赖注入:Bean 之间的依赖关系由容器自动处理
Bean 的配置方式
- XML 配置(传统方式)
<bean id="userService" class="com.example.UserServiceImpl">
<property name="userDao" ref="userDao"/>
</bean>
- Java 注解配置(现代方式)
@Service
public class UserServiceImpl implements UserService {
@Autowired
private UserDao userDao;
}
- Java Config 配置
@Configuration
public class AppConfig {
@Bean
public UserService userService() {
return new UserServiceImpl(userDao());
}
@Bean
public UserDao userDao() {
return new UserDaoImpl();
}
}
Bean 的作用域
Spring 支持多种 Bean 作用域:
作用域 | 描述 |
---|---|
singleton | 默认作用域,每个容器一个实例 |
prototype | 每次请求都创建新实例 |
request | 每个 HTTP 请求一个实例 |
session | 每个 HTTP 会话一个实例 |
application | ServletContext 生命周期 |
websocket | WebSocket 会话生命周期 |
Bean 的生命周期
-
实例化:容器创建 Bean 实例
-
属性填充:注入依赖
-
初始化:
• 调用InitializingBean.afterPropertiesSet()
• 调用自定义
init-method
-
使用:Bean 就绪可用
-
销毁:
• 调用DisposableBean.destroy()
• 调用自定义
destroy-method
常用 Bean 相关注解
注解 | 用途 |
---|---|
@Component | 通用组件注解 |
@Service | 标识服务层组件 |
@Repository | 标识数据访问层组件 |
@Controller | 标识控制器组件 |
@Autowired | 自动注入依赖 |
@Qualifier | 指定具体注入的 Bean |
@Scope | 指定 Bean 作用域 |
@Lazy | 延迟初始化 |
@Primary | 指定优先注入的 Bean |
Bean 的最佳实践
- 尽量使用构造器注入:使依赖关系明确且不可变
- 避免循环依赖:设计时应考虑解耦
- 合理使用作用域:根据业务需求选择
- 善用生命周期回调:进行资源初始化和清理
- 优先使用注解配置:提高开发效率
示例代码
@Service
@Scope("singleton")
public class OrderService {
private final PaymentService paymentService;
@Autowired
public OrderService(PaymentService paymentService) {
this.paymentService = paymentService;
}
@PostConstruct
public void init() {
System.out.println("OrderService initialized");
}
@PreDestroy
public void cleanup() {
System.out.println("OrderService destroyed");
}
}
Spring Bean 是 Spring 框架的核心概念,理解 Bean 的管理机制对于开发高质量的 Spring 应用程序至关重要。