陈雄华技术高手,毕业于厦门大学计算机与信息工程学院,倾心Spring技术研究多年,是ROP开源项目创始人,担任过多家公司的系统架构师、技术总监,主持过多个大型企业级应用及多家公司基础技术平台的研发,拥有丰富的一线实战经验。出版《精通JBuilder 2005》、《精通Spring 3.x》、《Spring就这么简单》等多本技术书籍,广受读者好评。林开雄资深软件开发经理,拥有10余年软件开发经验,对Spring、大数据、应用虚拟化、微服务等开源技术的应用和实现原理有深入研究,拥有丰富的产品研发实战经验,目前专注于大数据解决方案以及微服务的研究与实施,参与《精通Spring 3.x》、《Spring就这么简单》等多本技术书籍的创作。文建国系统架构设计师、高级项目经理,精通Spring等优秀开源技术在企业中的应用,主要研究方向为云计算、大数据、业务基础平台、分布式等技术。曾参与中国电信ITSP 3.0技术架构规范的编写,有多个大型全国集中项目的架构和管理经验。目前致力于“智能制造”的人机一体化系统研发,希望通过物联网与互联网的融合提升生产效率和增强企业原有系统。热衷于开源技术布道,曾译有《Spring Data实战》、《大规模Java平台虚拟化与调优》等书籍。
Spring 4.0是Spring在积蓄4年后,隆重推出的一个重大升级版本,进一步加强了Spring作为Java领域第一开源平台的翘楚地位。Spring 4.0引入了众多Java开发者翘首以盼的基于Groovy Bean的配置、HTML 5/WebSocket支持等新功能,全面支持Java 8.0,最低要求是Java 6.0。这些新功能实用性强、易用性高,可大幅降低Java应用,特别是Java Web应用开发的难度,同时有效提升应用开发的优雅性。本书是在《精通Spring 3.x——企业应用开发详解》的基础上,历时一年的重大调整改版而成的,延续了上一版本“追求深度,注重原理,不停留在技术表面”的写作风格,力求使读者在熟练使用Spring的各项功能的同时透彻理解Spring的内部实现,真正做到知其然并知其所以然。此外,本书重点突出了“实战性”的主题,力求使全书内容体现“从实际项目中来,到实际项目中去”的写作原则。
第1篇 基础篇第1章 Spring概述 21.1 认识Spring 21.2 关于SpringSource 41.3 Spring带给我们什么 51.4 Spring体系结构 61.5 Spring对Java版本的要求 81.6 Spring 4.0新特性 81.6.1 全面支持Java 8.0 91.6.2 核心容器的增强 111.6.3 支持用Groovy定义Bean 121.6.4 Web的增强 121.6.5 支持WebSocket 121.6.6 测试的增强 131.6.7 其他 131.7 Spring子项目 131.8 如何获取Spring 151.9 小结 16第2章 快速入门 172.1 实例概述 172.1.1 比Hello World更适用的实例 182.1.2 实例功能简介 182.2 环境准备 202.2.1 构建工具Maven 202.2.2 创建库表 222.2.3 建立工程 232.2.4 类包及Spring配置文件规划 282.3 持久层 292.3.1 建立领域对象 292.3.2 UserDao 302.3.3 LoginLogDao 332.3.4 在Spring中装配DAO 342.4 业务层 352.4.1 UserService 352.4.2 在Spring中装配Service 372.4.3 单元测试 382.5 展现层 402.5.1 配置Spring MVC框架 402.5.2 处理登录请求 422.5.3 JSP视图页面 442.6 运行Web应用 462.7 小结 48第3章 Spring Boot 493.1 Spring Boot概览 493.1.1 Spring Boot发展背景 503.1.2 Spring Boot特点 503.1.3 Spring Boot启动器 503.2 快速入门 523.3 安装配置 543.3.1 基于Maven环境配置 543.3.2 基于Gradle环境配置 563.3.3 基于Spring Boot CLI环境配置 573.3.4 代码包结构规划 583.4 持久层 593.4.1 初始化配置 593.4.2 UserDao 613.5 业务层 623.6 展现层 643.6.1 配置pom.xml依赖 643.6.2 配置Spring MVC框架 653.6.3 处理登录请求 653.7 运维支持 673.8 小结 70第2篇 核心篇第4章 IoC容器 724.1 IoC概述 724.1.1 通过实例理解IoC的概念 734.1.2 IoC的类型 754.1.3 通过容器完成依赖关系的注入 774.2 相关Java基础知识 784.2.1 简单实例 784.2.2 类装载器ClassLoader 804.2.3 Java反射机制 834.3 资源访问利器 854.3.1 资源抽象接口 854.3.2 资源加载 884.4 BeanFactory和ApplicationContext 914.4.1 BeanFactory介绍 924.4.2 ApplicationContext介绍 944.4.3 父子容器 1034.5 Bean的生命周期 1034.5.1 BeanFactory中Bean的生命周期 1034.5.2 ApplicationContext中Bean的生命周期 1124.6 小结 114第5章 在IoC容器中装配Bean 1155.1 Spring配置概述 1165.1.1 Spring容器高层视图 1165.1.2 基于XML的配置 1175.2 Bean基本配置 1205.2.1 装配一个Bean 1205.2.2 Bean的命名 1205.3 依赖注入 1215.3.1 属性注入 1215.3.2 构造函数注入 1245.3.3 工厂方法注入 1285.3.4 选择注入方式的考量 1305.4 注入参数详解 1305.4.1 字面值 1305.4.2 引用其他Bean 1315.4.3 内部Bean 1335.4.4 null值 1335.4.5 级联属性 1345.4.6 集合类型属性 1345.4.7 简化配置方式 1385.4.8 自动装配 1415.5 方法注入 1425.5.1 lookup方法注入 1425.5.2 方法替换 1435.6 <bean>之间的关系 1445.6.1 继承 1445.6.2 依赖 1455.6.3 引用 1465.7 整合多个配置文件 1475.8 Bean作用域 1485.8.1 singleton作用域 1485.8.2 prototype作用域 1495.8.3 与Web应用环境相关的Bean作用域 1505.8.4 作用域依赖问题 1525.9 FactoryBean 1535.10 基于注解的配置 1555.10.1 使用注解定义Bean 1555.10.2 扫描注解定义的Bean 1565.10.3 自动装配Bean 1575.10.4 Bean作用范围及生命过程方法 1625.11 基于Java类的配置 1645.11.1 使用Java类提供Bean定义信息 1645.11.2 使用基于Java类的配置信息启动Spring容器 1675.12 基于Groovy DSL的配置 1695.12.1 使用Groovy DSL提供Bean定义信息 1695.12.2 使用GenericGroovyApplicationContext启动Spring容器 1715.13 通过编码方式动态添加Bean 1725.13.1 通过DefaultListableBeanFactory 1725.13.2 扩展自定义标签 1735.14 不同配置方式比较 1755.15 小结 177第6章 Spring容器高级主题 1786.1 Spring容器技术内幕 1786.1.1 内部工作机制 1796.1.2 BeanDefinition 1826.1.3 InstantiationStrategy 1836.1.4 BeanWrapper 1836.2 属性编辑器 1846.2.1 JavaBean的编辑器 1856.2.2 Spring默认属性编辑器 1886.2.3 自定义属性编辑器 1896.3 使用外部属性文件 1926.3.1 PropertyPlaceholderConfigurer属性文件 1926.3.2 使用加密的属性文件 1956.3.3 属性文件自身的引用 1986.4 引用Bean的属性值 1996.5 国际化信息 2016.5.1 基础知识 2016.5.2 MessageSource 2066.5.3 容器级的国际化信息资源 2096.6 容器事件 2106.6.1 Spring事件类结构 2116.6.2 解构Spring事件体系的具体实现 2136.6.3 一个实例 2146.7 小结 215第7章 Spring AOP基础 2167.1 AOP概述 2167.1.1 AOP到底是什么 2177.1.2 AOP术语 2197.1.3 AOP的实现者 2217.2 基础知识 2227.2.1 带有横切逻辑的实例 2227.2.2 JDK动态代理 2247.2.3 CGLib动态代理 2287.2.4 AOP联盟 2297.2.5 代理知识小结 2307.3 创建增强类 2307.3.1 增强类型 2307.3.2 前置增强 2317.3.3 后置增强 2357.3.4 环绕增强 2367.3.5 异常抛出增强 2377.3.6 引介增强 2397.4 创建切面 2437.4.1 切点类型 2437.4.2 切面类型 2447.4.3 静态普通方法名匹配切面 2467.4.4 静态正则表达式方法匹配切面 2487.4.5 动态切面 2517.4.6 流程切面 2547.4.7 复合切点切面 2567.4.8 引介切面 2587.5 自动创建代理 2597.5.1 实现类介绍 2597.5.2 BeanNameAutoProxyCreator 2607.5.3 DefaultAdvisorAutoProxyCreator 2617.5.4 AOP无法增强疑难问题剖析 2627.6 小结 267第8章 基于@AspectJ和Schema的AOP 2698.1 Spring对AOP的支持 2698.2 Java 5.0注解知识快速进阶 2708.2.1 了解注解 2708.2.2 一个简单的注解类 2718.2.3 使用注解 2728.2.4 访问注解 2738.3 着手使用@AspectJ 2748.3.1 使用前的准备 2758.3.2 一个简单的例子 2758.3.3 如何通过配置使用@AspectJ切面 2778.4 @AspectJ语法基础 2788.4.1 切点表达式函数 2788.4.2 在函数入参中使用通配符 2798.4.3 逻辑运算符 2808.4.4 不同增强类型 2818.4.5 引介增强用法 2828.5 切点函数详解 2838.5.1 @annotation() 2848.5.2 execution() 2858.5.3 args()和@args() 2878.5.4 within() 2888.5.5 @within()和@target() 2898.5.6 target()和this() 2908.6 @AspectJ进阶 2918.6.1 切点复合运算 2928.6.2 命名切点 2928.6.3 增强织入的顺序 2948.6.4 访问连接点信息 2948.6.5 绑定连接点方法入参 2958.6.6 绑定代理对象 2978.6.7 绑定类注解对象 2988.6.8 绑定返回值 2998.6.9 绑定抛出的异常 2998.7 基于Schema配置切面 3008.7.1 一个简单切面的配置 3008.7.2 配置命名切点 3028.7.3 各种增强类型的配置 3038.7.4 绑定连接点信息 3058.7.5 Advisor配置 3068.8 混合切面类型 3078.8.1 混合使用各种切面类型 3088.8.2 各种切面类型总结 3088.9 其他 3098.9.1 JVM Class文件字节码转换基础知识 3098.9.2 使用LTW织入切面 3118.10 小结 314第9章 Spring SpEL 3169.1 JVM动态语言 3169.2 SpEL表达式概述 3189.3 SpEL核心接口 3199.3.1 EvaluationContext接口 3209.3.2 SpEL编译器 3219.4 SpEL基础表达式 3239.4.1 文本字符解析 3239.4.2 对象属性解析 3239.4.3 数组、集合类型解析 3249.4.4 方法解析 3269.4.5 操作符解析 3279.4.6 安全导航操作符 3299.4.7 三元操作符 3309.4.8 Elvis操作符 3319.4.9 赋值、类型、构造器、变量 3329.4.10 集合过滤 3359.4.11 集合转换 3359.5 在Spring中使用SpEL 3369.5.1 基于XML的配置 3369.5.2 基于注解的配置 3379.6 小结 338第3篇 数据篇第10章 Spring对DAO的支持 34010.1 Spring的DAO理念 34010.2 统一的异常体系 34110.2.1 Spring的DAO异常体系 34110.2.2 JDBC的异常转换器 34310.2.3 其他持久化技术的异常转换器 34410.3 统一数据访问模板 34410.3.1 使用模板和回调机制 34510.3.2 Spring为不同持久化技术所提供的模板类 34710.4 数据源 34810.4.1 配置一个数据源 34810.4.2 获取JNDI数据源 35210.4.3 Spring的数据源实现类 35310.5 小结 353第11章 Spring的事务管理 35511.1 数据库事务基础知识 35511.1.1 何为数据库事务 35611.1.2 数据并发的问题 35711.1.3 数据库锁机制 35911.1.4 事务隔离级别 36011.1.5 JDBC对事务的支持 36111.2 ThreadLocal基础知识 36211.2.1 ThreadLocal是什么 36311.2.2 ThreadLocal的接口方法 36311.2.3 一个TheadLocal实例 36411.2.4 与Thread同步机制的比较 36611.2.5 Spring使用ThreadLocal解决线程安全问题 36611.3 Spring对事务管理的支持 36811.3.1 事务管理关键抽象 36911.3.2 Spring的事务管理器实现类 37111.3.3 事务同步管理器 37411.3.4 事务传播行为 37511.4 编程式的事务管理 37611.5 使用XML配置声明式事务 37711.5.1 一个将被实施事务增强的服务接口 37911.5.2 使用原始的TransactionProxyFactoryBean 37911.5.3 基于aop/tx命名空间的配置 38211.6 使用注解配置声明式事务 38511.6.1 使用@Transactional注解 38511.6.2 通过AspectJ LTW引入事务切面 38911.7 集成特定的应用服务器 39011.7.1 BEA WebLogic 39011.7.2 WebSphere 39011.8 小结 390第12章 Spring的事务管理难点剖析 39212.1 DAO和事务管理的牵绊 39312.1.1 JDBC访问数据库 39312.1.2 Hibernate访问数据库 39512.2 应用分层的迷惑 39812.3 事务方法嵌套调用的迷茫 40112.3.1 Spring事务传播机制回顾 40112.3.2 相互嵌套的服务方法 40212.4 多线程的困惑 40512.4.1 Spring通过单实例化Bean简化多线程问题 40512.4.2 启动独立线程调用事务方法 40512.5 联合军种作战的混乱 40812.5.1 Spring事务管理器的应对 40812.5.2 Hibernate+Spring JDBC混合框架的事务管理 40812.6 特殊方法成漏网之鱼 41212.6.1 哪些方法不能实施SpringAOP事务 41212.6.2 事务增强遗漏实例 41312.7 数据连接泄露 41612.7.1 底层连接资源的访问问题 41612.7.2 Spring JDBC数据连接泄露 41712.7.3 事务环境下通过DataSourceUtils获取数据连接 42012.7.4 无事务环境下通过DataSourceUtils获取数据连接 42212.7.5 JdbcTemplate如何做到对连接泄露的免疫 42412.7.6 使用TransactionAwareDataSourceProxy 42512.7.7 其他数据访问技术的等价类 42612.8 小结 426第13章 使用Spring JDBC访问数据库 42813.1 使用Spring JDBC 42813.1.1 JdbcTemplate小试牛刀 42913.1.2 在DAO中使用JdbcTemplate 42913.2 基本的数据操作 43113.2.1 更改数据 43113.2.2 返回数据库的表自增主键值 43413.2.3 批量更改数据 43613.2.4 查询数据 43713.2.5 查询单值数据 44013.2.6 调用存储过程 44213.3 BLOB/CLOB类型数据的操作 44413.3.1 如何获取本地数据连接 44513.3.2 相关的操作接口 44613.3.3 插入LOB类型的数据 44813.3.4 以块数据方式读取LOB数据 45013.3.5 以流数据方式读取LOB数据 45113.4 自增键和行集 45213.4.1 自增键的使用 45213.4.2 如何规划主键方案 45413.4.3 以行集返回数据 45613.5 NamedParameterJdbcTemplate模板类 45613.6 小结 459第14章 整合其他ORM框架 46014.1 Spring整合ORM技术 46014.2 在Spring中使用Hibernate 46214.2.1 配置SessionFactory 46214.2.2 使用HibernateTemplate 46514.2.3 处理LOB类型的数据 46914.2.4 添加Hibernate事件监听器 47014.2.5 使用原生的Hibernate API 47114.2.6 使用注解配置 47214.2.7 事务处理 47414.2.8 延迟加载问题 47514.3 在Spring中使用MyBatis 47614.3.1 配置SqlMapClient 47614.3.2 在Spring中配置MyBatis 47814.3.3 编写MyBatis的DAO 47914.4 DAO层设计 48214.4.1 DAO基类设计 48214.4.2 查询接口方法设计 48414.4.3 分页查询接口设计 48614.5 小结 487第4篇 应用篇第15章 Spring Cache 49015.1 缓存概述 49015.1.1 缓存的概念 49015.1.2 使用Spring Cache 49315.2 掌握Spring Cache抽象 49815.2.1 缓存注解 49815.2.2 缓存管理器 50415.2.3 使用SpEL表达式 50615.2.4 基于XML的Cache声明 50615.2.5 以编程方式初始化缓存 50715.2.6 自定义缓存注解 50915.3 配置Cache存储 50915.3.1 EhCache 51015.3.2 Guava 51015.3.3 HazelCast 51115.3.4 GemFire 51115.3.5 JSR-107 Cache 51115.4 实战经验 51315.5 小结 514第16章 任务调度和异步执行器 51616.1 任务调度概述 51616.2 Quartz快速进阶 51716.2.1 Quartz基础结构 51816.2.2 使用SimpleTrigger 52016.2.3 使用CronTrigger 52216.2.4 使用Calendar 52616.2.5 任务调度信息存储 52716.3 在Spring中使用Quartz 53016.3.1 创建JobDetail 53016.3.2 创建Trigger 53316.3.3 创建Scheduler 53416.4 在Spring中使用JDK Timer 53616.4.1 Timer和TimerTask 53616.4.2 Spring对Java Timer的支持 53916.5 Spring对Java 5.0 Executor的支持 54016.5.1 了解Java 5.0的Executor 54116.5.2 Spring对Executor所提供的抽象 54316.6 实际应用中的任务调度 54416.6.1 如何产生任务 54516.6.2 任务调度对应用程序集群的影响 54716.6.3 任务调度云 54716.6.4 Web应用程序中调度器的启动和关闭问题 54916.7 小结 552第17章 Spring MVC 55317.1 Spring MVC体系概述 55417.1.1 体系结构 55417.1.2 配置DispatcherServlet 55517.1.3 一个简单的实例 56017.2 注解驱动的控制器 56517.2.1 使用@RequestMapping映射请求 56517.2.2 请求处理方法签名 56917.2.3 使用矩阵变量绑定参数 57017.2.4 请求处理方法签名详细说明 57117.2.5 使用HttpMessageConverter<T> 57517.2.6 使用@RestController和AsyncRestTemplate 58417.2.7 处理模型数据 58617.3 处理方法的数据绑定 59117.3.1 数据绑定流程剖析 59217.3.2 数据转换 59217.3.3 数据格式化 59817.3.4 数据校验 60217.4 视图和视图解析器 61117.4.1 认识视图 61117.4.2 认识视图解析器 61217.4.3 JSP和JSTL 61317.4.4 模板视图 61817.4.5 Excel 62117.4.6 PDF 62317.4.7 输出XML 62517.4.8 输出JSON 62617.4.9 使用XmlViewResolver 62617.4.10 使用ResourceBundleViewResolver 62717.4.11 混合使用多种视图技术 62817.5 本地化解析 63017.5.1 本地化的概念 63017.5.2 使用CookieLocaleResolver 63117.5.3 使用SessionLocaleResolver 63217.5.4 使用LocaleChangeInterceptor 63217.6 文件上传 63317.6.1 配置MultipartResolver 63317.6.2 编写控制器和文件上传表单页面 63317.7 WebSocket支持 63417.7.1 使用WebSocket 63417.7.2 WebSocket的限制 63817.8 杂项 63917.8.1 静态资源处理 63917.8.2 装配拦截器 64317.8.3 异常处理 64417.8.4 RequestContextHolder的使用 64617.9 小结 646第18章 实战案例开发 64818.1 论坛案例概述 64818.1.1 论坛整体功能结构 64818.1.2 论坛用例描述 64918.1.3 主要功能流程描述 65118.2 系统设计 65518.2.1 技术框架选择 65518.2.2 采用Maven构建项目 65618.2.3 单元测试类包结构规划 65718.2.4 系统架构图 65818.2.5 PO类设计 65818.2.6 持久层设计 65918.2.7 服务层设计 66018.2.8 Web层设计 66118.2.9 数据库设计 66218.3 开发前的准备 66318.4 持久层开发 66418.4.1 PO类 66418.4.2 DAO基类 66618.4.3 通过扩展基类定义DAO类 67018.4.4 DAO Bean的装配 67218.4.5 使用Hibernate二级缓存 67318.5 对持久层进行测试 67518.5.1 配置Unitils测试环境 67518.5.2 准备测试数据库及测试数据 67618.5.3 编写DAO测试基类 67718.5.4 编写BoardDao测试用例 67818.6 服务层开发 68018.6.1 UserService的开发 68018.6.2 ForumService的开发 68118.6.3 服务类Bean的装配 68318.7 对服务层进行测试 68418.7.1 编写Service测试基类 68518.7.2 编写ForumService测试用例 68518.8 Web层开发 68718.8.1 BaseController的基类 68718.8.2 用户登录和注销 68918.8.3 用户注册 69118.8.4 论坛管理 69218.8.5 论坛普通功能 69418.8.6 分页显示论坛版块的主题帖子 69618.8.7 web.xml配置 70018.8.8 Spring MVC配置 70218.9 对Web层进行测试 70318.9.1 编写Web测试基类 70318.9.2 编写ForumManageController测试用例 70418.10 开发环境部署 70518.11 项目配置实战经验 70818.11.1 “传统的”Web项目属性文件 70818.11.2 如何规划便于部署的Web项目属性文件 70918.11.3 数据源的配置 71018.12 小结 712第5篇 提高篇第19章 Spring OXM 71419.1 认识XML解析技术 71419.1.1 什么是XML 71419.1.2 XML的处理技术 71519.2 XML处理利器:XStream 71719.2.1 XStream概述 71719.2.2 快速入门 71819.2.3 使用XStream别名 72019.2.4 XStream转换器 72119.2.5 XStream注解 72319.2.6 流化对象 72519.2.7 持久化API 72619.2.8 额外功能:处理JSON 72719.3 其他常见的O/X Mapping开源项目 72919.3.1 JAXB 72919.3.2 Castor 73319.3.3 JiBX 73819.3.4 总结比较 74119.4 与Spring OXM整合 74219.4.1 Spring OXM概述 74219.4.2 整合OXM实现者 74419.4.3 如何在Spring中进行配置 74419.4.4 Spring OXM简单实例 74719.5 小结 749第20章 实战型单元测试 75020.1 单元测试概述 75120.1.1 为什么需要单元测试 75120.1.2 单元测试之误解 75220.1.3 单元测试之困境 75420.1.4 单元测试基本概念 75520.2 TestNG快速进阶 75720.2.1 TestNG概述 75720.2.2 TestNG生命周期 75820.2.3 使用TestNG 75820.3 模拟利器Mockito 76320.3.1 模拟测试概述 76320.3.2 创建Mock对象 76320.3.3 设定Mock对象的期望行为及返回值 76420.3.4 验证交互行为 76620.4 测试整合之王Unitils 76720.4.1 Unitils概述 76720.4.2 集成Spring 77020.4.3 集成Hibernate 77320.4.4 集成DbUnit 77420.4.5 自定义扩展模块 77520.5 使用Unitils测试DAO层 77620.5.1 数据库测试的难点 77620.5.2 扩展DbUnit用Excel准备数据 77620.5.3 测试实战 77920.6 使用Unitils测试Service层 78920.7 测试Web层 79420.7.1 对LoginController进行单元测试 79420.7.2 使用Spring Servlet API模拟对象 79520.7.3 使用Spring RestTemplate测试 79720.8 小结 798
评论关闭。