| 摘要 | 第1-5页 |
| ABSTRACT | 第5-10页 |
| 第一章 绪论 | 第10-14页 |
| ·引言 | 第10-11页 |
| ·国内外研究现状 | 第11-12页 |
| ·论文主要工作 | 第12-13页 |
| ·论文组织结构 | 第13-14页 |
| 第二章 关于LKM的知识分析 | 第14-30页 |
| ·操作系统知识 | 第14-25页 |
| ·硬件基础 | 第14-16页 |
| ·Linux内核分析 | 第16-25页 |
| ·Linux操作系统的可加载内核机制 | 第25-29页 |
| ·LKM模块概述 | 第25-26页 |
| ·模块(Module)的载入 | 第26-27页 |
| ·模块(Module)的卸载 | 第27-28页 |
| ·Linux2.6系列内核的模块加载 | 第28-29页 |
| ·本章小结 | 第29-30页 |
| 第三章 LKM攻击的分析与总结 | 第30-59页 |
| ·系统调用劫持 | 第30-37页 |
| ·直接使用sys_call_table的劫持 | 第30-31页 |
| ·不导出sys_call_table的劫持 | 第31-36页 |
| ·VFS调用的劫持 | 第36-37页 |
| ·IDT劫持 | 第37-42页 |
| ·一般中断劫持 | 第37-40页 |
| ·2.6内核下的改进 | 第40-42页 |
| ·LKM注入 | 第42-53页 |
| ·ELF文件格式 | 第42-44页 |
| ·注入的可行性分析 | 第44-46页 |
| ·.strtab节的修改 | 第46-49页 |
| ·代码插入的方法 | 第49-51页 |
| ·隐蔽性的保持 | 第51-52页 |
| ·2.6版内核下的改进 | 第52-53页 |
| ·模块隐藏机制 | 第53-54页 |
| ·安全性分析与总结 | 第54-58页 |
| ·模块的完整性 | 第55-56页 |
| ·模块信息管理 | 第56页 |
| ·模块的访问控制 | 第56-57页 |
| ·恶意模块检测 | 第57-58页 |
| ·本章小结 | 第58-59页 |
| 第四章 LSM对LKM安全的分析 | 第59-73页 |
| ·LSM的原理 | 第59-64页 |
| ·LSM的基本设计思想 | 第59-60页 |
| ·透明安全字段(Opaque Security Field) | 第60-61页 |
| ·安全钩子函数 | 第61-62页 |
| ·安全模块的注册与注销 | 第62-63页 |
| ·已实现的模型 | 第63-64页 |
| ·SELinux访问控制机制 | 第64-66页 |
| ·LSM框架对LKM安全的作用 | 第66-67页 |
| ·SELinux对LKM安全的作用 | 第67-68页 |
| ·LSM对LKM安全的不足 | 第68-69页 |
| ·LSM的扩展方法 | 第69-72页 |
| ·本章小结 | 第72-73页 |
| 第五章 LKM安全的改进 | 第73-89页 |
| ·改进的目标 | 第73页 |
| ·扩展LSM框架 | 第73-76页 |
| ·Hooks放置的地点 | 第76-80页 |
| ·子模块的设计与实现 | 第80-82页 |
| ·整体模块设计方案 | 第80页 |
| ·各子模块功能说明 | 第80-82页 |
| ·实验测试 | 第82-88页 |
| ·实验环境 | 第82-83页 |
| ·功能测试 | 第83-88页 |
| ·本章小结 | 第88-89页 |
| 第六章 结论 | 第89-91页 |
| ·全文总结 | 第89页 |
| ·今后的工作和展望 | 第89-91页 |
| 致谢 | 第91-92页 |
| 参考文献 | 第92-96页 |
| 攻硕期间取得的研究成果 | 第96页 |