Home | 简体中文 | 繁体中文 | 杂文 | Github | 知乎专栏 | Facebook | Linkedin | Youtube | 打赏(Donations) | About
知乎专栏

Netkiller Java 手札(2024版)

Java, Servlet, JavaBean, Struts, Spring ...

Mr. Neo Chan, 陈景峯(BG7NYT)



中国广东省深圳市望海路半岛城邦三期
518067
+86 13113668890


文档始创于 2015-11-10

电子书最近一次更新于 2024-02-26 09:55:29

版权声明

转载请与作者联系,转载时请务必标明文章原始出处和作者信息及本声明。

http://www.netkiller.cn
http://netkiller.github.io
http://netkiller.sourceforge.net
微信公众号: netkiller
微信:13113668890 请注明“读者”
QQ:13721218 请注明“读者”
QQ群:128659835 请注明“读者”
知乎专栏

2017-11

关于《Netkiller Java 手札》

作者2002年开始在项目中使用Java,各种原因没有留下Java文档,2015因工作需要重新拾起Java并整理本文档。

本电子书重点内容是Spring boot, Spring cloud, Spring data, Spring security


致读者

Netkiller 系列手札 已经被 Github 收录,并备份保存在北极地下250米深的代码库中,备份会保留1000年。

Preserving open source software for future generations

The world is powered by open source software. It is a hidden cornerstone of modern civilization, and the shared heritage of all humanity.

The GitHub Arctic Code Vault is a data repository preserved in the Arctic World Archive (AWA), a very-long-term archival facility 250 meters deep in the permafrost of an Arctic mountain.

We are collaborating with the Bodleian Library in Oxford, the Bibliotheca Alexandrina in Egypt, and Stanford Libraries in California to store copies of 17,000 of GitHub’s most popular and most-depended-upon projects—open source’s “greatest hits”—in their archives, in museum-quality cases, to preserve them for future generations.

https://archiveprogram.github.com/arctic-vault/

目录

