printf直接参数访问

argument_index$

是一个十进制整数,用于表明要格式化第几个参数。第一个参数由 "1$" 引用,第二个参数由 "2$" 引用,依此类推。

#include <stdio.h>

int main()
{
int a = 0x123,b = 0x456,d = 0x888;
printf("%2\$x",a,b,d);
}



moonflow@moonflow-ThinkPad-Edge:~/apuetrans$ ./format 
456

这个特性在格式化串漏洞中可以方便的访问到需要的内存数据

 

把0x08064d55处的字符串读出来
$'\x55\x4d\x06\x08%272$' 可以读出0x08064d55处的字符串
通过在字符串的开头指定内存地址,以及使用"直接参数访问“,可以从内存中指定的位置获取数据

 

转载于:https://www.cnblogs.com/moonflow/archive/2012/04/25/2469272.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值