首页 > 其他分享 >了解checksec显示的各种参数和保护

了解checksec显示的各种参数和保护

时间:2024-12-04 21:12:02浏览次数:4  
标签:只读 RELRO 随机化 保护 参数 checksec got 溢出

image

Arch:内核(32位/64位)

RELRO

在Linux系统安全领域数据可以写的存储区就会是攻击的目标,尤其是存储函数指针的区域。所以在安全防护的角度来说尽量减少可写的存储区域对安全会有极大的好处.
GCC, GNU linker以及Glibc-dynamic linker一起配合实现了一种叫做relro的技术: read only relocation。大概实现就是由linker指定binary的一块经过dynamic linker处理过 relocation之后的区域为只读.
RELRO重定位段只读保护分为以下三个等级:

  • NO RELRO:保护未开的情况,所有重定位段均可写,包括.dynamic、.got、.got.plt;
  • Partial RELRO:部分开启保护,其为GCC编译的默认配置。.dynamic、.got被标记为只读,并且会强制地将ELF的内部数据段 .got ,.got.plt等放到外部数据段 .data、.bss之前,即防止程序数据段溢出改变内部数据段的值,从而劫持程序控制流。虽然.got标记为只读,但是.got.plt仍然可写,即仍然可以改写GOT表劫持程序控制流;
  • Full RELRO:继承Partial RELRO的所有保护,并且.got.plt也被标为只读。此时延迟绑定技术被禁止,所有的外部函数地址将在程序装载时解析、装入,并标记为只读,不可更改。此时不需要link_map以及dl_runtime_resolve函数,则GOT表中这两项数据均置为0,此时ret2dlresolve技术最关键的两项数据丢失,并且GOT表不可写。

介绍RELRO与Pwn:https://bbs.kanxue.com/thread-282512.htm

Stack(栈检查)

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

NX

NX即No-eXecute(不可执行)的意思,NX(DEP)的基本原理是将数据所在内存页标识为不可执行,当程序溢出成功转入shellcode时,程序会尝试在数据页面上执行指令,此时CPU就会抛出异常,而不是去执行恶意指令。

PIE

一般情况下NX(Windows平台上称其为DEP)和地址空间分布随机化(ASLR)会同时工作。内存地址随机化机制(address space layout randomization),有以下三种情况
0 - 表示关闭进程地址空间随机化。
1 - 表示将mmap的基址,stack和vdso页面随机化。
2 - 表示在1的基础上增加堆(heap)的随机化。
可以防范基于Ret2libc方式的针对DEP的攻击。ASLR和DEP配合使用,能有效阻止攻击者在堆栈上运行恶意代码。
Built as PIE:位置独立的可执行区域(position-independent executables)。这样使得在利用缓冲溢出和移动操作系统中存在的其他内存崩溃缺陷时采用面向返回的编程(return-oriented programming)方法变得难得多。

Stripped

stripped:将程序中的符号表的信息剔除掉了,这样子编译出来的可执行文件体积比较小;
not stripped:则反之,但是就是因为其保留了这些信息,所以便于调试。

参考资料:
https://blog.csdn.net/panfengsoftware/article/details/7775108
https://blog.csdn.net/qq_44108455/article/details/104985351
https://www.testzero-wz.com/2022/03/05/Ret2dlresolve——从No-RELRO到FULL-RELRO/

标签:只读,RELRO,随机化,保护,参数,checksec,got,溢出
From: https://www.cnblogs.com/ljnljn/p/18587196

相关文章

  • 技术框架中MyBatis参数传递的学习
    MyBatis参数传递总结MyBatis参数传递#{}方式情况一:Mapper映射器接口方法参数只有一个且为基本类型接口方法:publicList<UserEntity>selectUserByAge(intage);映射结果:<selectid="selectUserByAge"resultMap="userResultMap">select*fromtb_userwhereag......
  • 参数传递进阶*args和**kwargs
    '''函数的参数传递进阶:在python中,所有的函数,在传入参数的时候,参数都会变成*args和**kwargs两种形态1.*args表示以元组的形态*表示参数基于元组的形态进行接受和解析。根本意义上就是拆包。将元组中的元素拆包成不同的数据,转为参数传入*......
  • NVR接入录像回放平台EasyCVR视频分析设备平台安防摄像机里的视频采集参数有什么意义
    在安防领域,摄像机图像质量的优劣直接影响监控效果,而图像质量的好坏不仅取决于DSP处理器和图像传感器(sensor)的性能,还与厂家的视频、图像算法和技术积累紧密相关。因此,了解并调整摄像机中的视频图像采集相关概念参数,对于获得最佳图像视频效果至关重要。EasyCVR安防监控视频系统以其......
  • plus.webview.create( url, id, styles, extras )参数及说明
    plus.webview.create("xxx.html",//url:String类型,可选,新窗口加载的HTML页面地址.新打开Webview窗口要加载的HTML页面地址,可支持本地地址和网络地址."xxx",//id:String类型,可选,新窗口的标识.窗口标识可用于在其它页面中通过getWebviewById来查找指定的窗口,为了保持窗口......
  • AI绘画进阶必看!9种 Midjourney 常用后缀参数!
    最近[AI]绘画真的越来越火了啦,开始有越来越多的设计师将Midjourney用到自己的设计工作流中,让它们生成各种设计灵感或素材。在使用Midjourney生成图片的时候,除了提示词(Prompt)要写好之外,后缀参数(Parameters)也非常重要,它们一般加在提示词后,可以帮我们更准确地控制图像的生......
  • (即插即用模块-Convolution部分) 四、(2023) RefConv 重参数化重聚焦卷积
    文章目录1、Re-parameterizedRefocusingConvolution2、代码实现paper:RefConv:Re-parameterizedRefocusingConvolutionforPowerfulConvNetsCode:https://github.com/Aiolus-X/RefConv1、Re-parameterizedRefocusingConvolution论文首先分析了传统卷积......
  • 1.1 Beginner Level学习之“了解 ROS 服务和参数”(第七节)
    学习大纲:1.ROS服务ROS服务是一种节点之间的通信方式,允许一个节点发送请求并接收响应。它采用的是同步机制,即一个节点会发送请求,等待另一个节点处理并返回结果。这个机制适合需要及时反馈的情况。rosservice是ROS提供的一个工具,专门用来与服务进行交互。它可以列出、查......
  • 瞧瞧别人家的参数校验,那叫一个优雅!
    前言对于开发人员来说,对用户输入的参数或者系统参数做校验,是日常工作之一。很多小伙伴在写接口的时候,可能都会碰到一个问题:参数校验应该怎么写?比如,开发一个用户注册接口,需要校验以下条件:用户名不能为空,长度在3到20个字符之间;密码不能为空,长度至少为8个字符;年龄必须是......
  • 高斯光束束腰测量和厄米-高斯光束的可调m,n参数仿真及强度测量方案
    clear;closeall;clc;%%参数设定%光学参数lambda=632.8e-9;%波长(单位:米)w0=1e-3;%光束腰半径(单位:米)z=10;%传播距离(单位:米)%模式阶数m=3;%x方向的模式阶数n=1;%y方向的模式......
  • 智慧工地算法视频分析服务器安全帽安全服检测:安防设备中的网络参数都分别代表什么?
    在探讨视频智能分析系统的广泛应用于网络安防设备的核心参数时,不可避免地要深入了解其背后的技术支撑与配置细节。这一系统,凭借其强大的视频接入与查看、智能分析、任务调度等功能,已经在工厂、工地、社区等多个场景中展现出了卓越的性能与价值。而网络安防设备,作为这一系统的基石,......