一段漏洞百出的代码

来源:互联网 发布:sql语句获取当前时间 编辑:程序博客网 时间:2024/04/28 02:12

下面是一段漏洞百出的代码:

#include <string.h>
#include 
<stdio.h>

class Base
{
  
private:
    
char * name;
  
public:
    Base(
char * className)
    
{
        name 
= new char[strlen(className)];
        strcpy(name, className);
    }


    
~Base()
    
{
        delete name;
    }


    
char * copyName()
    
{
        
char newname [256];
        strcpy(newname, name);
        
return newname;
    }


    
virtual char * getName()
    
{
        
return name;
    }


    
static void print(Base base)
    
{
        printf(
"name: %s /n" , base.name);
    }

}
;

class Subclass : public Base
{
  
public:
    Subclass(
char * className) : Base(className)
    
{
    }

}
;

int main()
{
    Base 
* pBase = new Subclass("test");
    Base::print(
*pBase);
    printf(
"name: %s /n", pBase->getName());
    printf(
"new name: %s/n ", pBase->copyName());

    
return 0;
}

 这是经过修改的:

 

#include <string.h>
#include <stdio.h>
class Base
{
  private:
    char * name;
  public:
    Base(char * className = NULL)
    {
        name = new char[strlen(className)+1];
        strcpy(name, className);
  name[strlen(className)] = '/0';
    }
 Base(Base& base)
 {
  if ( base.name )
  {
   name = new char[strlen(base.name)+1];
   strcpy(name, base.name);
   name[strlen(base.name)] = '/0';
  }
  else
   name = '/0';
 }
    ~Base()
    {
  if ( name )
   delete []name;
    }
    char * copyName()
    {
        char* newname = new char[strlen(name)+1];
        strcpy(newname, name);
  newname[strlen(name)] = '/0';
        return newname;
    }
    virtual char * getName()
    {
        return name;
    }
    static void print(Base base)
    {
        printf("name: %s/n" , base.name);
    }
};
class Subclass : public Base
{
  public:
    Subclass(char * className) : Base(className)
    {
    }
};
int main()
{
    Base * pBase = new Subclass("test");
    Base::print(*pBase);
    printf("name: %s/n", pBase->getName());
 char * tempName = pBase->copyName();
    printf("new name: %s/n", tempName);
 delete []tempName;
 delete pBase;
    return 0;
}

 

 

原创粉丝点击