qq_31078711 2017-04-24 10:54 采纳率: 0%
浏览 6041
已结题

Unchecked Input for Loop Condition

代码安全检查问题,这种问题如何解决啊,我看解决方式有两种:1.用户控制的数据避免for循环2.输入验证。完全没思路。我就是要遍历用户的数据啊,不然如何实现业务逻辑。请大神帮忙

  • 写回答

2条回答 默认 最新

  • threenewbee 2017-04-24 16:15
    关注

    http://cwe.mitre.org/data/definitions/606.html

    比如这个例子

     void iterate(int n){
    int i;
    for (i = 0; i < n; i++){
    foo();
    }
    }
    void iterateFoo()
    {
    unsigned int num;
    scanf("%u",&num);
    iterate(num);
    }
    

    如果用户输入-1,会导致死循环。
    所以你需要在循环前判断下n(输入验证),或者不把用户输入作为循环条件(.用户控制的数据避免for循环)

    评论

报告相同问题?