linux程序的常用保护机制

18 篇文章 0 订阅

 

linux         NX    PIE

windows  DEP  ASLR

  • NX:-z execstack / -z noexecstack (关闭 / 开启)
  • Canary:-fno-stack-protector /-fstack-protector / -fstack-protector-all (关闭 / 开启 / 全开启)
  • PIE:-no-pie / -pie (关闭 / 开启)
  • RELRO:-z norelro / -z lazy / -z now (关闭 / 部分开启 / 完全开启)

 

 

(1)NX(DEP)

DEP是数据执行保护的英文缩写,全称为Data Execution Prevention。数据执行保护(DEP) 是一套软硬件技术,能够在内存上执行额外检查以帮助防止在系统上运行恶意代码。

NX即No-eXecute(不可执行)的意思,NX(DEP)的基本原理是将数据所在内存页标识为不可执行,当程序溢出成功转入shellcode时,程序会尝试在数据页面上执行指令,此时CPU就会抛出异常,而不是去执行恶意指令。DEP 的主要作用是阻止数据页(如默认的堆页、各种堆栈页以及内存池页)执行代码。

 

linux下开启了NX的以及windows下开启了DEP的程序堆栈是不可执行的

如果需要关闭NX选项,可以给gcc编译器添加-z execstack参数。

 

(2)ASLR

ASLR内存地址随机化机制(address space layout randomization)

ASLR只是随机化基地址,页内偏移不会发生变化

liunx下关闭PIE的命令如下:

1

sudo -s echo 0 > /proc/sys/kernel/randomize_va_space

 

(3)栈溢出保护(加canary)

栈溢出保护(加canary)是一种缓冲区溢出攻击缓解手段,当函数存在缓冲区溢出攻击漏洞时,攻击者可以覆盖栈上的返回地址来让shellcode能够得到执行。当启用栈保护后,函数开始执行的时候会先往栈里插入cookie信息,当函数真正返回的时候会验证cookie信息是否合法,如果不合法就停止程序运行。攻击者在覆盖返回地址的时候往往也会将cookie信息给覆盖掉,导致栈保护检查失败而阻止shellcode的执行。在Linux中我们将cookie信息称为canary

 

关闭该保护输入:  -fno-stack-protector

 

gcc在4.2版本中添加了-fstack-protector和-fstack-protector-all编译参数以支持栈保护功能,4.9新增了-fstack-protector-strong编译参数让保护的范围更广。以下是-fstack-protector和-fstack-protector-strong的区别:

 

参数gcc支持版本说明
-fstack-protector4.2只为局部变量中包含长度超过8-byte(含)的char数组的函数插入保护代码
-fstack-protector-strong4.9满足以下三个条件都会插入保护代码:1.局部变量的地址作为赋值语句的右值或函数参数;2.局部变量包含数组类型的局部变量,不管数组的长度;3.带register声明的局部变量

Linux系统中存在着三种类型的栈:

  1. 应用程序栈:工作在Ring3,由应用程序来维护;
  2. 内核进程上下文栈:工作在Ring0,由内核在创建线程的时候创建;
  3. 内核中断上下文栈:工作在Ring0,在内核初始化的时候给每个CPU核心创建一个。

参考:https://my.oschina.net/macwe/blog/610357

 

(4)RELRO

在Linux系统安全领域数据可以写的存储区就会是攻击的目标,尤其是存储函数指针的区域。 所以在安全防护的角度来说尽量减少可写的存储区域对安全会有极大的好处.

GCC, GNU linker以及Glibc-dynamic linker一起配合实现了一种叫做relro的技术: read only relocation。大概实现就是由linker指定binary的一块经过dynamic linker处理过 relocation之后的区域为只读.

设置符号重定向表格为只读或在程序启动时就解析并绑定所有动态符号,从而减少对GOT(Global Offset Table)攻击。RELRO为” Partial RELRO”,说明我们对GOT表具有写权限。

gcc编译:

1

2

3

4

gcc -o test test.c // 默认情况下,是Partial RELRO

gcc -z norelro -o test test.c // 关闭,即No RELRO

gcc -z lazy -o test test.c // 部分开启,即Partial RELRO

gcc -z now -o test test.c // 全部开启,即

参考:https://www.cnblogs.com/Spider-spiders/p/8798628.html

 

 

Set-UID 是Unix系统中的一个重要的安全机制。当一个Set-UID程序运行的时候,它被假设为具有拥有者的权限。例如,如果程序的拥有者是root,那么任何人运行这个程序时都会获得程序拥有者的权限。

