this program uses gets(), which is unsafe.
来源:互联网 发布:淘宝官网网站首页 编辑:程序博客网 时间:2024/05/22 15:58
遇到了一个有意思的提醒:this program uses gets(), which is unsafe.
gets()函数。
说道gets()函数,就要说道fgets()函数。
fgets()函数是从流stream中读入最多num个字符到字符数组str中,当遇到换行符时、或读到num-1个字符时停止。并且在结尾自动加上’\0’空字符。
gets()函数则是从标准输入stdin读取一个字符串,遇到换行或结束时候终止。不同于fgets,他没有指定num,所以需要注意字符数组str的大小。
fgets和gets之间没有宏定义的关系,彼此各自有自己的实现。那么为什么说gets函数不安全呢?因为蠕虫病毒的实现就是函数gets的“功劳”。gets函数的任务是从流中读入一个字符串。它的调用者会告诉它把读入的字符串放在什么地方。但是,gets()函数并不检查缓冲区大小,如果调用者提供了一个指向堆栈的指针,并且get()函数读入的字符数量超过了超过了缓冲区的空间大小,get()会愉快地将多出来的字符继续写入到堆栈中,这就覆盖了堆栈中原来的内容。
- int main(void)
- {
- char string[81];
- ……
- gets(string);
这样任何多出来的数据都会被写入堆栈。
总之,普遍的建议就是用fgets()函数完全替代gets()函数。
另外:各种编译器对于gets()的态度不一样,有的会直接封杀编译不通过,有的则是提示
转自:https://www.logcg.com/archives/148.html
0 0
- this program uses gets(), which is unsafe.
- this program uses gets(), which is unsafe.
- warning: this program uses gets(), which is unsafe.
- warning:this program uses gets(), which is unsafe
- c中使用gets() 提示warning: this program uses gets(), which is unsafe.
- C语言(Bug) warning: this program uses gets(), which is unsafe.
- This is C++ program
- compile c++ program which uses stl in ndk
- This is my first program
- This is a C++ program
- mysql 警告提示Unsafe statement .The statement is unsafe because it uses a LIMIT clause
- This is a C++ program.cpp
- 输出“This is a C++ program.”
- warning C4996: 'gets': This function or variable may be unsafe. Consider using gets_s instead.
- 警告 1 warning C4996: 'gets': This function or variable may be unsafe.类似情况
- System.NotSupportedException: This method explicitly uses CAS policy, which has been obsoleted by th
- This file is needed to run this program
- This site uses a plugin (application/baiducnff-activex)that is not supported 解决办法
- Inno Setup 判断.NET是否安装
- debian 7.0 (Wheezy) 源设置
- CF 592D(Super M-虚树直径)
- iscroll原理
- Java网络编程
- this program uses gets(), which is unsafe.
- 数据结构例程——二叉排序树
- 进程相关概念
- 包图
- AvalonDock 2.0+Caliburn.Micro+MahApps.Metro实现Metro风格插件式系统(一)
- Android网络编程中的Header中的用法
- QProcess:进程通信之无名管道
- 项目中常见的文件
- 第十二周项目二 输出出图G中每个顶点的出度