导言
C语言,自创始以来,到现在经久不衰。虽然C你只好自己造轮子,由于C语言允许直接访问物理地址,可以直接对硬件进行操作,因此它既具有高级语言的功能,又具有低级语言的特性。所以有可移植的汇编之称。
可是也在这些直接对内存的访问,导致了危险的发生。
有了自由也就多了混乱 ————某斯基
那些危险的函数们
gets()
第一位公共敌人就是是 gets(),永远不要使用 gets()。该函数从标准输入读入用户输入的一行文本,它在遇到 EOF 字符或换行字符之前,不会停止读入文本。也就是:gets() 根本不执行边界检查。因此,使用 gets() 总是有可能使任何缓冲区溢出。
如以下代码:
char *p = (char *) malloc(8);
gets(p);
printf("%s",p);
free(p);
return 0;
效果如下
可见,gets()这个函数可以在不经意间溢出任何的缓冲区0.0
所以,还是老话:永远不要使用 gets()!
那么怎么办呢?可以用fget()来代替啊~
参数如下
fgets(buf, BUFSIZE, stdin);
这个用处和gets()一样,只是额外加入了限制接收长度的参数;
strcpy&strcat
strcpy()函数将源字符串复制到缓冲区。没有指定要复制字符的具体数目。复制字符的数目直接取决于源字符串中的数目。如果源字符串碰

C语言因其直接内存访问特性而具有危险的函数,如gets()和strcpy/strcat,它们可能导致缓冲区溢出。文章提醒开发者永远不要使用gets(),建议使用fgets()替代,并推荐使用strncpy()和strncat()来避免潜在的安全问题。
最低0.47元/天 解锁文章
728

被折叠的 条评论
为什么被折叠?



