《灰帽黑客:正义黑客的道德规范、渗透测试、攻击方法和漏洞分析技术(第3版)》
基本信息原书名:Gray Hat Hacking: The Ethical Hacker's Handbook, Third Edition作者: [美]Shon Harris Allen Harper [作译者介绍]译者: 杨明军 韩智文 程文俊丛书名: 安全技术经典译丛出版社:清华大学出版社ISBN:9787302301509上架时间:2012-10-17出版日期:2012 年11月开本:16开页码:1版次:1-1所属分类: 计算机 > 安全 > 网络安全/防火墙/黑客更多关于 》》》《 》内容简介书籍计算机书籍 运用最新策略揭示当今最具破坏力的攻击 《灰帽黑客:正义黑客的道德规范、渗透测试、攻击方法和漏洞分析技术(第3版)》在上一版的基础上做了全面更新,新增了9章内容。本书内容丰富,讲解透彻,浓墨重彩地描述最新漏洞、修复方法以及合法的公开途径,详细介绍恶意软件分析、渗透测试、scada、voip和web安全等主题,分析黑客们如何定位系统、破坏保护方案、编写恶意代码以及利用windows和linux系统的缺陷。通过本书的学习,您将可以借助最新技术查找和修复安全缺陷,从而能够得心应手地阻止恶意网络攻击。 《灰帽黑客:正义黑客的道德规范、渗透测试、攻击方法和漏洞分析技术(第3版)》主要内容 使用backtrack和metasploit来模拟漏洞攻击 分析潜入、社交工程和内部攻击技术 模拟构建用来发起栈缓冲区溢出攻击的perl、python和ruby脚本 理解并阻止adobe、office和多媒体文件中的恶意内容 检测和阻止客户端、web服务器、voip和scada攻击 介绍针对windows和linux软件的逆向工程、模糊处理及反编译 讨论sql注入、跨站脚本和伪造攻击 使用蜜罐和沙箱技术来捕获恶意软件和加壳软件目录灰帽黑客:正义黑客的道德规范、渗透测试、攻击方法和漏洞分析技术(第3版)》第ⅰ部分 “合乎道德的揭秘行为” 简介 1第1章 正义黑客的道德规范 31.1 理解敌方策略的意义 31.2 认识安全领域的灰色区域 71.3 本书与正义黑客类图书的关系 81.3.1 漏洞评估 81.3.2 渗透测试 91.4 关于黑客类图书和课程的争议 121.4.1 工具的双重性 131.4.2 识别攻击 141.4.3 模拟攻击 151.5 攻击者最喜欢利用的漏洞 15第2章 合乎道德的正常揭秘行为 192.1 各方看待问题的不同角度 202.2 cert目前采取的工作流程 212.3 完全揭秘策略—rainforest puppy policy 232.4 internet安全组织 242.4.1 发现漏洞 252.4.2 通知 25.2.4.3 验证 27
2.4.4 解决 292.4.5 发布 302.5 争议仍将存在 302.6 案例分析 342.6.1 正当揭秘过程的优缺点 352.6.2 供应商更加关注 382.7 接下来应该做什么 38第ⅱ部分 渗透测试及工具 41第3章 社会工程攻击 433.1 社会工程攻击原理 433.2 实施社会工程攻击 443.3 渗透测试中常用到的攻击手段 463.3.1 好心人 473.3.2 会议室 513.3.3 加入公司 533.4 准备好进行面对面的攻击 543.5 防御社会工程攻击 56第4章 潜入攻击 574.1 潜入攻击如此重要的原因 574.2 实施潜入攻击 584.2.1 侦察 584.2.2 思想准备 604.3 进入目标建筑物的常用方法 604.3.1 吸烟区入口 614.3.2 人工检查点 624.3.3 锁住的门 644.3.4 物理方式开锁 664.3.5 进入目标之后 694.4 防御潜入攻击 69第5章 内部攻击 715.1 模拟内部攻击的重要性 715.2 实施内部攻击 725.2.1 工具和准备工作 725.2.2 了解情况 725.2.3 获得本地管理员权限 735.2.4 禁用防病毒软件 765.2.5 使用cain 775.3 防御内部攻击 83第6章 使用backtrack linux发行 856.1 backtrack简介 856.2 将backtrack安装到dvd或优盘 866.3 直接在虚拟机中使用back track iso映像文件 876.3.1 使用virtualbox创建backtrack虚拟机 886.3.2 引导backtrack livedvd 系统 886.3.3 探索backtrack x窗口环境 896.3.4 启动网络服务 906.4 永久性更改backtrack906.4.1 将backtrack完整地安装在硬盘或者优盘中 916.4.2 新建一个包含永久性更改信息的iso文件 926.4.3 使用自定义文件自动保存和恢复更改 946.5 研究backtrack引导菜单 956.6 更新backtrack 97第7章 使用metasploit 997.1 metasploit简介 997.2 获取metasploit 997.3 使用metasploit控制台加载攻击工具 1007.4 使用metasploit攻击客户端漏洞 1057.5 使用metasploit meterpreter进行渗透测试 1077.5.1 使用meterpreter进行键盘记录 1107.5.2 使用meterpreter以不同的已登录用户身份运行代码 1107.5.3 使用meterpreter的hashdump命令和metasploit的psexec命令以及共享口令登录 1127.6 metasploit的自动化与脚本化 1137.7 更进一步探讨metasploit 115第8章 渗透测试管理 1178.1 制定渗透测试计划 1178.1.1 渗透测试的类型 1178.1.2 渗透测试的范围 1188.1.3 渗透测试的位置 1188.1.4 渗透测试小组成员构成 1188.1.5 方法和标准 1188.1.6 渗透测试的各个阶段 1198.1.7 渗透测试计划 1208.2 签署渗透测试协议 1218.2.1 工作声明 1218.2.2 “保释信” 1218.3 实施渗透测试 1228.3.1 测试启动会议 1228.3.2 渗透测试中的资源访问 1228.3.3 测试预期值管理 1238.3.4 测试问题管理 1238.3.5 欲速则不达 1238.3.6 外部和内部协同 1238.4 在渗透测试中进行信息共享 1248.5 生成渗透测试结果报告 1288.5.1 报告格式 1288.5.2 报告摘要 128第ⅲ部分 漏洞攻击 129第 9 章 编程技能 1319.1 c编程语言 1319.1.1 c语言基本结构 1319.1.2 程序范例 1359.1.3 使用gcc进行编译 1369.2 计算机内存 1379.2.1 随机存取存储器(ram) 1379.2.2 字节序 1379.2.3 内存分段 1389.2.4 内存中的程序 1389.2.5缓冲区 1399.2.6内存中的字符串 1399.2.7 指针 1399.2.8 内存知识小结 1409.3 intel处理器 1419.3.1 寄存器 1419.4 汇编语言基础 1429.4.1 机器指令、汇编语言与 c语言 1429.4.2 at&t与nasm 1429.4.3 寻址模式 1449.4.4 汇编文件结构 1459.4.5 汇编过程 1469.5 使用gdb进行调试 1469.5.1 gdb基础 1469.5.2 使用gdb进行反汇编 1489.6 python编程技能 1499.6.1 获取python 1499.6.2 python中的hello world程序 1499.6.3 python对象 1509.6.4 字符串 1509.6.5 数字 1519.6.6 列表 1529.6.7 字典 1539.6.8 python文件操作 1549.6.9 python套接字编程 155第10章 基本的linux漏洞攻击 15710.1 栈操作 15710.1.1 函数调用过程 15810.2 缓冲区溢出 15910.2.1 meet.c溢出 16010.2.2 缓冲区溢出的后果 16310.3 本地缓冲区溢出漏洞攻击 16410.3.1 漏洞攻击组成部分 16510.3.2 在命令行上进行栈溢出漏洞攻击 16710.3.3 使用通用漏洞攻击代码进行栈溢出漏洞攻击 16810.3.4 对小缓冲区进行漏洞攻击 17010.4 漏洞攻击开发过程 17310.4.1 控制eip 17310.4.2 确定偏移 17310.4.3 确定攻击途径 17610.4.4 构建漏洞攻击三明治 17610.4.5 测试漏洞攻击 177第11章 高级linux漏洞攻击 17911.1 格式化字符串漏洞攻击 17911.1.1 问题描述 17911.1.2 从任意内存读取 18311.1.3 写入任意内存 18411.1.4 利用.dtors获得根特权级 18611.2 内存保护机制 18911.2.1 编译器改进 19011.2.2 内核补丁和脚本 19311.2.3“返回到libc”漏洞攻击 19411.2.4 综合比较 202第12章 shellcode策略 20312.1 用户空间shellcode 20312.1.1 系统调用 20312.1.2 基本shellcode 20412.1.3 端口绑定shellcode 20512.1.4 反向shellcode 20612.1.5 查找套接字shellcode 20712.1.6 命令执行代码 20812.1.7 文件传输代码 20812.1.8 多级shellcode 20912.1.9 系统调用代理shellcode 20912.1.10 进程注入shellcode 21012.2 其他shellcode考虑因素 21112.2.1 shellcode编码 21112.2.2 自我破坏shellcode 21212.2.3 反汇编shellcode 21312.3 内核空间shellcode 21412.3.1 内核空间考虑因素 214第13章 编写linux shellcode 21713.1 基本的linux shellcode 21713.1.1 系统调用 21713.1.2 使用c进行系统调用 21813.1.3 使用汇编语言进行系统调用 21913.1.4 系统调用exit 21913.1.5 系统调用setreuid 22113.1.6 利用execve实现创建shell的shellcode 22213.2 实现端口绑定shellcode 22613.2.1 linux套接字编程 22613.2.2 采用汇编语言编程建立一个套接字 22813.2.3 测试shellcode 23113.3 实现反向连接shellcode 23413.3.1 反向连接c语言编程 23413.3.2 反向连接汇编程序 23513.4 shellcode编码 23713.4.1 简单的xor编码 23713.4.2 编码后shellcode的结构 23813.4.3 jmp/call xor解码器示例 23813.4.4 fnstenv xor示例 23913.4.5 将代码组合起来 24113.5 利用metasploit自动生成shellcode 24413.5.1 利用metasploit生成shellcode 24413.5.2 利用metasploit对shellcode进行编码 245第14章 windows漏洞攻击 24714.1 windows程序编译与调试 24714.1.1 在windows上进行编译 24714.1.2 在windows上用ollydbg进行调试 24914.2 编写windows漏洞攻击程序 25314.2.1 漏洞攻击程序开发过程回顾 25414.2.2 prosshd服务器 25414.2.3 控制eip 25514.2.4 确定偏移 25714.2.5 确定攻击途径 25814.2.6 构建攻击三明治 26114.2.7 根据需要调试漏洞攻击程序 26214.3 理解seh 26414.3.1 seh的实现 26414.4 理解windows内存保护(xp sp3、vista、7和server 2008) 26614.4.1 基于栈的缓冲区溢出检测(/gs) 26614.4.2 safeseh 26814.4.3 sehop 26814.4.4 堆保护 26814.4.5 dep 26814.4.6 aslr 26914.5 绕开windows内存保护 27014.5.1 绕开/gs 27014.5.2 绕开safeseh 27114.5.3 绕开aslr 27214.2.4 绕开dep27214.5.5 绕开sehop 27814.5.6 内存保护绕开方法小结 285第15章 content-type攻击原理与检测 28715.1 content-type攻击原理 28715.2 现今可被攻击的文件格式 28915.3 pdf文件格式简介 29015.4 恶意pdf漏洞攻击分析 29315.5 恶意pdf文件检测工具 29615.5.1 pdfid 29615.5.2 pdf-parser.py 30015.6 content-type攻击防御测试工具 30315.7 content-type攻击防御方法 30415.7.1 安装所有的安全更新 30415.7.2 在adobe reader中禁用javascript 30515.7.3 针对微软office应用程序和adobe reader启用dep 305第16章 web应用程序安全漏洞30716.1 最流行的web应用程序安全漏洞概述 30716.1.1 注入漏洞 30716.1.2 跨站脚本漏洞 30816.1.3 owasp十大隐患中的其他内容 30816.2 sql注入漏洞攻击 30816.2.1 sql数据库与语句 31016.2.2 测试web应用程序,搜寻sql注入漏洞 31216.3 跨站脚本漏洞攻击 31716.3.1 “脚本”的含义 31716.3.2 跨站脚本的含义 318第17章 oip攻击 32317.1 voip的含义 32317.2 voip使用的协议 32417.2.1 sip 32417.2.2 megaco h.248 32517.2.3 h.323 32517.2.4 tls和dtls 32617.2.5 srtp 32717.2.6 zrtp 32717.3 voip攻击类型 32717.3.1 枚举 32817.3.2 sip口令破解 32817.3.3 窃听与分组捕获 32917.3.4 拒绝服务 32917.4 如何防范voip攻击 335第18章 scada攻击 33718.1 scada的含义 33718.2 scada使用的协议 33818.2.1 opc 33818.2.2 iccp 33818.2.3 modbus 33818.2.4 dnp3 33918.3 scada fuzzing测试 34018.3.1 使用autodafé进行scada fuzzing测试 34018.3.2 使用tftp daemon fuzzer进行scada fuzzing测试 34618.4 stuxnet恶意软件(网络恐怖主义新浪潮) 34918.5 防范scada攻击 349第ⅳ部分 漏洞分析 351第19章 被动分析 35319.1 道德的逆向工程 35319.2 使用逆向工程的原因 35419.2.1 逆向工程注意事项 35419.3 源代码分析 35519.3.1 源代码审计工具 35519.3.2 源代码审计工具的实用性 35719.3.3 手工源代码审计 35919.3.4 自动化源代码分析 36319.4 二进制分析 36519.4.1 二进制代码的手工审计 36519.4.2 自动化的二进制分析工具 376第20章 使用ida pro进行高级静态分析 38120.1 静态分析难点 38120.1.1 剥离的二进制文件 38120.1.2 静态链接程序和flair 38320.1.3 数据结构分析 38920.1.4 已编译的c++代码的诡异之处 39320.2 扩展ida pro 39620.2.1 idc脚本编程 39620.2.2 ida pro插件模块及ida pro sdk 39820.2.3 构建ida pro插件 40020.2.4 ida pro加载器及处理器模块 402第21章 高级逆向工程技术 40521.1 软件攻击的目的 40521.2 软件开发过程概述 40621.3 检测工具 40721.3.1 调试器 40721.3.2 代码覆盖分析工具 40921.3.3 统计分析工具 41021.3.4 流程分析工具 41021.3.5 内存使用监视工具 41221.4 模糊测试 41621.5 定制的模糊测试工具和技术 41721.5.1 一个简单的url模糊测试工具 41721.5.2 对未知协议进行模糊测试 42021.5.3 spike 42121.5.4 spike静态内容原语 42121.5.5 spike proxy 42421.5.6 sharefuzz 424第22章 客户端浏览器的漏洞攻击 42722.1 客户端软件漏洞的重要性 42722.1.1 客户端漏洞可以规避防火墙保护 42722.1.2 客户端应用程序经常在管理权限下运行 42822.1.3 客户端漏洞易于针对特定人群或机构目标 42822.2 internet explorer的安全概念 42922.2.1 activex控件 42922.2.2 internet explorer安全区域 43022.3 客户端漏洞攻击的历史与发展趋势 43122.3.1 客户端漏洞的流行 43122.3.2 历史上针对客户端攻击的著名漏洞43122.4 挖掘基于浏览器的新漏洞 43722.4.1 mangleme 43722.4.2 mozilla安全团队的模糊测试工具 44022.4.3 axenum 44122.4.4 axfuzz 44622.4.5 axman 44622.5 可利用的堆喷射技术 45122.5.1 internetexploiter 45122.6 防范客户端漏洞攻击 45222.6.1 同步更新安全补丁 45222.6.2 获取最新信息 45322.6.3 在缩减权限下运行internet应用 453第23章 攻击windows访问控制模型 45523.1 攻击访问控制机制的理由 45523.1.1 多数人不理解访问控制机制 45523.1.2 访问控制漏洞易于攻击 45623.1.3 访问控制漏洞数量巨大 45623.2 windows访问控制的工作机制 45623.2.1 安全标识符 45623.2.2 访问令牌 45723.2.3 安全描述符 46023.2.4 访问检查 46323.3 访问控制配置分析工具 46523.3.1 转储进程令牌 46623.3.2 转储安全描述符 46823.4 特殊sid、特殊访问权限和“禁止访问”问题 46923.4.1 特殊的sid46923.4.2 特殊访问权限 47123.4.3 “禁止访问”的原理 47223.5 访问控制引起的提权漏洞 47723.6 各种对象类型的攻击模式 47823.6.1 服务攻击 47823.6.2 windows注册表dacl攻击 48423.6.3 目录dacl攻击 48823.6.4 文件dacl攻击 49323.7 其他对象类型的枚举方法 49723.7.1 共享内存段 49723.7.2 命名管道 49823.7.3 进程 49923.7.4 其他已命名的内核对象(信号量、互斥锁、事件、设备) 500第24章 智能模糊测试框架sulley 50324.1 协议分析 50324.2 sulley模糊测试框架 50424.2.1 安装sulley 50524.2.2 强大的模糊测试工具 50524.2.3 块结构 50724.2.4 监视进程中的错误 51124.2.5 监视网络流量 51224.2.6 控制vmware 51224.2.7 综述 51324.2.8 崩溃事件的事后分析 51524.2.9 网络使用分析 51624.2.10 进一步研究 517第25章 漏洞的可利用性和漏洞攻击程序 51925.1 漏洞的可利用性 51925.1.1 通过调试分析可利用性 52025.1.2 初始分析 52025.2 理解漏洞攻击问题 52425.2.1 先决条件和后置条件 52425.2.2 可重复性 52525.3 构造漏洞攻击程序有效载荷的有关考虑 53325.3.1 漏洞攻击程序有效载荷的协议元素 53325.3.2 缓冲区的方向 53425.3.3 自毁式shellcode 53425.4 对问题进行归档 53525.4.1 背景知识 53525.4.2 环境 53625.4.3 研究结果 536第26章 关闭漏洞:缓解问题 53726.1 各种缓解方案 53726.1.1 端口碰撞技术 53726.1.2 迁移 53826.2 打补丁 53926.2.1 对源代码打补丁的注意事项 53926.2.2 给二进制程序打补丁的注意事项 54126.2.3 二进制变异 54526.2.4 第三方打补丁方案 549第ⅴ部分 恶意软件分析 551第27章 收集恶意软件和初步分析 55327.1 恶意软件 55327.1.1 恶意软件类型 55327.1.2 恶意软件的防护技术 55427.2 蜜网技术的最新发展趋势 55527.2.1 蜜罐 55527.2.2 蜜网 55527.2.3 为什么要使用蜜罐 55527.2.4 蜜罐的局限性 55627.2.5 低交互性蜜罐 55627.2.6 高交互性蜜罐 55727.2.7 蜜网的类型 55727.2.8 规避vmware检测技术 55927.3 捕捉恶意软件:设置陷阱 56127.3.1 vmware宿主机设置 56127.3.2 vmware客户机设置 56127.3.3 使用nepenthes进行捕获 56227.4 恶意软件的初步分析 56327.4.1 静态分析 56327.4.2 动态分析 56527.4.3 norman sandbox技术 569第28章 破解恶意软件 57328.1 恶意软件的发展趋势 57328.1.1 嵌入的组件 57328.1.2 加密的使用 57428.1.3 用户空间隐藏技术 57428.1.4 rootkit技术的应用57428.1.5 持久化措施 57528.2 对恶意软件进行去混淆处理 57528.2.1 加壳程序基础 57628.2.2 对二进制文件进行 脱壳处理 57728.3 对恶意软件进行逆向工程 58428.3.1 恶意软件的设置阶段 58428.3.2 恶意软件的运行阶段 58428.3.3 自动化的恶意软件分析 585本信息来源: