设为首页  加入收藏  联系我们 繁體中文  

黑客软件:

  漏洞扫描 | 木马间谍 | 加密解密 | 远程控制 | 破坏攻击 | 杀毒软件 | 防火墙类 | OICQ专区 | 黑客必备 | 常用工具 | 网吧攻击
文章中心:   最新资讯 | 黑客技术 | 电脑基础 | 菜鸟文摘 | 网络安全 | 网络技巧 | QQ技巧 | OQ空间代码 | 免费资源 | 编程世界 | 建站技术
素材源码:   论坛相关 | ASP源码 | CGI 源码 | NET 源码 | PHP 源码 | 酷站素材 | 字体素材 | 图片素材 | 友情发布 | 网页模版 | 建站软件
教程动画:   黑客教程 | 黑客编程 | 网站入侵 | 菜鸟教程 | 入侵教程 | 破解教程 | 电子书籍 | 网页制作 | 高级会员 | 综合教程 | 本站原创


   

  您当前的位置:中华隐士黑客联盟 -> 编程世界 -> 黑客编程 -> 文章内容 [站内搜索]  

 
巧妙利用成员模板函数为类留下后门
作者:不详  来源:转载  发布时间:2007-5-1 17:07:00  发布人:heigeheapao

【编辑提示:本文内容仅供参考,切勿用于不当之处!】

如果你的类需要扩展功能,除了修改源码之外,你也可以从这个类派生一个类来对这个类作扩充。比如有如下一个类。

class cls
{
public:
  int fun( int a)
  {
    //一些处理
    return 0;
  }
};

类cls有一个函数fun能针对一个int型的数据进行一些必要的动作。现在假如,要对这个cls类进行功能扩充。让它能针对一个double型的数据进行一些动作。第一种扩充方法是修改类的源码如下:

class cls
{
public:
  int fun( int a)
  {
    //一些处理
    return 0;
  }
  int fun( double a)
  {
    // 一些处理
    return 0;
  }
};

经过对类cls源码的修改,cls现在有了针对的double功能了。可是这种改源码的方法。会影响到其它的使用到这个cls类的地方。为了降低这种影响,可以采用从cls类再派生新类的做法,如下:

class cls2: public cls
{
public:
  int fun( double a)
  {
    //一些处理
    return 0;
  }

};

经过对派生,现在cls2这个类扩展了cls的功能。现在cls2可以针对int和double两种数据类型而做必要的处理了。可是这种通过派生新类的扩展,不能使以前就使用cls的用户直接从中受益。这些用户想要使用这个新扩展的功能,就必需修改自己的代码来,添加对cls2的适应。

如果象上面的这种功能扩充,要是进行多几次的话,采用第一种方法,就会经历多次cls类的代码修改,采用第二种方法,就会产生多次派生过程。象cls3,cls4等等。而且采用第二种方法还有一个非常大的不足。那就是派生类不能访问基类的私有成员。假如扩充出来的功能在进行处理时要对cls中的一些私有成员有所依赖,就不能采用第二种扩展方法。

从以上的弊端来看,这两种功能扩展的方法都不是好方法。

下面我们再来说一种进行功能扩展的方法。要采用这种方法,就需要在cls类在设计时就留出扩展口。现在我们重新设计cls类如下:

class cls
{
public:
  //把要传入的数据的地址转为void型的,
  //用type来表明进行处理时要对arg进行什么样的转换
  int fun( void* arg, int type)
  {
    switch(type)
    {
    case 0:
      //做针对int型数据的处理
      break;
    default:
      break;
    }
    return 0;
  }
};

经过重新设计的cls类,现在要进行功能扩展的话,只需要在它的函数fun中多加一条case就行了,很方便了。但是这样的设计是脆弱的。函数fun的两个参数arg和type,非常的不安全,很容易出现搭配错误。看来我们还要寻找更好的办法。于是我们再次修改我们的cls类如下:

class cls
{
public:
  template< typename t>
  int fun( t& arg)
  {
    //一些处理
    return 0;
  }
};

这一次的cls类的模板成员函数fun,可以经得起功能扩充了。扩充它的途径是特化这个成员模板函数。例如现在要对cls进行针对double的处理的扩展,只需对fun进行double类型的特化如下。

template <>
int cls::fun(double& arg)
{
  //针对double的一些处理
  return 0;
}

特化的过程没有动过cls类的一分一毫,但我们的功能扩展却安全的完成了,这才是我们想要的方便的,安全的功能扩展方法。

[] [返回上一页] [打 印] [收 藏]
  [相关文章评论]    (评论内容只代表网友观点,与本站立场无关!) [更多评论...]
 

  记一次前所未有巧妙..
巧妙帮闪存杀毒的另..
用Word巧妙获取QQ聊..
巧妙防止QQ密码被盗..
关注细节量身定做 巧..
如何巧妙利用系统进..
推荐:如何巧妙利用系..
推荐:如何能巧妙从进..
巧妙设置 让天网防..
巧妙利用三招保护局..


 
免费获得Q币的最新方法
最新免费在线看的电影网站集绵
不用木马,轻松万能偷daoQQ号码
最新QQ空间4.0全屏版效果图!!
新免蟆Q秀,刷红钻的方法
黑客快速入门(强烈推荐)
QQ密码本地破解的原理和方法
18岁少女欲6000元卖处女身 救患血..
8款QQ空间免费开场动画
免费QQ蓝钻体验(附考试答案)
 
设置Web邮箱黑客警报器 防止财务.. 04-11
二行代码解决全部网页木马(含ifr.. 04-11
防止黑客根据PHP中的错误信息爆路.. 04-11
webshell下查找所有IIS站点配置... 04-11
终级win2003服务器安全配置篇! 04-11
解决“网际快车”和“迅雷”右键.. 04-11
英国电信(BT)被指监视36000余名互.. 04-11
用命令行开启或关闭 IP 安全策略.. 04-11
Firefox2狂占CPU解决办法 04-11
大水牛下载者手工清除的方法 04-11
 
关于本站 网站帮助 广告合作 下载声明 友情连接 网站地图 访客留言 论坛登录
〖中华隐士黑客联盟〗,Copyright © 2006-2010 WwW.Hack86.Com 闽ICP备:06023304号
站长:小质 QQ:771760,软件发布MAIL:Hack086@21cn.com