sinat_24243075 2015-05-17 12:40 采纳率: 50%
浏览 1350
已采纳

缓冲溢出代码缝分析!!

#include
#include
#include
#include

const char card[] = "IDB_CARD_";

const char *card_4[] = { "SWORD_", "WAND_", "PENT_", "CUP_" };

const char *card_royal[] = { "KING", "KNAVE", "QUEEN", "KNIGHT" };

char *point_to_card[78] = { NULL };

int sort[78] = { 0 };//the card's sorting

int main()//this is a model to get name in dll ,it's ok
{
char current_name[20] = "0", num[2] = "0";
int count = 0, big_count = 0, card_count = 0;

int i;
strcpy(current_name, card);
for (big_count = 1; big_count <= 5; big_count++)
{
    if (big_count == 1)
    {
        for (count = 0; count <= 21; count++)
        {
            itoa(count, num, 10);
            strcat(current_name, num);
            point_to_card[card_count] = (char*)malloc(sizeof(char)*strlen(current_name));
            strcpy(point_to_card[card_count], current_name);
            strcpy(current_name, card);
            card_count++;
        }
    }
    else{
        for (count = 1; count <= 14; count++)
        {
            if (count <= 10)
            {
                strcat(current_name, card_4[big_count - 2]);
                itoa(count, num, 10);
                strcat(current_name, num);
                point_to_card[card_count] = (char*)malloc(sizeof(char)*strlen(current_name));
                strcpy(point_to_card[card_count], current_name);
                strcpy(current_name, card);
                card_count++;
            }

            else
            {
                strcat(current_name, card_4[big_count - 2]);
                strcat(current_name, card_royal[count - 11]);
                point_to_card[card_count] = (char*)malloc(sizeof(char)*strlen(current_name));
                strcpy(point_to_card[card_count], current_name);
                strcpy(current_name, card);
                card_count++;
            }
        }
    }
}

}
调试时会出现图片说明

  • 写回答

2条回答 默认 最新

  • Tiger_Zhao 2015-05-18 05:36
    关注

    num[2] 大小不够。
    内容("0"~"21")最多2个字符,字符串结束符 \0 在哪里?
    不就溢出了!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 关于#网络安全#的问题:求ensp的网络安全,不要步骤要完成版文件
  • ¥15 可否在不同线程中调用封装数据库操作的类
  • ¥20 使用Photon PUN2解决游戏得分同步的问题
  • ¥15 微带串馈天线阵列每个阵元宽度计算
  • ¥15 keil的map文件中Image component sizes各项意思
  • ¥20 求个正点原子stm32f407开发版的贪吃蛇游戏
  • ¥15 划分vlan后,链路不通了?
  • ¥20 求各位懂行的人,注册表能不能看到usb使用得具体信息,干了什么,传输了什么数据
  • ¥15 Vue3 大型图片数据拖动排序
  • ¥15 Centos / PETGEM