1. 自述
1.1. 写给读者
1.2. 作者简介
1.3. 如何获得文档
1.4. 打赏(Donations)
1.5. 联系方式
I. Java 21
1. JVM
1.1. Almalinux / RockyLinux
1.2. CentOS 8 Java 14
1.3. Java 版本切换
1.4. 安装 Java 6
1.4.1. HeapDumpOnOutOfMemoryError
1.5. java-1.8.0-openjdk
1.6. docker 环境
1.7. java - Launches a Java application.
1.7.1. java 9~11
1.7.2. -verbose:class 显示载入jar文件
1.7.3. java.io.tmpdir
1.7.4. 显示版本号
1.7.5. 列出java模块
1.8. Java 相关命令
1.8.1. jps
1.8.2. jar
1.8.3. jdeps - Java class dependency analyzer.
1.8.4. JShell
1.8.5. jlink
2. exec 运行shell
2.1. System
2.1.1. user.dir
2.1.2. java.io.tmpdir
2.1.3. 打印当前 Java 文件的默认编码
2.1.4. 自定义
2.1.5. System.in 标准输入(Stdin)
2.1.6. ANSI Color
3. 数据类型
3.1. var 本地变量类型推断
3.2. Integer 整形
3.2.1. 字符串转整数
3.2.2. 进制转换
3.2.3. 前面补零
3.2.4. NumberFormat 数字格式化
3.3. String 字符串
3.3.1. 查找字符重现的位置
3.3.2. 行数统计
3.3.3. 复制字符串
3.3.4. 随机字符串
3.3.5. 字符串替换处理
3.3.6. substring
3.3.7. string to timestamp
3.3.8. String.strip
3.3.9. 文本块
3.3.10. 分割字符串
3.3.11. 通过 stream() 匹配一组字符串
3.4. 类型转换
3.4.1. Long to String
3.5. Date 日期时间
3.5.1. DateTimeFormatter 格式化日期和时间
3.5.2. SimpleDateFormat 格式化日期和时间
3.5.3. Timestamp
3.5.4. TimeZone
3.5.5. String to Date
3.5.6. 比较两个日期与时间
3.5.7. Calendar
3.5.8. getToday
3.5.9. Yesterday
3.5.10. ISO 8601
3.5.11. LocalDateTime
3.5.12. ZonedDateTime
3.6. Array 数组
3.6.1. 字符串转数组
3.6.2. for each
3.6.3. Array to String
3.6.4. 数据转字符串
3.7. float 浮点
3.8. double 双精度浮点
3.8.1. String to double
3.8.2. 百分数转Double
3.8.3. Double转百分数
3.9. BigDecimal
3.9.1. Convert BigDecimal Object to double value
3.9.2. 去除末尾多余的0
3.9.3. 禁用科学计数法
3.9.4. 移动小数点位置
3.10. StringBuffer
3.11. enum
3.12. byte 类型
3.12.1. string2byte
3.12.2. byte[] to String
3.12.3. BigInteger2byte
3.12.4. int to byte array
3.12.5. byte array to int
3.12.6. byte2char
3.12.7. longToByte64
3.12.8. byte64ToLong
3.12.9. short2byte
3.12.10. byte8ToDouble
3.12.11. byte4ToFloat
3.12.12. 无符号 byte
3.12.13. byte to hex
3.12.14. byte[] to hex
3.12.15. 连接两个 byte[]
3.12.16. List<Byte> to byte[]
3.13. 布尔型 Boolean
4. 流程控制
4.1. Switch
4.1.1. yield
5. 面向对象
5.1. 可变参数
5.2. 泛型
5.2.1.
5.2.2. 数组泛型方法
5.2.3. 静态方法
5.2.4. 可变参数的泛型方法
5.2.5. 返回泛型值
5.2.6. 泛型类
5.3. record
5.4. Callback 回调
5.5. 密封类
5.5.1.
6. 异常处理
6.1. 抛出异常
6.2. try-with-resources
6.3. SneakyThrows
6.3.1. 处理所有异常 Exception
6.3.2. 处理特定异常
6.3.3. 抛出异常
7. Java 线程
7.1. 多线程 Lambda 表达式
7.2. 实现异步执行
7.3. 继承 Thread 类实现多线程
7.3.1. 设置线程名称
7.4. 实现 Runnable 接口
7.5. 线程同步
7.6. ThreadLocal
7.7. ThreadLocalMap
7.8. InheritableThreadLocal
7.9. 守护线程
7.10. 线程等待与线程通知
7.10.1. 通知所有线程
7.10.2. 携带消息
II. JDK Development Kit
8. 数据结构
8.1. Collection 接口
8.2. List
8.2.1. 静态 List
8.2.2. List.of()
8.2.3. List.copyOf()
8.2.4. String[] to List
8.2.5. Stream.toList() 方法
8.2.6. containsAll
8.2.7. stream().allMatch()
8.2.8. 随机 List
8.2.9. getFirst() / getLast()
8.2.10. List 转 Array
8.3. ArrayList
8.3.1. 初始化
8.3.2. 判断元素是否存在
8.3.3. 循环打印
8.3.4. ArrayList to Array
8.3.5. ArrayList to String
8.3.6. Array to List
8.3.7. List to Array
8.3.8. ArrayList forEach
8.3.9. ArrayList stream()
8.3.10. ArrarList 转换为 string[]
8.3.11. string 转换为 ArrayList
8.3.12. ArrayList 转换为 string
8.3.13. string[] 转换为 ArrarList
8.3.14. 合并 List<byte[]> ArrayList<byte[]>
8.4. LinkedList
8.5. Set 转为 List
8.5.1. Set.of()
8.5.2. Set to Array
8.6. Map
8.6.1. 初始化
8.6.2. HashMap
8.6.3. LinkedHashMap
8.6.4. 遍历数据
8.6.5. 迭代器
8.6.6. Map forEach
8.6.7. 随机取值
8.7. Iterator 迭代器
8.7.1. List 迭代
8.7.2. 处理剩余结果
8.7.3. Map 迭代
8.7.4. Iterator 与 List 的区别
8.7.5. remove() 删除操作
8.7.6. Iterable 转 List
8.8. ListIterator
8.9. Queue
8.9.1. 阻塞队列
8.9.2. Deque 双端队列
8.9.3. 数据转换
8.10. Optional
8.10.1. of() 为非null的值创建一个Optional。
8.10.2. ofNullable() 为指定的值创建一个Optional,如果指定的值为null,则返回一个空的Optional。
8.10.3. isPresent 如果值存在返回true,否则返回false。ifEmpty() null 返回 true 否则返回 false
8.10.4. ifPresent() 如果Optional实例有值执行 lambda 表达式
8.10.5. get() 返回值
8.10.6. orElse 如果有值则将其返回,否则返回指定的其它值。
8.10.7. orElseGet与orElse方法类似,区别在于得到的默认值从 Supplier 返回。
8.10.8. orElseThrow 如果有值则将其返回,否则抛出supplier接口创建的异常
8.10.9. map() 方法用来对Optional实例的值执行一系列操作
8.10.10. flatMap()
8.10.11. filter() 通过传入限定条件过滤Optional值
8.10.12. stream()
8.10.13. or()
8.10.14. example
9. 正则表达式
9.1. 正则查找
9.2. 正则替换
9.3. 字符串分割
10. Java 并发编程
10.1. TimeUnit
10.2. AtomicInteger / AtomicLong / AtomicBoolean
10.3. AtomicReference
10.4. ReentrantLock 锁
10.5. 线程安全的 HashMap(ConcurrentHashMap)
10.5.1. 设置键与值
10.6. ArrayBlockingQueue
10.7. Future
10.7.1. Future + Stream 管理一组线程
10.8. FutureTask
10.9. CompletableFuture
10.9.1. runAsync 创建没有返回值的异步任务
10.9.2. supplyAsync 创建带有返回值的异步任务。
10.9.3. 创建 CompletableFuture 实例,并且其他线程中使用
10.9.4. 获取结果
10.9.5. thenRun / thenRunAsync
10.9.6. thenAccept / thenAcceptAsync
10.9.7. thenApply / thenApplyAsync
10.9.8. runAsync / thenAccept / thenApply 区别
10.9.9. whenComplete 任务完成时执行,并且返回结果和异常
10.9.10. 超时处理
10.9.11. 按顺序执行
10.9.12. thenCombine、thenAcceptBoth 和runAfterBoth
10.9.13. applyToEither、acceptEither和runAfterEither
10.9.14. allOf / anyOf
10.9.15. 并行执行 CompletableFuture
10.9.16. 通知完成任务
10.9.17. 异常处理
10.9.18. CompletableFuture 实现 Pipeline 流水线
10.10. java 线程池
10.10.1. newCachedThreadPool
10.10.2. 固定线程池(newFixedThreadPool)
10.10.3. Executors.newScheduledThreadPool
10.10.4. SingleThreadExecutor
10.10.5. ExecutorService 正确关闭方法
10.10.6. ForkJoinPool / ForkJoinTask
10.11. Flow
10.11.1. 自定义 Publisher / Subscriber
10.11.2. SubmissionPublisher
10.11.3. Flow.Processor
10.12. Java 协程
11. Stream
11.1. Stream.of
11.2. Stream.ofNullable
11.3. filter
11.4. map
11.5. limit/skip
11.6. sorted
11.7. distinct
11.8. forEach
11.9. count
11.10. 流转列表
11.11. collect
11.11.1. Collectors.toList() 列表转字符串
11.11.2. Collectors.joining() 连接字符串
11.11.3. 转 Set Collectors.toSet()
11.11.4. Collectors.teeing()
11.12. takeWhile 和 dropWhile
11.13. 合并 Stream
11.14. mapToObj
11.15. 混合使用的例子
11.15.1. List to Stream
11.16. 流复用 streamSupplier
11.17. Parallel Streams(并行流)
11.18. IntStream / LongStream / DoubleStream
12. 函数式编程
12.1. Supplier 供应型的接口
12.1.1. Supplier 作为方法参数使用
12.2. IntSupplier / LongSupplier / DoubleSupplier / BooleanSupplier
12.3. Consumer 消费型的接口
12.4. IntConsumer
12.5. BiConsumer
12.6. BiFunction
12.7. Predicate 判断型的接口
12.8. Supplier / Consumer / Predicate 应用场景
13. Util
13.1. Properties 处理 *.properties 文件
13.1.1. 打开 properties 文件
13.1.2. propertyNames()
13.1.3. keySet()
13.1.4. entrySet()
13.1.5. 方法中返回 Properties
13.1.6.
13.1.7. getResourceAsStream()
13.1.8. store
13.1.9. 实现国际化
13.2. Logging
13.2.1. console
13.3. BASE64
13.4. Locale 国际化
13.5. ResourceBundle
13.6. Scanner
13.7. UUID
13.8. Arrays.equals 判断两个数组是否相等
13.9. Random 随机字符串
13.9.1. 取 0-n 范围内随机数
13.9.2. 指定随机数范围
13.10. CRC32
13.11. Timer / TimerTask 实现周期性重复执行
14. 时间
14.1. LocalDate
14.2. Instant
14.3. Period :基于日期值
14.4. Duration:基于时间值
14.4.1. 设置指定单位的持续时间
14.4.2. 获取指定单位的持续时间
14.4.3. 获取两个时间点之间差值的持续时间
14.4.4. 获取毫秒
15. IO
15.1. 取出文件名中的扩展名
15.1.1. getAbsolutePath() 获取绝对路径
15.1.2. 创建目录 mkdir()
15.2. 临时文件
15.3. FileWriter 文本写入文件
15.4. BufferedWriter
15.5. inputStream.transferTo()
15.6. InputStreamReader
15.7. 获得 Resource 下文件路径
15.8. PrintWriter
15.9. OutputStreamWriter
15.10. FileOutputStream
15.11. FileInputStream
15.12. Scanner
15.13. 二进制文件
15.13.1. 理解二进制文件
15.13.2. byte 类型
15.13.3. boolean 布尔型
15.13.4. Long 型
15.13.5. char 类型
15.13.6. UTF 字符串
15.13.7. Short 类型
15.13.8. float 单精度浮点类型
15.13.9. double 数据类型
15.13.10. 二进制文件操作演示
16. Network
16.1. URL
16.2. 获取IP地址何机器名
17. JDBC
17.1. 安装 JDBC 包
17.2. MySQL
17.3. Oracle
17.3.1. SID
17.3.2. SERVICE_NAME
17.3.3. TNS
17.3.4. Oracle RAC Cluster
17.3.5. Oracle JDBC Demo
17.4. FAQ
17.4.1. java.sql.SQLRecoverableException: IO Error: The Network Adapter could not establish the connection
17.4.2. Exception in thread "main" java.lang.ClassNotFoundException: oracle.jdbc.driver.OracleDriver
18. Reflection 反射
18.1. 获得所有变量
18.2. 批量赋值
18.3. 方法操作
18.3.1. 获得所有方法
18.3.2. set/get 方法
18.3.3. static 方法调用
18.4. 完成的例子
19. java.security
19.1. 列出 Java 支持的数字摘要算法
19.2. 计算文件的 MD5,SHA 等 HASH 值
20. javax
20.1. java 脚本引擎
20.1.1. Maven
20.1.2. Helloworld
20.1.3. 运行脚本文件
20.1.4. 变量传递
20.1.5. 全局变量与局部变量定义
20.1.6. 调用脚本中的函数或方法
20.1.7. 脚本编译
20.1.8. jjs - Invokes the Nashorn engine.
20.2. Crypto
20.2.1. MD5
20.2.2. AES
20.2.3. AES/CBC/PKCS5PADDING
20.2.4. DES
III. Build Tools
21. Apache Ant
21.1. 安装 ant
21.1.1. 1.8
21.1.2. 1.10.1
21.2. ANT
21.2.1. ant.project.name
21.2.2. 定义
21.3. Project
21.3.1. property
21.3.2. ant
21.3.3. environment
21.4. path
21.5. copy
21.6. javac
21.7. condition
21.8. exec
21.8.1. sshexec
21.9. if
21.10. macrodef
21.10.1. Git
21.10.2. Rsync
21.10.3. SSH
21.10.4. maven
21.11. Javascript
21.12. mail
21.13. basename
21.14. 创建文件
21.15. FAQ
21.15.1. warning: 'includeantruntime' was not set, defaulting to build.sysclasspath=last; set to false for repeatable builds
21.15.2. 调试 exec
22. Apache Ivy
22.1. Ivy Install
22.1.1. source code
22.1.2. apt-get
22.2. Test example
23. Apache Maven
23.1. 安装 Maven
23.1.1. CentOS 8 安装 Maven
23.1.2. Ubuntu
23.1.3. 一键安装
23.1.4. apache-maven-3.8.2
23.1.5. Nexus Repository OSS
23.1.6. mvnd
23.2. Maven 命令
23.2.1. 切换 JAVA 版本
23.2.2. 参数
23.2.3. -s 指定 settings.xml 文件
23.2.4. 多线程
23.2.5. help
23.2.6. archetype:create
23.2.7. clean
23.2.8. compile
23.2.9. 编译测试代码
23.2.10. test
23.2.11. package
23.2.12. install
23.2.13. war
23.2.14. exec
23.2.15. dependency
23.2.16. jar
23.2.17. 构建装配Maven Assembly
23.2.18. 加密密码
23.2.19. help:describe
23.3. settings.xml 配置
23.3.1. Maven 仓库
23.3.2. 镜像配置
23.4. pom.xml
23.4.1. properties
23.4.2. 常用的POM属性
23.4.3. repositories 仓库配置
23.4.4. dependencies
23.4.5. dependencyManagement
23.4.6. build
23.4.7. plugins
23.5. Maven Module
23.5.1. Parent
23.5.2. 公共项目 common
23.5.3. 常规项目
23.5.4. 现在测试效果
23.6. 依赖管理
23.6.1. 创建依赖模块
23.6.2. 引用依赖管理
23.7. plugins
23.7.1. maven-compiler-plugin
23.7.2. maven-war-plugin
23.7.3. maven-antrun-plugin
23.7.4. maven-install-plugin
23.7.5. maven-surefire-plugin
23.7.6. maven-deploy-plugin
23.7.7. maven-jar-plugin
23.7.8. maven-dependency-plugin
23.7.9. spring-boot-maven-plugin
23.7.10. tomcat8-maven-plugin
23.7.11. docker-maven-plugin
23.8. 应用案例
23.8.1. 并行开发解决不同环境包引用
24. Gradle 5
24.1. 安装 Gradle
24.1.1. CentOS
24.1.2. Mac
24.1.3. Artifactory 本地仓库
24.2. Example
24.3. gradle 命令
24.3.1. tasks 列出任务
24.4. build.gradle
24.4.1. repositories
24.4.2. dependencies
24.4.3. jar
24.4.4. Task
24.5. gradle.properties
24.5.1. 列出 properties
24.5.2. 自定义 gradle.properties
24.5.3. ext
24.5.4. System.properties
25. JitPack - Easy to use package repository for Git
IV. Spring Boot
26. Spring Boot Quick start
26.1. 创建项目
26.2. pom.xml
26.3. Controller
26.4. Springboot with Maven
26.4.1. resource
26.4.2. Maven run
26.4.3. Spring Boot maven 插件 build-image
26.4.4. 生成项目信息
27. Spring 开发环境
27.1. Java 开发环境
27.2. 安装 Spring Tool Suite
27.3. Dashboard
27.4. Spring Initializr - Bootstrap your application
28. SpringApplication
28.1. 运行 Spring boot 项目
28.1.1. Linux systemd
28.1.2. 传统 init.d 脚本
28.1.3. 编译用于Tomcat的 War
28.2. @SpringBootApplication
28.2.1. 排除 @EnableAutoConfiguration 加载项
28.3. 获取 Resources 目录中的静态文件
28.4. @EnableAutoConfiguration
28.5. @ComponentScan
28.6. @EntityScan 实体扫描
28.7. @EnableJpaRepositories
28.8. 启动和销毁
28.9. 打印环境变量
28.10. CharacterEncodingFilter
28.11. 隐藏 Banner
28.12. 实体与仓库扫描
28.13. 列出 Beans
28.14. Tomcat 端口
28.15. 配置项设定
28.16. spring.profiles.active
28.17. @Profile("dev") / @ActiveProfiles("dev")
28.18. 设置默认时区
29. 如何优雅停止 Springboot 运行
29.1. 准备工作
29.2. kill 命令演示
29.3. 容器中如何优雅关闭 Springboot
29.4. 写入PID文件
30. Properties 配置文件
30.1. application.properties 配置文件
30.1.1. application.properties 参考
30.1.2. 启动指定参数
30.1.3. 加载排除
30.1.4. PID FILE
30.1.5. banner 关闭
30.1.6. server
30.1.7. logging
30.1.8. 内嵌 tomcat server
30.1.9. servlet
30.1.10. JSON 输出与日期格式化
30.1.11. SMTP 相关配置
30.1.12. Redis
30.1.13. MongoDB
30.1.14. MySQL
30.1.15. Oracle
30.1.16. default_schema
30.1.17. datasource
30.1.18. velocity
30.1.19. Security 相关配置
30.1.20. MVC 配置
30.1.21. Kafka 相关配置
30.2. Properties 文件
30.2.1. @Value 注解
30.2.2. @EnableConfigurationProperties 引用自定义 *.properties 配置文件
30.2.3. @PropertySource 注解载入 properties 文件
30.3. Environment 读取配置文件
30.4. 手工载入 *.properties 文件
30.5. 命令行注入配置项
30.5.1. spring.profiles.active 参数切换配置文件
30.5.2. SpringApplicationBuilder.properties() 方法添加配置项
30.5.3. 禁用命令行注入环境变量
30.6.
30.7. PropertyResolver 获取配置
30.8. 参数引用
30.9. 默认值
30.10. 产生随机数
30.10.1. 随机数
30.11. 多行字符串
30.12. 注入多值属性 arrays, list, set
30.13. List 列表类型
30.14. Map类型
30.15. Binder
30.16. 加密 application.properties 中的敏感内容
31. Spring boot with Logging
31.1. 配置日志文件
31.1.1. 日志输出级别
31.1.2. Spring boot 2.1 以后的版本不打印 Mapped 日志问题
31.1.3. 禁止控制台输出日志
31.1.4. 定制日志格式
31.1.5. 彩色输出
31.2. 打印日志
31.2.1. lombok
31.3. logback 配置详解
31.3.1. 标准输出
31.3.2. 禁止 logback 日志输出
31.3.3. 指定Class过滤日志
31.3.4. configuration 属性配置
31.3.5. contextName 设置上下文名称
31.3.6. property 设置变量
31.3.7. encoder 日志格式设置
31.3.8. RollingFileAppender
31.3.9. 日志过滤
31.3.10. 标准输出
31.3.11. MDC
31.3.12. 日志写入 MongoDB
31.3.13. 日志发送给 logstash
31.3.14. fluentd
31.3.15. Loki4j Logback
31.4. Log4j2 + Gelf + Logstash
31.4.1. Maven 配置
31.4.2. log4j2.xml 配置
31.4.3. Java 测试代码
31.4.4. Logstash 配置
31.4.5. 测试结果
31.4.6. Log4j2 更多技巧
31.5. 日志报警
31.5.1. Logstash 配置
31.5.2. 监控 SpringBootApplication 的启动和退出
31.6. Spring boot with ELK(Elasticsearch + Logstash + Kibana)
31.6.1. TCP 方案
31.6.2. Redis 方案
31.6.3. Kafka 方案
31.6.4. Other
32. Spring boot with Undertow
32.1. Maven 依赖
32.2. Application
32.3. 相关配置
33. Spring boot with Jetty
34. Spring boot with HTTP2 SSL
34.1. 生成自签名证书
34.2. application.properties 配置文件
34.3. 启动 Spring boot
34.4. restTemplate 调用实例
34.5. HTTP2
35. Spring boot with MongoDB
35.1. Maven
35.2. Application
35.3. MongoTemplate
35.4. Repository
36. Spring boot with MySQL
36.1. Maven
36.2. Resource
36.3. Application
36.4. JdbcTemplate
36.5. CrudRepository
37. Spring boot with Oracle
37.1. Maven
37.2. application.properties
37.3. Application
37.4. CrudRepository
37.5. JdbcTemplate
37.6. Controller
38. Spring boot with PostgreSQL
38.1. pom.xml
38.2. application.properties
38.3. Application
38.4. CrudRepository
38.5. JdbcTemplate
38.6. Controller
38.7. Test
39. Spring boot with Elasticsearch
39.1. Maven
39.2. Application
39.3. application.properties
39.4. Domain
39.5. ElasticsearchRepository
40. Spring boot with Elasticsearch TransportClient
40.1. Maven
40.2. Application
40.3. application.properties
40.4. ElasticsearchConfiguration
40.5. RestController
41. Spring boot with Apache Hive
41.1. Maven
41.2. application.properties
41.3. Configuration
41.4. CURD 操作实例
42. Spring boot with Phoenix
42.1. Maven
42.2. application.properties
42.3. Configuration
43. Spring boot with Datasource
43.1. Master / Slave 主从数据库数据源配置
43.1.1. application.properties
43.1.2. 配置主从数据源
43.1.3. 选择数据源
43.2. 多数据源配置
43.3. JPA 多数据源
44. 连接池配置
44.1. org.apache.tomcat.jdbc.pool.DataSource
44.2. druid
44.2.1. 加密数据库密码
44.3. c3p0 - JDBC3 Connection and Statement Pooling
44.4. dbcp2
44.5. bonecp
44.6. HikariPool
45. Spring boot with Queue
45.1. Spring boot with RabbitMQ(AMQP)
45.1.1. maven
45.1.2. RabbitMQConfig
45.1.3. 生产者
45.1.4. 消费者
45.2. Spring boot with Apache Kafka
45.2.1. 安装 kafka
45.2.2. maven
45.2.3. Spring boot Application
45.2.4. EnableKafka
45.2.5. KafkaListener
45.2.6. 测试
45.2.7. 完整的发布订阅实例
45.2.8. Spring cloud with Kafka
46. Spring boot with Scheduling
46.1. Application.java
46.2. 配置
46.3. Component
46.4. 查看日志
46.5. 计划任务控制开关
46.6. @Scheduled 详解
46.6.1. 每3秒钟一运行一次
46.6.2. 凌晨23点运行
46.7. Timer 例子
46.8. ScheduledExecutorService 例子
47. Spring boot with Swagger
47.1. Swagger3
47.2. Swagger2
47.2.1. Maven 文件
47.2.2. SpringApplication
47.2.3. EnableSwagger2
47.2.4. RestController
47.3. @Api()
47.4. @ApiOperation()
47.5. @ApiResponses
47.6. @ApiModel 实体类
47.7. Spring boot with knife4j
47.7.1. maven
47.7.2. Knife4jConfiguration
47.7.3. application.properties
48. Spring boot with lombok
48.1. @Builder
48.2. @Slf4j 注解
49. Spring boot with Container
49.1. Spring boot with Docker
49.1.1. 通过 Docker 命令构建镜像
49.1.2. 通过 Maven 构建 Docker 镜像
49.1.3. [ERROR] No plugin found for prefix 'dockerfile' in the current project and in the plugin groups [org.apache.maven.plugins, org.codehaus.mojo] available from the repositories [local (/Users/neo/.m2/repository), central (https://repo.maven.apache.org/maven2)] -> [Help 1]
49.1.4. curl: (35) LibreSSL SSL_connect: SSL_ERROR_SYSCALL in connection to localhost:8888
49.2. Spring boot with Docker stack
49.2.1. 编译 Docker 镜像
49.2.2.
49.3. Spring boot with Kubernetes
49.3.1. Kubernetes 编排脚本
49.3.2. 部署镜像
50. Spring boot with command line
50.1. Maven
50.2. CommandLineRunner 例子
50.3. ApplicationRunner 例子
51. Spring Boot Actuator
51.1. Maven 依赖
51.2. 与 Spring Boot Actuator 有关的配置
51.2.1. 禁用HTTP端点
51.2.2. 安全配置
51.2.3. 修改 actuator 地址
51.2.4. 关机
51.3. actuator 接口
51.4. 健康状态
51.4.1. 健康状态
51.5. info 配置信息
51.6. beans 信息
51.7. caches
51.8. conditions
51.9. configprops 配置文件
51.10. env 环境变量
51.11. logfile 日志
51.12. threaddump 线程信息
51.13. 计划任务
51.14. metrics
51.15. 控制器映射 URL
51.16. 自定义监控指标
52. SpringBootTest
52.1. Maven 依赖
52.2. 测试类
52.2.1. Junit基本注解介绍
52.3.
52.3.1. Assert.assertEquals 判断相等
52.3.2. Assert.assertTrue
52.4. JPA 测试
52.5. TestRestTemplate
52.6. Controller单元测试
52.7. WebTestClient
53. Spring boot with Aop
53.1. Aspect
53.1.1. Maven
53.1.2. Pojo 类
53.1.3. Service 类
53.1.4. Aspect 类
53.1.5. 控制器
53.1.6. Application
53.1.7. 测试
54. Spring boot with starter
54.1. 实现 starter
54.1.1. Maven pom.xml 依赖包
54.1.2. 配置文件处理
54.1.3. 自动配置文件
54.1.4. 启用 starter 的自定义注解
54.2. 引用 starter
54.2.1. Maven pom.xml 引入依赖
54.2.2. 通过注解配置 starter
54.2.3. 测试运行结果
55. Spring boot with Monitor
55.1. Spring boot with Grafana
55.1.1. Springboot 集成 InfluxDB
55.1.2. InfluxDB
55.2. Spring Boot with Prometheus
55.2.1. Maven 依赖
55.2.2. application.properties 配置文件
55.2.3. 启动类
55.2.4. 测试
55.2.5. 控制器监控
55.2.6. 自定义埋点监控
57. Spring boot with Git version
57.1. CommonRestController 公共控制器
57.2. VersionRestController 测试控制器
57.3. 创建 .gitattributes 文件
58. Spring boot with Session share
58.1. Redis
58.1.1. Maven
58.1.2. application.properties
58.1.3. Application
58.2. 测试 Session
58.3. JDBC
58.4. Springboot 2.1
59. Spring boot with Caching
59.1. maven
59.1.1. Redis
59.2. 启用 Cache
59.3. @Cacheable 的用法
59.3.1. SpEL表达式
59.3.2. 排除 null 结果
59.3.3. 排除 empty
59.4. @CachePut 用法
59.5. 清空缓存
59.6. @Caching
59.7. 解决Expire 和 TTL 过期时间
60. Spring boot with Email
60.1. Maven
60.2. Resource
60.3. POJO
60.4. RestController
60.5. Test
61. Spring boot with Hessian
61.1. Maven
61.2. Application
61.3. HessianServiceExporter
61.4. Service
61.5. RestController
62. Spring boot with Async
62.1. Callable 实现异步
62.2. WebAsyncTask 实现异步
62.3. DeferredResult 实现异步返回结果
62.4. 带有返回值的异步任务
62.4.1. Future
62.4.2. CompletableFuture
62.5. 默认简单线程池 SimpleAsyncTaskExecutor
62.5.1. 配置线程池
62.5.2. @Service/@Component 中异步执行
62.5.3. applicationTaskExecutor
62.6. ThreadPoolTaskExecutor 自定义线程池
62.6.1. 最简单的配置
62.6.2. 队列
62.6.3. 定义多个线程池
62.6.4. 实现 AsyncConfigurer 接口方式创建自定义连接池
62.6.5. 继承 AsyncConfigurerSupport 创建自定义连接池
62.6.6. 生产环境完整代码 @Bean 注入方式
62.6.7. 通过 @Bean 覆盖掉 SimpleAsyncTaskExecutor
62.7. 自定义线程池 ThreadPoolExecutor
62.7.1. ThreadPoolExecutor
62.7.2. 注入自定义线程池bean
62.8. 设置线程名称
62.9. 线程池监控
62.10. 注意事项
63. Springboot with Ethereum (web3j)
63.1. Maven
63.2. application.properties
63.3. TestRestController
63.4. 测试
64. Java Record 新特性
64.1. Record 替代 POJO 类
64.2. Record 作为 Properties
64.3. Record 作为实体类
64.4. Record 作为 Service
64.5. Record 作为 Controller
V. Spring Framework
65. Spring MVC
65.1. @EnableWebMvc
65.1.1. CORS 跨域请求
65.1.2. Spring MVC CORS with WebMvcConfigurerAdapter
65.2. @Controller
65.2.1. @RequestMapping
65.2.2. @GetMapping
65.2.3. @PostMapping
65.2.4. @RequestBody
65.2.5. RequestMapping with Request Parameters - @RequestParam
65.2.6. @RequestHeader - 获取 HTTP Header 信息
65.2.7. RequestMapping with Path Variables - @PathVariable
65.2.8. @MatrixVariable注解,RFC3986定义URI的路径(Path)中可包含name-value片段
65.2.9. @ModelAttribute
65.2.10. @ResponseBody
65.2.11. @ResponseStatus 设置 HTTP 状态
65.2.12. @CrossOrigin
65.2.13. @CookieValue - 获取 Cookie 值
65.2.14. @SessionAttributes
65.2.15. ModelAndView
65.2.16. HttpServletRequest / HttpServletResponse
65.2.17. StreamingResponseBody 输出 Raw Data
65.3. @RestController
65.3.1. 上传文件
65.3.2. 返回实体
65.3.3. JSON
65.3.4. 处理原始 RAW JSON 数据
65.3.5. 返回 JSON 对象 NULL 专为 "" 字符串
65.3.6. XML
65.3.7. 兼容传统 json 接口
65.3.8. 上传文件
65.3.9. Spring boot with csv
65.3.10. Json 处理
65.3.11. synchronized
65.3.12. SSE Streaming in Spring MVC
65.3.13. StreamingResponseBody
65.4. View
65.4.1. 配置静态文件目录
65.4.2. 添加静态文件目录
65.4.3. Using Spring’s form tag library
65.4.4. Thymeleaf
65.4.5. FreeMarker
65.4.6. i18n 国际化
65.5. 校验器(Validator)
65.5.1. 常规用法
65.5.2. 自定义注解
65.6. Interceptor/Filter 拦截器/过滤
65.6.1. Session 拦截
65.6.2. Token 拦截
65.6.3. 过滤器
65.6.4. 拦截器获取PathVariable变量
67. WebFlux framework
67.1. Getting Started
67.1.1. Maven
67.1.2. Application
67.1.3. RestController
67.1.4. 测试
67.2. WebFlux 与 SprintMVC 有什么不同?
67.2.1. 实验程序
67.2.2. 实验结果
67.3. WebFlux Router
67.3.1. Component 原件
67.3.2. 路由配置
67.4. Thymeleaf
67.4.1. 模板引擎 Thymeleaf 依赖
67.4.2. application.properties 相关的配置
67.4.3. Webflux 控制器
67.4.4. Tymeleaf 视图
67.5. Webflux Redis
67.5.1. Maven Redis 依赖
67.5.2. Redis 配置
67.5.3. Config
67.5.4. Service
67.5.5.
67.6. Webflux Mongdb
67.6.1. Maven 依赖
67.6.2. Repository
67.6.3. Service
67.6.4. 控制器
67.7. Mono
67.7.1. Mono.just()/Mono.justOrEmpty()
67.7.2. MonoSink 创建 Mono
67.7.3. Supplier 创建 Mono
67.7.4. then()
67.7.5. 异常处理
67.7.6. 同步阻塞等待结果
67.8. Flux 返回多条数据
67.8.1. FluxSink 创建异步 Flux
67.8.2. SynchronousSink 创建同步 Flux
67.8.3. just()
67.8.4. 从 Flux/Mono 创建 Flux
67.8.5. 消息订阅
67.8.6. 从 Flux/Mono 创建 Flux
67.8.7. 从 Iterable 创建 Flux
67.8.8. 从 Stream 创建 Flux
67.8.9. defer()
67.8.10. Flux.interval()
67.8.11. Flux.empty()
67.8.12. Flux.error()
67.8.13. Flux.never()
67.8.14. Flux.range()
67.8.15. 返回数据
67.8.16. 持续更新 Flux
67.8.17. map(), flatMap()
67.8.18. 过滤
67.8.19. 触发操作
67.9. SSE
67.9.1. 一次性事件
67.9.2. 从 Steam 返回数据
67.9.3. 周期性事件
67.9.4. 返回 ServerSentEvent 数据结构
67.9.5. SSE 完整的例子
67.9.6. SSE Client 订阅实例
67.10. 并发
67.11. ConnectableFlux
67.12. WebClient
67.12.1. 配置 WebClient
67.12.2. @Controller/@RestController 实例
67.12.3. Get 请求实例
67.12.4. URI 参数
67.12.5. 查询参数
67.12.6. Post 操作演示
67.12.7. Post 表单数据
67.12.8. 上传文件
67.12.9. 设置 HTTP 头
67.12.10. 同步阻塞等待返回结果
67.12.11. websocket
67.12.12. 获取 HTTP 链接状态
67.12.13. Http Base Authentication - 401 Unauthorized
67.12.14. 订阅 SSE
67.12.15. 超时时间
67.12.16. share() 共享订阅数据
67.12.17. 打印调试日志
67.13. Webflux 安全
67.13.1. Token 拦截器
67.13.2. JWT
67.13.3. spring-boot-starter-security
67.14. 常见问题
67.14.1. The Java/XML config for Spring MVC and Spring WebFlux cannot both be enabled, e.g. via @EnableWebMvc and @EnableWebFlux, in the same application.
67.14.2. @EnableWebFluxSecurity 与 @EnableReactiveMethodSecurity 不生效
67.14.3. webflux netty 不支持 Content-Type: application/x-www-form-urlencoded
68. @Bean
68.1. @Scope 定义类型
68.2. InitializingBean
69. Service
69.1. Application
69.2. 定义接口
69.3. 实现接口
69.4. 调用 Service
69.5. context.getBean 调用 Service
69.6. AopContext
69.7. Service 单例/多例模式
69.7.1. Service 是单例模式
69.7.2. Service 多例实现
69.8. 构造方法
70. Spring boot with Webpage
70.1. Maven
70.2. application.properties
70.3. Application
70.4. IndexController
70.5. src/main/webapp/WEB-INF/jsp/index.jsp
70.6. 集成模板引擎
71. Spring boot with Velocity template
71.1. Maven
71.2. Resource
71.3. Application
71.4. RestController
71.5. Test
72. Spring boot with Thymeleaf
72.1. Maven
72.2. application.properties
72.3. Controller
72.4. HTML5 Template
73. Tomcat Spring 运行环境
73.1. Maven
73.2. Spring MVC configuration
73.3. Tomcat
73.4. 集成 Mybatis
73.4.1. pom.xml
73.4.2. properties
73.4.3. dataSource
73.4.4. SqlSessionFactory
73.4.5. Mapper 扫描
73.4.6. Mapper 单一class映射
73.4.7. Service
73.4.8. 测试实例
74. Spring 工具集
74.1. URL 拼装/解析
74.2. ServletUriComponentsBuilder
74.3. URL 路径相关
74.4. String boot with RestTemplate
74.4.1. RestTemplate Example
74.4.2. GET 操作
74.4.3. POST 操作
74.4.4. PUT 操作
74.4.5. Delete 操作
74.4.6. 上传文件
74.4.7. HTTP Auth
74.4.8. PKCS12
74.4.9. Timeout 超时设置
74.5. RestClient
74.5.1. 创建 RestClient
74.5.2. Get 操作
74.5.3. Post Json
74.5.4. HTTP Authorization Basic
74.5.5. onStatus
74.5.6. 下载二进制流
VI. Spring Data
75. EntityManager
76. Spring Data with JdbcTemplate
76.1. execute
76.2. queryForInt
76.3. queryForLong
76.4. queryForObject
76.4.1. 返回整形与字符型
76.4.2. 查询 Double 类型数据库
76.4.3. 返回日期
76.4.4. 返回结果集
76.4.5. 通过 "?" 向SQL传递参数
76.4.6. RowMapper 记录映射
76.5. queryForList
76.5.1. Iterator 用法
76.5.2. for 循环
76.5.3. forEach 用法
76.6. queryForMap
76.7. query
76.7.1. ResultSet
76.7.2. ResultSetExtractor
76.7.3. RowMapper
76.8. queryForRowSet
76.9. update
76.10. MapSqlParameterSource
76.11. 实例参考
76.11.1. 参数传递技巧
77. Spring Data with MySQL
77.1. 选择数据库表引擎
77.2. 声明实体
77.2.1. @Entity 声明实体
77.2.2. @Table 定义表名
77.2.3. @Id 定义主键
77.2.4. @Column 定义字段:
77.2.5. 非数据库字段
77.2.6. @Lob 注解属性将被持久化为 Blog 或 Clob 类型
77.2.7. @NotNull 不能为空声明
77.2.8. @Temporal 日期定义
77.2.9. 创建日期
77.2.10. @DateTimeFormat 处理日期时间格式
77.2.11. Enum 枚举数据类型
77.2.12. SET 数据结构
77.2.13. JSON 数据类型
77.2.14. 索引
77.2.15. 嵌入
77.2.16. 外键
77.2.17. 映射集合属性
77.2.18. @JsonIgnore
77.2.19. @EnableJpaAuditing 开启 JPA 审计功能
77.2.20. 注释 @Comment
77.2.21. @Pattern 数据匹配
77.2.22. 实体继承
77.3. Repository
77.3.1. CrudRepository
77.3.2. JpaRepository
77.3.3. PagingAndSortingRepository
77.3.4. findByXXX
77.3.5. count 操作
77.3.6. delete 删除操作
77.3.7. OrderBy
77.3.8. GreaterThan
77.3.9. Sort 排序操作操作
77.3.10. Pageable 翻页操作
77.3.11. @DynamicInsert 与 @DynamicUpdate
77.3.12. 继承已存在的 Repository
77.3.13. 自定义返回字段
77.4. TransactionTemplate
77.5. JPQL @Query
77.5.1. @Modifying 更新/删除
77.5.2. 事务 @Transactional
77.5.3. 参数传递
77.5.4. 原生 SQL 操作
77.5.5. @Query 与 Pageagble
77.5.6. 返回指定字段
77.5.7. 返回指定的模型
77.5.8. Collection
77.5.9. Sort
77.5.10. 锁 @Lock
78. Spring Data with Redis
78.1. 集成 Redis XML 方式
78.1.1. pom.xml
78.1.2. springframework-servlet.xml
78.1.3. Controller
78.1.4. index.jsp
78.1.5. 测试
78.2. 通过构造方法实例化 Redis
78.3. RedisTemplate
78.3.1. 设置缓存时间
78.3.2. increment
78.3.3. 删除 key
78.3.4. 对象存储
78.3.5. 获取过期时间
78.3.6. 过期时间未执行
78.4. stringRedisTemplate 基本用法
78.5. ValueOperations
78.5.1. 字符串截取
78.5.2. 追加字符串
78.5.3. 设置键的字符串值并返回其旧值
78.5.4. 返回字符串长度
78.5.5. 如果key不存便缓存。
78.5.6. 缓存多个值 /获取多个值 multiSet / multiGet
78.5.7. setBit / getBit 二进制位操作
78.6. 列表操作
78.6.1. rightPush
78.6.2. rightPushAll
78.6.3. rightPushIfPresent
78.6.4. leftPush
78.6.5. leftPushAll
78.6.6. range
78.7. SetOperations 数据类型
78.7.1. 返回集合中的所有成员
78.7.2. 取出一个成员
78.7.3. 随机获取无序集合中的一个元素
78.7.4. 随机获取 n 个成员(存在重复数据)
78.7.5. 随机获取 n 个不重复成员
78.7.6. 在两个 SET 间移动数据
78.7.7. 成员删除
78.7.8. 返回集合数量
78.7.9. 判断元素是否在集合成员中
78.7.10. 对比两个集合求交集
78.7.11. 对比两个集合求交集,然后存储到新的 key 中
78.7.12. 合并两个集合,并去处重复数据
78.7.13. 合并两个集合去重复后保存到新的 key 中
78.7.14. 计算两个合集的差集
78.7.15. 计算两个合集的差集,然后保存到新的 key 中
78.7.16. 遍历 SET 集合
78.8. ZSetOperations 有序的 set 集合
78.9. HashOperations
78.9.1. put
78.9.2. putAll
78.9.3. 从键中的哈希获取给定hashKey的值
78.9.4. delete
78.9.5. 确定哈希hashKey是否存在
78.9.6. 从哈希中获取指定的多个 hashKey 的值
78.9.7. 只有hashKey不存在时才能添加值
78.9.8. 获取整个Hash
78.9.9. 获取所有key
78.9.10. 通过 hashKey 获取所有值
78.9.11. 值加法操作
78.9.12. 遍历 Hash 表
78.10. 存储 Json 对象
78.10.1. 集成 RedisTemplate 定义新类 JsonRedisTemplate
78.10.2. 配置 Redis
78.10.3. 测试
78.11. Spring Data Redis - Repository Examples
78.11.1. @EnableRedisRepositories 启动 Redis 仓库
78.11.2. 定义 Domain 类
78.11.3. Repository 接口
78.11.4. 测试代码
79. Spring Data with MongoDB
79.1. Example Spring Data MongoDB
79.1.1. pom.xml
79.1.2. springframework-servlet.xml
79.1.3. POJO
79.1.4. Controller
79.1.5. 查看测试结果
79.1.6. 条件查询
79.2. MongoDB 多数据源
79.2.1. Maven
79.2.2. Application 禁止自动配置 MongoDB
79.2.3. application.properties 新增配置项
79.2.4. MongoDB 配置类
79.2.5. 创建 Document 关系映射类
79.2.6. 测试控制器
79.2.7. 测试
79.3. @Document
79.3.1. 指定表名
79.3.2. @Id
79.3.3. @Version
79.3.4. @Field 定义字段名
79.3.5. @Indexed
79.3.6. @CompoundIndex 复合索引
79.3.7. @TextIndexed
79.3.8. @GeoSpatialIndex 地理位置索引
79.3.9. @Transient 丢弃数据,不存到 mongodb
79.3.10. @DBRef 做外外键引用
79.3.11. @DateTimeFormat
79.3.12. @NumberFormat
79.3.13. 在 @Document 中使用 Enum 类型
79.3.14. 在 @Document 中定义数据结构 List/Map
79.3.15. GeoJson 数据类型
79.4. MongoRepository
79.4.1. 扫描仓库接口
79.4.2. findAll()
79.4.3. deleteAll()
79.4.4. save()
79.4.5. count()
79.4.6. exists() 判断是否存在
79.4.7. existsById()
79.4.8. findByXXXX
79.4.9. findAll with OrderBy
79.4.10. findAll with Sort
79.4.11. FindAll with Pageable
79.4.12. StartingWith 和 EndingWith
79.4.13. Between
79.4.14. Before / After
79.4.15. @Query
79.5. mongoTemplate
79.5.1. Save 保存
79.5.2. Insert
79.5.3. updateFirst 修改符合条件第一条记录
79.5.4. updateMulti 修改符合条件的所有
79.5.5. 查找并保存
79.5.6. upsert - 修改符合条件时如果不存在则添加
79.5.7. 删除
79.5.8. 查找一条数据
79.5.9. 查找所有数据
79.5.10. Query
79.5.11. Criteria
79.5.12. Update
79.5.13. BasicUpdate
79.5.14. Sort
79.5.15. Query + PageRequest
79.5.16. newAggregation
79.5.17. 创建索引
79.5.18. 子对象操作
79.6. GeoJson 反序列化
79.7. FAQ
79.7.1. location object expected, location array not in correct format; nested exception is com.mongodb.MongoWriteException: location object expected, location array not in correct format
80. Spring Data with Elasticsearch
80.1. 内嵌 Elasticsearch
80.1.1. Maven
80.1.2. src/main/resources/application.properties
80.1.3. Domain Class
80.1.4. ElasticsearchRepository
80.1.5. SearchRestController
80.1.6. 测试
80.2. 集群模式
80.3. Document
80.4. Elasticsearch 删除操作
80.5. FAQ
80.5.1. java.lang.IllegalStateException: Received message from unsupported version: [2.0.0] minimal compatible version is: [5.0.0]
81. Spring boot with Data restful
81.1. Maven
82. Apache ShardingSphere
82.1. 微服务集群环境,雪花算法出现重复ID
82.1.1. 方案一、配置实现
82.1.2. 方案二、代码实现
VII. Spring Security
83. Springboot 3 + Security 6
83.1. Spring Security with HTTP Auth
83.1.1. 默认配置
83.1.2. 设置用户名和密码
83.1.3. 禁用 Security
83.1.4. 设置角色
83.2. Springboot 3 Security + OncePerRequestFilter
83.2.1. OncePerRequestFilter
83.2.2. SecurityConfiguration
83.3. SecurityFilterChain
83.4. @PreAuthorize
83.4.1. hasRole
83.4.2. hasAnyRole
83.4.3. 从 HttpServletRequest 返回的 request 变量中判断角色
83.4.4. getAuthentication() 获得角色
83.4.5. UserDetailsService
83.5. httpBasic 配置
83.6.
84. Spring Authorization Server
84.1. Oauth2 协议
84.1.1. token
84.1.2. grant_type
84.1.3. 授权码授权模式(Authorization Code Grant)
84.1.4. 密码模式(Resource Owner Password Credentials Grant)
84.1.5. 客户端凭证模式(Client Credentials Grant)
84.1.6. 刷新 TOKEN 方式
84.2. Maven 依赖
84.3. Spring cloud with Oauth2
84.3.1. authorization_code
84.3.2. Spring boot with Oauth2 - Password
84.3.3. Spring boot with Oauth2 jwt
84.3.4. Spring boot with Oauth2 jwt 非对称证书
84.3.5. Apple iOS 访问 Oauth2
84.3.6. Oauth2 客户端
84.3.7. Android Oauth2 + Jwt example
84.3.8. RestTemplate 使用 HttpClient
84.3.9. 自签名证书信任问题
84.3.10. Principal
84.3.11. SecurityContextHolder 对象
84.3.12. 资源服务器配置
84.3.13. Client
84.3.14. Oauth2 常见问题
85. Spring boot with Spring security(2.x)
85.1. Spring security 静态配置例子
85.1.1. Maven
85.1.2. Reource
85.1.3. Application
85.1.4. WebSecurityConfigurer
85.1.5. RestController
85.1.6. 测试
85.2. Spring + Security + MongoDB
85.2.1. Account
85.2.2. AccountRepository
85.2.3. WebSecurityConfiguration
85.3. Spring Boot with Web Security(2.x)
85.3.1. EnableWebSecurity
85.3.2. Web静态资源
85.3.3. 正则匹配
85.3.4. 登陆页面,失败页面,登陆中页面
85.3.5. CORS
85.3.6. X-Frame-Options 安全
85.4. 访问控制列表(Access Control List,ACL)
85.4.1. antMatchers
85.4.2. HTTP Auth
85.4.3. Rest
85.4.4. hasRole
85.4.5. hasAnyRole()
85.4.6. withUser
VIII. Spring Cloud
86. Spring Cloud
86.1. Spring Cloud 相关的 application.properties 配置
86.1.1. 启用或禁用 bootstrap
86.1.2. bootstrap.properties 配置文件
87. Spring Cloud Config
87.1. Maven 项目 pom.xml 文件
87.2. Server
87.2.1. Maven config 模块
87.2.2. Application
87.2.3. application.properties
87.2.4. Git 仓库
87.2.5. 测试服务器
87.3. Client
87.3.1. Maven pom.xml
87.3.2. Application
87.3.3. bootstrap.properties
87.3.4. 测试 client
87.4. Config 高级配置
87.4.1. 仓库配置
87.4.2. Config server 用户认证
87.4.3. 加密敏感数据
87.4.4. Spring Cloud Config JDBC Backend
87.5. Old
87.5.1. Server (Camden.SR5)
87.5.2. Client (Camden.SR5)
88. Spring Cloud Consol
88.1. Spring Cloud Consul 配置
88.2. Maven 父项目
88.3. Consul 服务生产者
88.3.1. Maven
88.3.2. application.properties
88.3.3. SpringApplication
88.3.4. TestController
88.4. Consul 服务消费者
88.4.1. Maven
88.4.2. application.properties
88.4.3. SpringApplication
88.4.4. TestController
88.5. Openfeign
88.5.1. Maven
88.5.2. application.properties
88.5.3. SpringApplication
88.5.4. Feign 接口
88.5.5. TestController
89. Spring Cloud Netflix
89.1. Eureka Server
89.1.1. Maven
89.1.2. Application
89.1.3. application.properties
89.1.4. 检查注册服务器
89.2. Eureka Client
89.2.1. Maven
89.2.2. Application
89.2.3. RestController
89.2.4. application.properties
89.2.5. 测试
89.3. Feign client
89.3.1. Maven
89.3.2. Application
89.3.3. interface
89.3.4. application.properties
89.3.5. 测试
89.3.6. fallback
89.4. 为 Eureka Server 增加用户认证
89.4.1. Maven
89.4.2. application.properties
89.4.3. Eureka Client
89.4.4. Feign Client
89.5. Eureka 配置项
89.5.1. /eureka/apps
89.5.2. Eureka instance 配置项
89.5.3. Eureka client 配置项
89.5.4. Eureka Server配置项
89.6. ribbon
89.6.1.
89.6.2. LoadBalancerClient 实例
89.6.3. Ribbon 相关配置
89.7. 获取 EurekaClient 信息
89.8. Zuul
89.8.1. Maven
89.8.2. EnableZuulProxy
89.8.3. application.yml
89.8.4. 负载均衡配置
90. Openfeign
90.1. Openfeign 扫描包配置
90.2. 用户认证
90.3. 应用实例
90.4. 配置连接方式
90.4.1. httpclient
90.4.2. okhttp
90.5. 配置手册
91. Spring Cloud Gateway
91.1. Gateway 例子
91.1.1. Maven
91.1.2. SpringApplication
91.1.3. application.yml
91.1.4. RouteLocator 方式
91.2. 路由配置
91.2.1. 转发操作
91.2.2. URL 参数
92. Spring Cloud Sleuth
92.1. logback 安装
93. Spring Cloud with Kubernetes
93.1. Config
93.1.1. Maven 依赖
93.1.2. Spring Cloud 配置文件
93.1.3. 程序文件
93.1.4. Kubernetes 编排脚本
93.1.5. 测试
93.2. 注册发现
93.2.1. Maven 父项目
93.2.2. provider
93.2.3. consumer
93.2.4. 测试
93.2.5.
94. Spring Cloud Alibaba
94.1. 安装 Nacos
94.1.1. Docker 安装 Nacos
94.1.2. Kubernetes 安装 Nacos
94.1.3. IP限制,白名单
94.1.4. 防火墙配置
94.2. Kubernetes 部署微服务
94.2.1. pom.xml 中加入 docker 插件
94.2.2. 容器启动脚本
94.2.3. 构建 docker 镜像
94.2.4. 编排 kubernetes 容器
94.2.5. 启动指定 nacos
94.3. Nacos 配置中心/注册中心代码实例
94.3.1. Maven
94.3.2. SpringBootApplication
94.3.3. ConfigController
94.3.4. 配置文件
94.4. FAQ
94.4.1. 禁用 Nacos
94.4.2. 禁止注册
94.4.3. Failed to bind properties under 'server.tomcat.basedir' to java.io.File:
94.4.4. 不读取 bootstrap.yaml 文件
94.4.5. WARN [com.alibaba.nacos.client.naming:177] [,] - out of date data received, old-t: 1665711914993, new-t: 1665711902390
94.4.6. User limit of inotify instances reached or too many open files
94.4.7. 开启权限
94.4.8. ERROR Whitelabel
94.4.9.
95. FAQ
95.1. Cannot execute request on any known server
95.2. @EnableDiscoveryClient与@EnableEurekaClient 区别
95.3. Feign请求超时
95.4. 已停止的微服务节点注销慢或不注销
95.5. Feign 启动出错 PathVariable annotation was empty on param 0.
95.6. Feign 提示 Consider defining a bean of type 'common.feign.Cms' in your configuration.
95.7. Load balancer does not have available server for client
95.8. Eureka Client (Dalston.SR1)
95.8.1. Maven
95.8.2. Application
95.8.3. RestController
95.8.4. application.properties
95.8.5. 测试
95.9. Config Server(1.3.1.RELEASE)
95.9.1. Server
95.9.2. Client
95.10. feign.RetryableException: Read timed out executing
96. Spring Integration
96.1. Spring Redis Lock
96.1.1. Maven 依赖
96.1.2. 配置锁
96.1.3. 使用方法
96.2. MQTT Support
96.2.1. 入站消息通道适配器
96.2.2. 出站通道适配器
96.2.3. @MessagingGateway 定义消息网管接口
96.2.4. 手动 ACK 应答
96.2.5. Spring boot with Mqtt v5
97. MyBatis
97.1. Mybatis 入门
97.2. 接口注解
98. Apache Struts
98.1. struts.xml
98.1.1. include
98.2. Struts Tags
98.2.1. property
98.2.2. set
98.2.3. url
98.2.4. s:include
98.2.5. s:action
98.2.6. HTML Form
98.2.7. iterator
98.2.8. if elseif else
98.3. Action
98.3.1. redirect
98.3.2. redirectAction
98.3.3. JSON
98.3.4. 传递 Timestamp 变量
98.4. Ajax + JSON
98.4.1. GET/POST JSON
98.5. Json 内容展示
98.5.1. 禁止方法
98.5.2. 格式化日期
98.5.3. 重命名变量名
98.5.4. org.apache.struts2.json
98.6. Interceptor
98.6.1. Session
98.7. Action 中使用线程
98.8. 日志
98.9. FAQ
98.9.1. Struts 怎样判断用户来自电脑还是移动设备
99. Apache Tiles
99.1. 配置 Tiles
99.1.1. Maven
99.1.2. web.xml
99.2. Template 配置模板
99.3. Struts tiles
100. Play
101. Servlet
101.1. Example
101.2. Session
101.3. HttpServletRequest
101.4. Filter
101.4.1. web.xml
101.4.2. Filter 类
101.5. Listener
101.5.1. web.xml
101.5.2. NewsListener 类
101.5.3. NewsTask 类
101.5.4. JSP 中心显示
101.6. JSP
101.6.1. 注释
101.6.2. pageContext
101.6.3. request
101.6.4.
101.6.5. cookie
101.6.6. session
101.6.7. page
101.6.8. trimDirectiveWhitespaces
101.6.9. include
101.6.10. jsp
101.6.11. error-page
101.6.12. JSP 编程
101.6.13. FAQ
101.7. JSTL(JavaServer Pages Standard Tag Library)
101.7.1. c:set
101.7.2. c:out
101.7.3. c:url
101.7.4. c:redirect
101.7.5. c:import
101.7.6. c:if
101.7.7. c:choose
101.7.8. c:forEach
101.7.9. empty 判断是否为空
101.7.10. JSTL fmt Tag setBundle Example
101.8. WebSocket
101.8.1. Server
101.8.2. Client
102. Log
102.1. Logback
102.1.1. Maven 包
102.1.2. Example
102.2. slf4j
102.3. log4j
102.3.1. 安装 Log4j
102.3.2. log4j 环境变量
102.3.3. Log4j Example
102.3.4. log4j.properties
103. AMQP(Advanced Message Queuing Protocol)
103.1. Send and Recv
103.2. direct
104. NoSQL
104.1. MongoDB
104.1.1. pom.xml
104.1.2. 插入操作
104.1.3. 读取操作
105. Elasticsearch API
105.1. Client
105.2. insert
105.3. Get
105.4. delete
105.5. Search
105.6. Query 查询
105.6.1. match all 匹配所有数据
105.6.2. match 匹配查询
105.6.3. match phrase 短语精准匹配
105.7. Filter 过滤
105.7.1. term
105.7.2. range
105.8. Sorting
105.9. 返回 Source 字段
105.10. Count
105.11. Example 范例
105.11.1. Spring boot 案例
105.12. FAQ
105.12.1. 显示查询 JSON 字符串
106. Jersey - RESTful Web Services in Java.
106.1. Client 2.x
106.1.1. Maven 版本
106.1.2. GET 操作
106.1.3. GET + Auth 用户认证
106.2. Client 1.x
106.2.1. Jersey + Auth + HTTP2 + SSL
107. Apache HttpComponents
107.1. org.apache.commons.lang3
107.1.1. HTML 标签处理
107.1.2. StringUtils.join 使用特定字符链接字符串
107.1.3. RandomStringUtils
107.2. commons-text
107.2.1. 禁止转译 json
107.3. Apache HttpClient
107.3.1. Maven
107.3.2. HTTP POST 操作
107.3.3. HTTPS
107.3.4. HTTP/2
107.3.5. Java11
107.3.6. Host name 'api.netkiller.cn' does not match the certificate subject provided
107.3.7. HttpStatus
107.3.8.
108. Cache
108.1. java memcached client
108.2. Jedis
108.2.1. 认证
108.2.2. jedis.keys
108.3. Ehcache
109. Kafka
109.1. 安装 Kafka 环境
109.2. Maven
109.3. 启动 kafka
109.4. 入门例子
109.4.1. 订阅例子
109.4.2. 发布例子
109.5. 线程例子
110. Software Development Kit
110.1. JAVE(Java Audio Video Encoder)
110.2. Google
110.2.1. com.google.gson
110.2.2. Guava
110.3. Mahout
110.3.1. 推荐系统
110.4. Hessian
110.5. quartz-scheduler
110.6. Redisson
IX. Android
111. Android Studio
111.1. 卸载 Android Studio
111.2. 代码格式化
111.3. 设置兼容最低SDK版本
111.4. SDK Tools
111.4.1. 接受 License
111.4.2. 查看 SDK 列表
111.4.3. 按照 Android SDK
111.5. 命令行操作
111.6. adb 命令
111.6.1. 获得 root 权限
111.6.2. 设备管理
111.6.3. Shell
111.6.4. 设备 ID
111.6.5. 查看安卓版本
111.6.6. Logcat
111.6.7. 上传文件
111.6.8. 下载文件
111.6.9. 安卓 .apk bk
111.6.10. 屏幕尺寸
111.6.11. dump 系统信息
111.6.12. 解锁
111.6.13. 蓝牙管理
112. AndroidManifest.xml
112.1. SDK 版本配置
112.2. 开启网络
112.3. 文件存储权限
112.4. 相机权限
112.5. GPS 定位权限
112.6. 全屏-无标题
112.7. 设置为默认开机启动
112.8. 开机启动
112.9. 默认横屏
112.10. 禁止屏幕旋转变化
113. 设备
113.1. 环境变量
113.1.1. 扩展存储
113.1.2. 下载缓存目录
113.1.3. 数据目录
113.2. 配置文件
113.2.1. *.properties 文件
113.2.2. 再 AndroidManifest.xml 使用 meta-data element 定义
113.2.3. 再 build.gradle 文件中配置 productFlavors
113.2.4. 从 assets 目录读取配置文件
113.3. 设备信息
113.4. Physical density
113.5. 声卡
113.5.1. 播放
113.5.2. 录音
113.5.3. 查看声卡信息
113.5.4. /proc/asound 设备信息
113.5.5. 查看声卡当前占用设备
113.5.6. tinymix 设置声卡参数
113.5.7. 麦克风阵列调试
114. Activity
114.1. 定义 UI
114.2. 隐藏虚拟键
114.3. 显式四种跳转方式
114.3.1. startActivity()
114.4. 定时关闭
114.5. 恢复触发
114.6. 返回触发
114.7. 保持屏幕常开
114.8. 标题栏添加返回按钮
114.9. Activity 间数据传递
114.9.1. Intent 方式
114.9.2. Bundle 方式
114.9.3. Flag 属性
114.9.4. 返回值
114.10. intentActivityResultLauncher 跳转
114.11. startActivityForResult 替代方案
114.11.1. 返回值
114.12. Activity 关闭
114.12.1. 退出 App
114.13. App 间跳转
114.14. Res 资源
114.14.1. 通过名称查找 layout ID
114.14.2. 查找 drawable 资源 ID
114.14.3. 获取 color 颜色 ID
114.14.4. 获取 array.xml 文件下某个字段的 ID
114.14.5. 获取 style.xml 文件下的某个样式的 id
115. Fragment
115.1. 启动 Fragment
115.2. 关闭 Fragment
115.3. 在 Fragment 中使用 findViewById
115.4. 在 Fragment 中使用 Intent 跳转
115.5. Fragment 中调用 getPackageManager()
115.6. 在 Fragment 中使用 runOnUiThread
115.7. Fragment 中调用 findViewById
115.8. 替换 FrameLayout
115.9. Fragment 接收 BroadcastReceiver 广播
116. Resources
116.1. strings.xml
116.1.1.
116.1.2.
116.1.3. 获取 Resource
117. Palette 视觉设计
117.1. 父容器定位
117.2. 样式布局
117.2.1. 对齐布局
117.2.2. LinearLayout
117.2.3. FrameLayout
117.2.4. 动画
117.2.5. 声音波形图
117.3. Widgets
117.3.1. ImageView
117.3.2. TextClock
117.3.3. 进度条
117.4. Containers
117.4.1. CardView
117.5. Legacy
117.5.1. GardView
117.5.2. GridView
117.6. 渐变背景色
117.7. 屏幕
117.7.1. 尺寸
117.7.2. 屏幕触摸事件 onTouch(View view, MotionEvent motionEvent)
117.7.3. 手势事件
119. Schedule 计划任务
119.1. 延迟执行
119.2. Time 和 TimerTask 定时刷新
119.3. 使用 Runnable 和 Handler 实现定时执行
119.4. 循环执行
119.5. TimerTask 实现循环播放
119.6. TimerTask 更新 UI
120. Internationalization i18n with Android (国际化)
120.1. 创建国际化文件
120.2. strings.xml 文件
120.3. 翻译语言
120.4. 引用国际化文件
120.5. 切换语言
121. 存储
121.1. 存储目录
121.2. SharedPreferences
121.2.1. 操作模式
121.2.2. 保存数据
121.2.3. 读取数据
121.2.4. 通过 key 查询数据是否存在
121.2.5. 删除数据
121.2.6. 清空数据
121.2.7. 对象存储
121.2.8. SharedPreferences 读取物理存储文件
121.3. SD Card
121.3.1. SD Card 状态
121.3.2. Android 11 申请 sdcard 权限
122. 网络
122.1. Wifi 配置
122.2. OkHttp - An HTTP & HTTP/2 client for Android and Java applications
122.2.1. Gradle
122.2.2. AndroidManifest.xml 开启网络访问权限
122.2.3. okhttp 默认是 HTTPS 开启 HTTP
122.2.4. GET
122.2.5. POST
122.2.6. HTTP PUT 请求
122.2.7. http header 相关设置
122.2.8. HTTP Base Auth
122.2.9. HttpUrl.Builder 组装 URL 地址参数
122.2.10. Android Activity Example
122.2.11. Android Oauth2 + Jwt example
122.2.12. HTTP/2
122.2.13. 异步更新 UI
122.2.14. WebSocket Client
123. 相机与相册
123.1. manifest 文件
123.2. layout
123.3. Activity
123.4. LED flash 做手电筒
124. 麦克风与录音
124.1. 开启麦克风和SD卡权限
124.2. layout
124.3. Activity
125. 多媒体开发
125.1. MediaPlayer
125.1.1. 播放Raw下的元数据
125.1.2. 播放assets文件夹中的音乐
125.1.3. 播放互联网音乐
125.1.4. 使用单例模式
125.1.5. 设置速度,快进播放
125.2. VideoView 开发
125.2.1. 播放网络视频
125.2.2. MediaController 添加翻页事件
125.2.3. 静音播放视频
125.2.4. 更新进度条
125.2.5. 完整的例子
125.2.6. 循环播放
125.2.7. 静音播放
125.3. SoundPool
125.4. 音量控制
125.5. SurfaceView
125.6. Vitamio
126. 定位
126.1. GPS + 网络 定位
126.1.1. manifest 权限配置
126.1.2. layout
126.1.3. Activity
126.2. 只从 GPS 获取定位
127. 电话
127.1. SIM 卡状态
127.2. 通信录与拨打电话
127.3. 发送短信
128. 消息广播
128.1. 动态注册
128.2. 静态注册
128.2.1. 电源管理
128.2.2. 接收不到消息
128.3. 自定义用户消息广播
128.4. 本地广播
128.5. 动态监听广播
128.6. 广播重复接收
128.7. 指定静态广播接收者
128.8. 异步执行广播
129. Service 服务
129.1. Service的基本用法
129.1.1. manifest 文件
129.1.2. 创建 Service
129.1.3. Layout 代码
129.1.4. Activity 代码
129.2. Service 中启动线程
129.3. Service 和 Activity 通信
129.3.1. Layout
129.3.2. Service
129.3.3. Activity
129.4. Service 和 Toast
129.5. Service 中启动 Activity
129.6. Service 中更新 UI
130. Notification 通知中心
130.1. 文本通知
130.2. 添加点击操作
131. NFC (Near field communication)
131.1. AndroidManifest.xml 文件配置
131.2. Loyout 文件
131.3. Activity 文件
132. 图形开发
132.1. Paint
132.2. AnimationDrawable
133. 下载管理
133.1. 从 URL 下来文件
133.2. 安装 APK
133.3. 下载后接收广播通知
134. Android 多线程
134.1. GPIO
135. EventBus
135.1. 添加 EventBus 依赖到项目Gradle文件
135.2. 快速开始一个演示例子
135.2.1. 创建 MessageEvent 类
135.2.2. Layout
135.2.3. Activity
135.3. Sticky Events
135.3.1. MainActivity
135.3.2. StickyActivity
135.3.3. MessageEvent
135.3.4. 删除粘性事件
135.4. 线程模型
135.5. 配置 EventBus
135.6. 事件优先级
135.7. 捕获异常事件
136. Android MQTT
136.1. build.gradle 添加依赖包
136.2. AndroidManifest.xml
136.3. Android Mqtt v5 例子
137. 安卓开发版
137.1. rk3568
137.1.1. 声卡
138. 杂项
138.1. Sleep
138.2. Caused by: java.net.UnknownServiceException: CLEARTEXT communication to 47.100.253.187 not permitted by network security policy
138.3. 设计模式
138.3.1. 单例模式
138.4. Android OS 包
138.4.1. 进程ID
138.4.2. handler
138.5. fastjson android
138.5.1. 对象转字符串
138.5.2. JsonObject 转对象
138.5.3. 字符串 与 json 互转
138.5.4. json 转 数组
138.5.5. JSON数组转List
138.5.6. Map 与 Json 互转
138.6. Butter Knife
138.7. Android Things
138.7.1. GPIO
139. FAQ
139.1. java.net.UnknownServiceException: CLEARTEXT communication to 192.168.0.185 not permitted by network security policy
139.2. Caused by: android.os.NetworkOnMainThreadException
139.3. java.lang.IllegalStateException: Player is accessed on the wrong thread.
139.4. Manifest merger failed with multiple errors, see logs
139.5. 从 Android API 30 废弃 setSystemUiVisibility(uiOptions)
140. 讯飞云
140.1. AIUI
140.1.1. AIUIPlayer
140.1.2. 酷我音乐
140.1.3. 控制技能
140.1.4. 唤醒词
140.1.5. 汉字转拼音
140.2. 讯飞 TTS
140.2.1. 设置日志输出级别
140.2.2. 流式语音合成
140.3. 语音唤醒
140.3.1. 范例
1. 附录
1.1. 一致性算法

范例清单

1.1. /etc/profile.d/java.sh
23.1. Maven properties
23.2. 将本地 lib/*.jar 包添加到项目中
23.3. 将本地 src/resources 打包到项目
23.4. Maven parent
23.5. watir-webdriver example
37.1. Example Spring boot with Oracle
8. RedisTemplate
45.1. Spring boot with Apache kafka.
45.2. Spring boot with Apache kafka.
45.3. Test Spring Kafka
60.1. Spring boot with Email (pom.xml)
71.1. Spring boot with Velocity template (pom.xml)
73.1. MyBatis
78.1. Spring Data Redis Example
79.1. Spring Data MongoDB - springframework-servlet.xml
95.1. Share feign interface.
108.1. memcached.java
119.1.