第1章 与安全有关的概念
1. 1 介绍
1. 2 因特网威胁模型
1. 3 角色
1. 4 安全目标
1. 5 必要的装备
1. 6 组合起来使用
1. 7 简单的安全消息系统
1. 8 简单的安全通道
1. 9 出口形式
l. 10 实际的加密算法
1. 11 对称加密:序列密码
1. 12 对称加密:分组密码
1. 13 摘要算法
1. 14 密钥的确立
1. 15 数字签名
1. 16 MAC
1. 17 密钥长度
1. 18 总结
第2章 SSL介绍
2. l 简介
2. 2 标准与标准化组织
2. 3 SSL概述
2. 4 SSL/TLS的设计目标
2. 5 SSL与TCP/IP族
2. 6 SSL的历史
2. 7 用于Web的SSL
2. 8 在SSL上构建一切
2. 9 获得SSL
2. 10 总结
第3章 SSL基础
3. 1 介绍
3. 2 SSL概述
3. 3 握手
3. 4 SSL记录协议
3. 5 各种消息协同工作
3. 6 一次真实的连接
3. 7 其他的连接细节
3. 8 SSL规范语言
3. 9 握手消息结构
3. 10 握手消息
3. 11 密钥导出
3. 12 记录协议
3. 13 警示与关闭
3. 14 总结
第4章 高级SSL
4. l 介绍
4. 2 会话恢复
4. 3 客户端认证
4. 4 临时RSA
4. 5 再握手
4. 6 服务器网关加密
4. 7 DSS与DH
4. 8 椭圆曲线加密套件
4. 9 Kerberos
4. 10 FORTEZA
4. 11 小结
4. 12 会话恢复细节
4. 13 客户端认证细节
4. 14 临时RSA的细节
4. 15 SGC的细节
4. 16 DH/DSS的细节
4. 17 FORTEZZA的细节
4. 18 错误警示(Error Alert)
4. 19 SSLv2的向后兼容性
4. 20 总结
第5章 SSL的安全
5. l 介绍
5. 2 SSL都提供了什么
5. 3 保护master_secret
5. 4 保护服务器的私用密钥
5. 5 使用良好的随机性
5. 6 检查证书链
5. 7 算法的选择
5. 8 小结
5. 9 攻破master_secret
5. 10 在内存中保护秘密
5. 11 保证服务器私用密钥的安全
5. 12 随机数生成
5. 13 证书链的验证
5. 14 部分攻破
5. 15 已知的攻击
5. 16 计时密码分析
5. 17 百万消息攻击
5. 18 小-子组攻击(SmallsubgroopAttack)
5. 19 降级使用出口模式
5. 20 总结
第6章 SSL的性能
6. l 介绍
6. 2 SSL速度慢
6. 3 性能法则
6. 4 加密的开销昂贵
6. 5 会话恢复
6. 6 握手算法与密钥选择
6. 7 批量数据传输
6. 8 基本的SSL性能法则
6. 9 小结
6. 10 握手的时间分配
6. 11 普通RSA模式
6. 12 带有客户端认证的RSA
6. 13 临时RSA
6. 14 DSS/DHE
6. 15 具有客户端认证的DSS/DHE
6. 16 DH性能的改进
6. 17 记录处理
6. 18 Java
6. 19 重负下的SSL服务器
6. 20 硬件加速
6. 21 串联硬件加速器
6. 22 网络延迟
6. 23 Nagle算法
6. 24 握手缓冲
6. 25 高级SSL性能法则
6. 26 总结
第7章 使用SSL进行设计
7. l 介绍
7. 2 了解要保证什么的安全
7. 3 客户端认证选项
7. 4 引用完整性
7. 5 不适合的任务
7. 6 协议的选择
7. 7 减少握手的开销
7. 8 设计策略
7. 9 小结
7. 10 独立端口
7. 11 磋商升级
7. 12 降级攻击
7. 13 引用完整性
7. 14 用户名/口令认证
7. 15 SSL客户端认证
7. 16 相互用户名/口令认证
7. 17 再握手
7. 18 二级通道
7. 19 关闭
7. 20 总结
第8章 SSL编程
8. 1 介绍
8. 2 SSL的实现
8. 3 范例程序
8. 4 上下文环境的初始化
8. 5 客户端连接
8. 6 服务器接受请求
8. 7 简单的I/O处理
8. 8 使用线程实现多路I/O
8. 9 使用select()实现多路I/O
8. 10 关闭
8. 11 会话恢复
8. 12 缺少什么?
8. 13 总结
第9章 SSL上的HTTP
9. l 介绍
9. 2 保护Web的安全
9. 3 HTTP
9. 4 HTML
9. 5 URL
9. 6 HTTP的连接行为
9. 7 代理
9. 8 虚拟主机
9. 9 协议选择
9. 10 客户端认证
9. 11 引用完整性
9. 12 HTTPS
9. 13 HTTPS概述
9. 14 URL与引用完整性
9. 15 连接关闭
9. 16 代理
9. 17 虚拟主机
9. 18 客户端认证
9. 19 Referrer
9. 20 替换攻击
9. 21 升级
9. 22 编程问题
9. 23 代理CONNECT
9. 24 处理多个客户端
9. 25 总结
第10章 TLS上的SMTP
10. l 介绍
10. 2 因特网邮件的安全
10. 3 因特阿消息传递概述
10. 4 SMTP
10. 5 RFC822和 MIME
10. 6 E-mail地址
10. 7 邮件中继
10. 8 虚拟主机
10. 9 MX记录
10. 10 客户端邮件存取
10. 11 协议的选择
10. 12 客户端认证
10. 13 引用完整性
10. 14 连接语义
10. 15 STARTTLS
10. 16 STARTTLS M概述
10. 17 连接关闭
10. 18 要求使用TLS
10. 19 虚拟主机
10. 20 安全指示器
10. 21 经过认证的中继
10. 22 源发者认证
10. 23 引用完整性的细节
10. 24 为什么不使用CONNECT
10. 25 STARTTLS有什么好处
10. 26 编程问题
10. 27 实现STARTTLS
10. 28 服务器的启动
10. 29 总结
第11章 各种方案的对比
11. l 介绍
11. 2 端到端的论述
11. 3 端到端的论述与 SMTP
11. 4 其他协议
11. 5 IPsec
11. 6 安全关联
11. 7 ISAKMP和 IKE
11. 8 AH和ESP
11. 9 协同工作:IPsec
11. 10 IPsec与SSL的对比
11. 11 安全HTTP
11. 12 CMS
11. 13 消息格式
11. 14 加密选项
11. 15 协调工作:S-HTTP
11. 16 S-HTTP与 HTTPS的对比
11. 17 SMIME
11. 18 S/MIME的基本格式
11. 19 只进行签名
11. 20 算法的选择
11. 21 协调工作:SMIME
11. 22 实现障碍
11. 23 S/MIME与SMTP/TLS的对比
11. 24 选择合适的解决方案
11. 25 总结
附录A 范例代码
A. l 第8章
A. 2 第9章
附录B SSLv2
B. l 介绍
B. 2 SSLv2概述
B. 3 缺少的功能
B. 4 安全问题
B. 5 PCT
B. 6 有关SSLv1的情况
参考文献