Stack smashing是堆栈缓冲区溢出(stack buffer overflow)的一个时髦称谓。它表示利用代码中存在的缓冲区溢出bug而发起的攻击。在早期,这完全是程序员的责任,他们要确保代码中不存在缓冲区溢出的问题。但是随着时间推移,技术的不断发展,现在像gcc这样的编译器已经有编译选项用来确保缓冲区溢出问题不被攻击者利用来破坏系统或者程序。

 

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 《深入Linux设备驱动程序内核机制》是一本非常经典的Linux设备驱动程序内核开发方面的专业书籍。该书由深入浅出的方式,全面介绍了Linux设备驱动程序的基本知识、内核框架、字符设备驱动程序、块设备驱动程序以及网络设备驱动程序等内容。 该书首先详细介绍了Linux操作系统的内核架构和设备驱动程序的基本概念,让读者对Linux内核的组成、系统调用、进程管理等有一个清晰的了解。接着,该书介绍了设备驱动程序的开发流程和编写规范,并重点讲解了字符设备驱动程序的开发方法。通过具体的代码实例,读者可以深入了解字符设备的注册、读写操作以及地址映射等关键步骤。 此外,该书还涵盖了块设备驱动程序和网络设备驱动程序等领域的知识。块设备驱动程序的开发涉及磁盘操作、缓冲区管理等内容,而网络设备驱动程序的开发则包括套接字的初始化、数据传输等方面。通过学习这些内容,读者不仅可以掌握Linux设备驱动程序的内核机制,还能够应对更加复杂的设备驱动开发工作。 综上所述,《深入Linux设备驱动程序内核机制》是一本非常实用和权威的Linux设备驱动程序开发方面的书籍。通过阅读本书,读者可以系统地学习Linux设备驱动的原理和开发方法,提升自己在Linux内核开发领域的技能和水平。无论是对于初学者还是有一定经验的开发者来说,都是一本不可或缺的参考书。 ### 回答2: "深入Linux设备驱动程序内核机制"是一本非常重要的图书,主要介绍了Linux操作系统中的设备驱动程序开发原理和实践技巧。这本书非常适合那些对Linux设备驱动程序开发感兴趣的人阅读。 首先,这本书详细讲解了Linux设备驱动程序的内核机制。它介绍了设备驱动程序的基本概念、内核模块的加载和卸载、驱动程序的注册和注销、设备的访问和控制等重要知识点。通过深入了解这些机制,读者可以对设备驱动程序的工作原理有清晰的认识。 此外,这本书还对Linux设备模型进行了详细的解释。它介绍了字符设备、块设备和网络设备等不同类型的设备,并讲解了它们在内核中的实现方式和工作原理。同时,它还提供了许多实例和示例代码,方便读者理解和实践。 除了内核机制和设备模型,这本书还介绍了在Linux设备驱动程序开发过程中常用的工具和技术。比如,它详细介绍了调试技术、日志记录、内核模块参数传递等实用的开发技巧。这些内容对于提高驱动程序的稳定性和可靠性非常有帮助。 总之,"深入Linux设备驱动程序内核机制"是一本非常重要的图书,它深入探讨了Linux设备驱动程序的内核机制,提供了丰富的实例和示例代码,帮助读者更好地理解和应用设备驱动程序开发技术。无论是对于初学者还是有经验的开发者来说,这本书都是不可或缺的学习资料。 ### 回答3: 《深入Linux设备驱动程序内核机制》是一本在CSDN上提供的PDF文档,涵盖了Linux设备驱动程序的内核机制。本书主要介绍了Linux内核中设备驱动的基本知识、原理和设计方法。其中详细讲解了设备驱动程序的注册、驱动与设备的交互、设备的初始化和释放、设备操作的原理等内容。 该书着重介绍了字符设备驱动、块设备驱动和网络设备驱动等常见类型的设备驱动程序的内核实现机制。对于想要了解Linux设备驱动开发的开发人员来说,这本书提供了非常有价值的知识,可以帮助他们理解和掌握设备驱动程序的编写和调试技巧。 该书从理论和实践的角度出发,结合了大量的源代码示例和实际案例,使读者更好地理解和掌握设备驱动程序的内核机制。此外,书中还介绍了设备树和设备模型的相关知识,以及错误处理和调试技术。通过阅读和学习该书,读者可以更好地理解和应用Linux设备驱动程序的内核机制。 总之,《深入Linux设备驱动程序内核机制》这本PDF文档对于想要深入理解Linux设备驱动程序的人来说是非常有价值的资料。通过CSDN渠道获取该文档可以方便大家进行学习和参考。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

安安csdn

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值