内核snprintf的0x300数据访问异常

定义如下:char *p 没有赋初始值。
然后调用snprintf(“%s”, 100, p);是否可以把字符串控制在100个字符之内呢?
答案是否定的。
笔者就遇到过。
我们可以看一下实现:

int snprintf(char * buf, size_t size, const char *fmt, ...)
    =>i=vsnprintf(buf,size,fmt,args);
        =>for (; *fmt ; ++fmt)//fmt没有尾结束符就一直遍历
            ==>if (*fmt != '%') {//定位到 %格式化
                if (str < end)
                    *str = *fmt;
                ++str;
                continue;
            }
            ==>++fmt;       /* this also skips first '%' *///分析%后面的格式字符是什么
            ==>switch (*fmt)
                ====>case 's':
                        s = va_arg(args, char *);
                        if ((unsigned long)s < PAGE_SIZE)
                            s = "<NULL>";

                        len = strnlen(s, precision);//计算s的长度,如果s是一个野指针,那么后果将是灾难性的,s的结尾鬼才知道,可能落在未知权限的页,结果就是数据异常访问

                        if (!(flags & LEFT)) {
                            while (len < field_width--) {
                                if (str < end)
                                    *str = ' ';
                                ++str;
                            }
                        }
                        for (i = 0; i < len; ++i) {
                            if (str < end)
                                *str = *s;
                            ++str; ++s;
                        }
                        while (len < field_width--) {
                            if (str < end)
                                *str = ' ';
                            ++str;
                        }
                        continue;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值