当前位置: 首页 > news >正文

建设美妆企业网站武当王也

建设美妆企业网站,武当王也,汽车嵌入式软件开发,企业网站seo最好方法前言 这是一个系列文章#xff0c;之前已经介绍过一些二进制安全的基础知识#xff0c;这里就不过多重复提及#xff0c;不熟悉的同学可以去看看我之前写的文章 heap2 程序静态分析 https://exploit.education/protostar/heap-two/#include stdlib.h #include 之前已经介绍过一些二进制安全的基础知识这里就不过多重复提及不熟悉的同学可以去看看我之前写的文章 heap2 程序静态分析 https://exploit.education/protostar/heap-two/#include stdlib.h #include unistd.h #include string.h #include sys/types.h #include stdio.hstruct auth { #定义了一个名为 auth 的结构体char name[32]; #定义了一个名叫name的变量能存储32字节数据int auth; #定义了一个整数变量auth };struct auth *auth; #auth 指针用来指向 struct auth 类型的对象 char *service; #定义了一个service指针int main(int argc, char **argv) #主函数 {char line[128]; #定义了一个名叫line的变量能存储128字节数据while(1) { #一个无限循环printf([ auth %p, service %p ]\n, auth, service); #输出auth 和 service 指针的当前值if(fgets(line, sizeof(line), stdin) NULL) break; #获取我们输入如果读取失败就会退出if(strncmp(line, auth , 5) 0) { #如果输入auth进入if语句 auth malloc(sizeof(auth)); #给auth 结构体分配内存memset(auth, 0, sizeof(auth)); #将内存初始化为零if(strlen(line 5) 31) { #line 5即 auth 后面的字符串的长度小于31字符strcpy(auth-name, line 5); #它将被复制到 auth 结构体的 name 字段}}if(strncmp(line, reset, 5) 0) { #如果输入是 resetfree(auth); #释放掉auth结构体的内存}if(strncmp(line, service, 6) 0) { #如果输入以 service 开头service strdup(line 7); #程序将使用 strdup 函数复制 service 后面的字符串并将 service 指针指向这个新分配的副本}if(strncmp(line, login, 5) 0) { #如果输入是 loginif(auth-auth) { #程序将检查 auth 结构体的 auth 字段printf(you have logged in already!\n); #如果 auth 字段非零程序会打印一条消息表示用户已经登录} else {printf(please enter your password\n); #否则程序提示用户输入密码}}} }什么是use-after-free漏洞 Use-After-FreeUAF漏洞是一种内存安全漏洞发生在程序释放了一块内存之后再次错误地使用访问或操作这块内存的情况。这种漏洞通常出现在动态内存管理的环境中尤其是在使用手动内存管理如C和C语言的程序中较为常见。UAF漏洞可能导致程序行为异常、数据损坏、信息泄露甚至允许攻击者执行任意代码。 UAF漏洞发生的条件 内存释放程序通过某种机制例如C语言的free()函数释放了一块动态分配的内存。 错误重用在该内存被释放后程序中的某个部分尝试再次访问或使用这块已释放的内存。 内存再分配操作系统或内存管理器可能将已释放的内存块重新分配给其他请求导致原先的引用变得不可预测或危险。 演示 char *buffer malloc(100); // 分配100字节的内存 strcpy(buffer, sensitive data); // 将敏感数据复制到分配的内存中 free(buffer); // 释放内存// ... 程序的其他部分// 错误地重新使用了已释放的内存 printf(%s, buffer); // 尝试打印已释放内存中的数据在这个例子中buffer指针首先指向了一块分配的内存存储了一些敏感数据。随后这块内存被释放理应不再被访问。然而程序后面的部分错误地尝试访问这块已经释放的内存试图打印它的内容。这个操作可能导致未定义行为包括打印出随机数据、导致程序崩溃或更糟糕的情况 程序动态调试 这是一个类似于登陆程序的程序我们可以先看看程序的参数运行程序随便往堆里存放一些数据然后登陆 图中可以看到auth结构体的堆地址是0x804c008由于程序检查auth结构体指针的auth成员的值。这个成员是一个整型int用来表示用户是否已经认证非零值表示已认证零值表示未认证。 如果auth-auth的值为非零即用户已经通过认证则输出用户以登陆 这个程序存在use-after-free漏洞我们在输入reset释放auth结构体内存时指针并为重置为0这个auth结构体的指针还是指向0X804c008 输入service参数会执行strdup函数简单来说这个函数的作用是复制字符串然后会自动调用mallco函数来分配内存空间并返回指向这个新分配内存的指针也可以使用free函数释放调内存 随便输入一些值可以看见service的指针指向了0x804c008 为什么service的指针和auth的指针指向的是同一个地址呢聪明的同学可能已经知道了我们上一个步骤是执行了reset参数释放了auth结构体的空间现在又执行了service参数上面说过输入service参数会执行strdup函数简单来说这个函数的作用是复制字符串然后会自动调用mallco函数来分配内存空间并返回指向这个新分配内存的指针也可以使用free函数释放调内存 由于释放了auth结构体的空间程序给我们分配空间时使用了这个空闲的空间现在auth和service就指向了同一个地址这就是use-after-free漏洞漏洞点就发生在这 假设现在有一个内存空间A空间A是由root用户创建的可以以最高权限执行命令现在空间A被free掉了被程序标记为空闲空间现在user用户要创建一个内存空间由于A空间被标记为空闲空间所以程序会把A空间分配给user用户我们就可以用user用户操作root用户的空间执行越权的操作这就是UAFuse-after-free漏洞 现在我们用gdb调试程序用auth参数执行一次分配内存空间的操作 ctrlc中断程序然后查看程序映射的堆空间 info proc mappings可以看到堆空间为0x804c000-0x804d000现在我们查看堆空间的内容 我们也可以使用print参数详细显示存放的内容 现在可以看到我们输入的字符串A和后面的身份验证auth 0 我们在printf函数处下一个断点然后用commands参数在每一步操作停下来后自动的运行我们设置的命令可以更方便的展示堆空间的操作 echo -----------------------------------------------\n x/20wx 0x804c000 echo auth-------------------------------------------\n print *auth echo service----------------------------------------\n print *service echo -----------------------------------------------\n continue end运行程序使用auth参数来分配第一个堆空间 现在又有一个新问题为什么auth只有8个字节的空间不应该是32个字节4字节整数36字节空间吗 这是因为结构体为auth整数也叫auth而结构体auth的指针又叫auth程序计算auth的大小时计算的是auth变量的大小而不是struct auth的大小 因此auth被分配到的空间只有4字节大小malloc函数会将其对齐到8字节 现在来看看free函数是怎么运行的输入reset 可以看到我们之前写入的字符串都被清空了但是auth指针依然存在 现在我们用service参数写入一些字符串 可以看到auth的值也变成了AAA 身份验证int auth的地址是第32个字节后的四个字节 也就是图中选中的地方刚好分配三次service的空间就能覆盖刚刚我们以及执行了一次现在我们再执行两次service 现在身份验证的值变成了CCC已经不为0了现在我们输入login即可 成功登陆 我们也可以直接用service参数输入36个A来覆盖身份验证的地址 重新运行程序
http://www.zqtcl.cn/news/223824/

