本書是一本經(jīng)典而實用的暢銷Spring 學習指南。
第5 版涵蓋了Spring 5.0 和Spring Boot 2.0 里程碑式的更新。全書分為5 個部分,共19 章。第1 部分(第1~5 章)涵蓋了構建Spring 應用的基礎話題。第2 部分(第6~9章)討論如何將Spring 應用與其他應用進行集成。第3 部分(第10~12 章)探討Spring對反應式編程提供的全新支持。第4 部分(第13~15 章)拆分單體應用模型,介紹SpringCloud 和微服務開發(fā)。第5 部分(第16~19 章)討論如何為應用投入生產(chǎn)環(huán)境做準備以及如何進行部署。
本書既適合剛開始學習Spring Boot 和Spring 框架的Java 開發(fā)人員快速上手,也適合經(jīng)驗豐富的Spring 開發(fā)人員學習Spring 的新特性,尤其適用于企業(yè)級Java 開發(fā)人員。
全球有超過100 000名開發(fā)者使用本書來學習Spring
暢銷經(jīng)典Spring技術圖書,針對Spring 5全面升級
Spring框架能夠讓Java開發(fā)人員的工作更加輕松。Spring 5的新特性通過微服務、反應式開發(fā)進一步提升了生產(chǎn)效率。隨著與Spring Boot的全面集成,我們現(xiàn)在用最少的配置就可以啟動復雜的項目。全新升級的WebFlux框架對反應式應用程序提供了開箱即用的支持。
本書繼續(xù)以眾所周知的清晰風格,介紹了Spring 5的核心特性。你將親自動手,逐步構建出一個安全的、以數(shù)據(jù)庫作為支撐的Web應用。在這個過程中,你還將會探索反應式編程、微服務、服務發(fā)現(xiàn)、RESTful API、部署并掌握專家級的最佳實踐。無論你是Spring的初學者,還是想要升級到Spring 5,本書都不容錯過。
本書包含一下內(nèi)容
·構建反應式應用;
· 使用Spring MVC構建Web應用和RESTful Web服務;
·使用Spring Security保護應用;
· Spring 5新特性。
專家推薦
《Spring實戰(zhàn)(第5版)》進行了全面的升級,兼顧了實戰(zhàn)指南和綜合理論。
——Daniel Vaughan
European Bioinformatics Institute
學習Spring框架的很棒的參考指南。
——Colin Joyce,Cisco
本書包含了你需要掌握的所有關于Spring的知識,并且涵蓋了如何構建云原生應用。
—— David Witherspoon,Parsons
本書堪稱Spring開發(fā)人員的“瑞士軍刀”。
——Riccardo Noviello
Nuvio Software Solutions
克雷格·沃斯(Craig Walls)是Pivotal的首席軟件工程師、暢銷書作者、Spring框架的熱情支持者,經(jīng)常在各種技術會議上發(fā)表演講。
第 1 部分 Spring 基礎
第 1 章 Spring 起步 3
1.1 什么是Spring 4
1.2 初始化Spring 應用 6
1.2.1 使用Spring Tool Suite
初始化Spring 項目 7
1.2.2 檢查Spring 項目的
結(jié)構 10
1.3 編寫Spring 應用 16
1.3.1 處理Web 請求 16
1.3.2 定義視圖 17
1.3.3 測試控制器 18
1.3.4 構建和運行應用 20
1.3.5 了解Spring Boot DevTools 21
1.3.6 回顧一下 23
1.4 俯瞰Spring 風景線 24
1.4.1 Spring 核心框架 24
1.4.2 Spring Boot 25
1.4.3 Spring Data 25
1.4.4 Spring Security 25
1.4.5 Spring Integration 和Spring
Batch 26
1.4.6 Spring Cloud 26
1.5 小結(jié) 26
第 2 章 開發(fā)Web 應用 27
2.1 展現(xiàn)信息 27
2.1.1 構建領域類 28
2.1.2 創(chuàng)建控制器類 30
2.1.3 設計視圖 33
2.2 處理表單提交 37
2.3 校驗表單輸入 43
2.3.1 聲明校驗規(guī)則 43
2.3.2 在表單綁定的時候執(zhí)行
校驗 45
2.3.3 展現(xiàn)校驗錯誤 46
2.4 使用視圖控制器 48
2.5 選擇視圖模板庫 49
2.6 小結(jié) 52
第3 章 使用數(shù)據(jù) 53
3.1 使用JDBC 讀取和寫入
數(shù)據(jù) 53
3.1.1 調(diào)整領域?qū)ο笠赃m應
持久化 55
3.1.2 使用JdbcTemplate 56
3.1.3 定義模式和預加載數(shù)據(jù) 61
3.1.4 插入數(shù)據(jù) 63
3.2 使用Spring Data JPA 持久
化數(shù)據(jù) 72
3.2.1 添加Spring Data JPA 到
項目中 72
3.2.2 將領域?qū)ο髽俗閷嶓w 73
3.2.3 聲明JPA repository 76
3.2.4 自定義JPA repository 77
3.3 小結(jié) 80
第4 章 保護Spring 81
4.1 啟用Spring Security 81
4.2 配置Spring Security 83
4.2.1 基于內(nèi)存的用戶存儲 85
4.2.2 基于JDBC 的用戶存儲 86
4.2.3 以LDAP 作為后端的
用戶存儲 89
4.2.4 自定義用戶認證 92
4.3 保護Web 請求 100
4.3.1 保護請求 100
4.3.2 創(chuàng)建自定義的登錄頁 103
4.3.3 退出 105
4.3.4 防止跨站請求偽造 106
4.4 了解用戶是誰 107
4.5 小結(jié) 109
第5 章 使用配置屬性 111
5.1 細粒度的自動配置 112
5.1.1 理解Spring 的環(huán)境抽象 112
5.1.2 配置數(shù)據(jù)源 114
5.1.3 配置嵌入式服務器 115
5.1.4 配置日志 116
5.1.5 使用特定的屬性值 118
5.2 創(chuàng)建自己的配置屬性 118
5.2.1 定義配置屬性的持有者 120
5.2.2 聲明配置屬性元數(shù)據(jù) 123
5.3 使用profile 進行配置 125
5.3.1 定義特定profile 的屬性 126
5.3.2 激活profile 127
5.3.3 使用profile 條件化地創(chuàng)建
bean 128
5.4 小結(jié) 129
第2部分 Spring 集成
第6 章 創(chuàng)建REST 服務 133
6.1 編寫RESTful 控制器 134
6.1.1 從服務器中檢索數(shù)據(jù) 136
6.1.2 發(fā)送數(shù)據(jù)到服務器端 140
6.1.3 在服務器上更新數(shù)據(jù) 142
6.1.4 刪除服務器上的數(shù)據(jù) 144
6.2 啟用超媒體 145
6.2.1 添加超鏈接 147
6.2.2 創(chuàng)建資源裝配器 149
6.2.3 命名嵌套式的關聯(lián)關系 154
6.3 啟用數(shù)據(jù)后端服務 155
6.3.1 調(diào)整資源路徑和關系
名稱 157
6.3.2 分頁和排序 159
6.3.3 添加自定義的端點 160
6.3.4 為Spring Data 端點添加
自定義的超鏈接 162
6.4 小結(jié) 163
第7 章 消費REST 服務 165
7.1 使用RestTemplate 消費
REST 端點 166
7.1.1 GET 資源 167
7.1.2 PUT 資源 169
7.1.3 DELETE 資源 169
7.1.4 POST 資源 169
7.2 使用Traverson 導航
REST API 170
7.3 小結(jié) 172
第8 章 發(fā)送異步消息 173
8.1 使用JMS 發(fā)送消息 174
8.1.1 搭建JMS 環(huán)境 174
8.1.2 使用JmsTemplate 發(fā)送
消息 176
8.1.3 接收JMS 消息 183
8.2 使用RabbitMQ 和
AMQP 186
8.2.1 添加RabbitMQ 到
Spring 中 188
8.2.2 通過RabbitTemplate 發(fā)送
消息 189
8.2.3 接收來自RabbitMQ 的
消息 192
8.3 使用Kafka 的消息 196
8.3.1 為Spring 搭建支持Kafka
消息的環(huán)境 197
8.3.2 通過KafkaTemplate 發(fā)送
消息 198
8.3.3 編寫Kafka 監(jiān)聽器 200
8.4 小結(jié) 201
第9 章 Spring 集成 203
9.1 聲明一個簡單的
集成流 204
9.1.1 使用XML 定義集成流 205
9.1.2 使用Java 配置集成流 207
9.1.3 使用Spring Integration 的
DSL 配置 209
9.2 Spring Integration 功能
概覽 210
9.2.1 消息通道 211
9.2.2 過濾器 212
9.2.3 轉(zhuǎn)換器 213
9.2.4 路由器 214
9.2.5 切分器 216
9.2.6 服務激活器 218
9.2.7 網(wǎng)關 220
9.2.8 通道適配器 221
9.2.9 端點模塊 223
9.3 創(chuàng)建Email 集成流 224
9.4 小結(jié) 229
第3部分 反應式Spring
第 10 章 理解反應式編程 233
10.1 反應式編程概覽 234
10.2 初識Reactor 237
10.2.1 繪制反應式流圖 238
10.2.2 添加Reactor 依賴 239
10.3 使用常見的反應式
操作 240
10.3.1 創(chuàng)建反應式類型 240
10.3.2 組合反應式類型 244
10.3.3 轉(zhuǎn)換和過濾反應式流 248
10.3.4 在反應式類型上執(zhí)行邏輯
操作 258
10.4 小結(jié) 259
第 11 章 開發(fā)反應式API 261
11.1 使用Spring WebFlux 261
11.1.1 Spring WebFlux 簡介 262
11.1.2 編寫反應式控制器 264
11.2 定義函數(shù)式請求處
理器 268
11.3 測試反應式控制器 271
11.3.1 測試GET 請求 271
11.3.2 測試POST 請求 274
11.3.3 使用實時服務器進行
測試 275
11.4 反應式消費
REST API 276
11.4.1 獲取資源 277
11.4.2 發(fā)送資源 279
11.4.3 刪除資源 280
11.4.4 處理錯誤 280
11.4.5 交換請求 282
11.5 保護反應式Web API 283
11.5.1 配置反應式Web 應用的
安全性 284
11.5.2 配置反應式的用戶詳情
服務 285
11.6 小結(jié) 287
第 12 章 反應式持久化數(shù)據(jù) 289
12.1 理解Spring Data 的
反應式概況 290
12.1.1 Spring Data 反應式本
質(zhì)論 290
12.1.2 反應式和非反應式類型
之間的轉(zhuǎn)換 291
12.1.3 開發(fā)反應式repository 292
12.2 使用反應式的
Cassandra repository 293
12.2.1 啟用Spring Data
Cassandra 293
12.2.2 理解Cassandra 的數(shù)據(jù)
模型 296
12.2.3 將領域?qū)ο笥成錇镃assandra
持久化 296
12.2.4 編寫反應式
Cassandra repository 301
12.3 編寫反應式的
MongoDB repository 304
12.3.1 啟用Spring Data
MongoDB 304
12.3.2 將領域?qū)ο笥成錇?文檔 306
12.3.3 編寫反應式的MongoDB
repository 接口 309
12.4 小結(jié) 312
第4 部分 云原生Spring
第 13 章 注冊和發(fā)現(xiàn)服務 315
13.1 思考微服務 316
13.2 搭建服務注冊中心 318
13.2.1 配置Eureka 321
13.2.2 擴展Eureka 324
13.3 注冊和發(fā)現(xiàn)服務 325
13.3.1 配置Eureka 客戶端
屬性 326
13.3.2 消費服務 328
13.4 小結(jié) 332
第 14 章 管理配置 333
14.1 共享配置 334
14.2 運行配置服務器 335
14.2.1 啟用配置服務器 336
14.2.2 填充配置倉庫 339
14.3 消費共享配置 341
14.4 提供特定應用和profile 的
屬性 343
14.4.1 提供特定應用的屬性 343
14.4.2 提供來自profile 的
屬性 344
14.5 保持配置屬性的
私密性 346
14.5.1 在Git 中加密屬性 346
14.5.2 在Vault 中存儲私密
信息 349
14.6 在運行時刷新配置
屬性 353
14.6.1 手動刷新配置屬性 354
14.6.2 自動刷新配置屬性 356
14.7 小結(jié) 363
第 15 章 處理失敗和延遲 365
15.1 理解斷路器模式 365
15.2 聲明斷路器 367
15.2.1 緩解延遲 369
15.2.2 管理斷路器的閾值 371
15.3 監(jiān)控失敗 372
15.3.1 Hystrix dashboard
簡介 373
15.3.2 理解Hystrix 的線程
模型 375
15.4 聚合多個Hystrix 流 377
15.5 小結(jié) 378
第5 部分 部署Spring
第 16 章 使用Spring Boot
Actuator 381
16.1 Actuator 概覽 382
16.1.1 配置Actuator 的基礎
路徑 383
16.1.2 啟用和禁用Actuator
端點 383
16.2 消費Actuator 端點 384
16.2.1 獲取應用的基礎信息 385
16.2.2 查看配置細節(jié) 388
16.2.3 查看應用的活動 396
16.2.4 獲取應用的指標 398
16.3 自定義Actuator 401
16.3.1 為“/info”端點提供信息 401
16.3.2 實現(xiàn)自定義的健康
指示器 405
16.3.3 注冊自定義的指標 407
16.3.4 創(chuàng)建自定義的端點 408
16.4 保護Actuator 411
16.5 小結(jié) 413
第 17 章 管理Spring 415
17.1 使用Spring Boot
Admin 415
17.1.1 創(chuàng)建Admin 服務器 416
17.1.2 注冊Admin 客戶端 418
17.2 探索Admin 服務器 421
17.2.1 查看應用基本的健康狀況
和信息 421
17.2.2 觀察核心指標 423
17.2.3 探查環(huán)境屬性 424
17.2.4 查看和設置日志
級別 424
17.2.5 監(jiān)控線程 425
17.2.6 跟蹤HTTP 請求 426
17.3 保護Admin 服務器 428
17.3.1 為Admin 服務器啟用登錄
功能 428
17.3.2 為Actuator 啟用認證 429
17.4 小結(jié) 429
第 18 章 使用JMX 監(jiān)控
Spring 431
18.1 使用Actuator MBean 431
18.2 創(chuàng)建自己的MBean 434
18.3 發(fā)送通知 436
18.4 小結(jié) 437
第 19 章 部署Spring 439
19.1 權衡各種部署方案 440
19.2 構建和部署WAR
文件 441
19.3 推送JAR 文件到Cloud
Foundry 上 443
19.4 在Docker 容器中運行
Spring Boot 445
19.5 以終為始 449
19.6 小結(jié) 449
附錄 初始化Spring 應用 451
A.1 使用Spring Tool Suite
初始化項目 451
A.2 使用IntelliJ IDEA 初始化
項目 454
A.3 使用NetBeans 初始化
項目 457
A.4 在start.spring.io 中初始化
項目 459
A.5 使用命令行初始化
項目 462
A.5.1 curl 和Initializr API 462
A.5.2 Spring Boot 命令行
接口 464
A.6 使用元框架創(chuàng)建Spring
應用 465
A.7 構建和運行項目 465