ubuntu中ASLR与gcc安全编译选项(简洁版)

ASLR

ASLR等级与说明
等级说明
0关闭
1保留 共享库 栈 mmap vdso随机化
2完全 1 基础上 brk() 分配的内存空间也将被随机化
ASLR等级查看
sysctl -n kernel.randomize_va_space

cat /proc/sys/kernel/randomize_va_space
ASLR修改
sysctl -w kernel.randomize_va_space=0

echo 0 > /proc/sys/kernel/randomize_va_space

gcc编译安全选项

PIE(代码段和数据段的随机)
效果编译选项
关闭低版本默认关闭 高版本-fno-pie -no-pie
可执行文件等级1-fpie -pie
可执行文件等级2fPIE -pie
共享库文件等级1-fpic
共享库文件等级2-fPIC
DEP/NX(数据不可执行保护)
效果编译选项
开启默认开启 -z noexecstack
关闭-z execstack
canary(栈溢出保护)
效果编译选项
禁止-fno-stack-protector
启用 针对部分char数组函数-fstack-protector
启用 全部函数-fstack-protector-all
FORTIFY(缓冲区溢出检查)
效果编译选项
关闭默认
开启 较弱检查 编译时检查-D_FORTIFY_SOURCE=1
开启 较强检查 运行时也检查-D_FORTIFY_SOURCE=2
RELRO(只读保护)
效果编译选项
关闭-z norelro
部分 Partial RELRO默认 -z lazy
全部-z now
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值