相关文章:

  • 成都网站建设方案服务旅游网站建设报价单
  • 京东网址seo排名查询工具
  • 南京制作网站速成班外贸营销信模板
  • 简单网站建设规划方案物联网网站设计
  • 做360网站官网还是百度四川平台网站建设方案
  • 做网站的主题有哪些精品课程网站建设情况
  • 帝国网站开发电商平台搭建
  • 建设工程网站tcwordpress 标题入库
  • 网站开发简直广州网站制作后缀
  • 上海短视频seo优化网站wordpress 构建知识库
  • 做的网站图片不显示2018做网站赚钱不
  • 国内建站平台网站建设是什么科目
  • 响应式个人网站psd建设银行网站联系电话
  • 大型网站开发实战品牌网站建设费用要多少
  • 昆山网站建设昆山html5制作手机端页面
  • 做网站的国标有哪些达州网络推广
  • 站内seo和站外seo区别wordpress演示数据
  • 建设旅游网站财务分析创意设计公司网站
  • 张家港网站优化wordpress调用图片上传
  • 做网站要商标吗房产网站 设计方案
  • 做网站的费用怎么做账客户案例 网站建设
  • 怎么查询网站的备案号城乡建设杂志网站
  • 婚恋网站哪家做的最好北斗导航2022最新版手机版
  • 别墅效果图网站重庆金融公司网站建设
  • 中兴能源建设有限公司网站企业营销策划及推广
  • 外贸英文网站制作WordPress对接微信公众号
  • 推广网站建设花费得多少钱哪些平台可以发布软文
  • wordpress网站检测购物app大全
  • 遵义建设厅官方网站 元丰兰州网站设计有限公司
  • 芜湖做网站的公司排名贵阳好的网站建设公司