为什么杀毒软件都喜欢编译的程序
⑴ 易语言编写的程序为什么容易被报毒
“编译”出来的程序几乎不报毒,而“静态编译”出来的软件就很容易报毒。
编译:直接将代码转换为程序,程序运行时要求系统或该软件运行目录里有该程序运行时所需要的库文件!静态编译:将代码编译为程序,再将软件运行所需要的压进程序里,当程序运行时释放库文件,再从指定位置读取调用库文件,使程序运行!
“静态编译”的程序就很类似于捆绑木马:1.程序运行,2.释放文件,3.调用文件!几乎都差不多把!只是最后一步有点差别!
“静态编译”的程序里面含有程序运行所需要的库文件,运行程序后就像是捆绑了东西的文件,释放文件爱你,并调用!使杀毒软件误以为程序是被捆绑后的的软件,所以报毒!而现在大多数人都应该用的是静态编译,所以就有了网上闹得沸沸扬扬的“易语言误报门”了!
“编译”出来的程序,直接调用库文件,类似于C++,而静态编译则需要先将库文件释放出来在加以调用,就类似于“winrar自解压”,使得杀毒软件检测到程序里包含了其他文件,而且程序里也含有将文件释放出来的命令,触动杀毒神经,所导致杀毒误认为是捆绑了木马的程序,故杀毒软件认为“静态编译”出来的程序是病毒!
⑵ 为什么易语言写的程序都会被杀
易语言的程序为何常被杀毒软件误杀?答案在于其历史背景、程序结构认知不足与病毒撰写者的不当利用。
首先,易语言虽在5.0版本后改用静态编译和VC链接库,其结构接近标准程序,然而,过往遗留的"支持库"问题,导致杀毒软件在识别程序时难以准确判断。
其次,主流杀毒软件厂商对于易语言程序结构的认知不够深入,一旦发现疑似易语言特征,便会采取通杀策略,缺乏精准识别能力。
再者,国内部分易语言爱好者可能滥用其特性撰写病毒,使得病毒特征码与云查杀系统对易语言程序产生警觉,误判为可疑程序。
特别提到360杀毒软件的识别机制较为粗放,面对易语言程序往往缺乏细致判断,仅凭特征即进行杀毒处理。
为使易语言避免此类误杀,需要网友们的广泛使用与支持,通过增加使用人群,促使杀软厂商深入研究易语言,提升识别准确率。
实现易语言成为主流编程语言的目标,不仅需要网友们的努力,还需要开发者吴涛等人的持续优化与推广。
⑶ 怎样让易语言编的程序不被杀毒软件当成病毒
易语言本身极容易被杀毒软件报毒,尤其是360安全卫士(或360杀毒软件),因此使用易语言编写软件需要做相应的信任或排除工作。
易误报的原因:主要是因为易语言的使用简单,因此有许多人是用易语言来开发软件程序,这其中也包括了很多居心叵测的人,他们同样会使用这样一种简单方便的语言来设计各种带有恶意功能的程序或软件,比如:病毒、木马等。由于以易语言设计的程序的特殊结构以及必须携带运行库(支持库)的特殊性,因此不少杀毒软件在提取病毒特征码时常常选择(或误选择)这些本身无害的支持库作为目标样本或者选择易语言程序的特殊结构作为样本,因此导致所有使用易语言设计的程序都携带有这些错误的特征码,从而导致杀毒软件误报正常程序。
处理方法:通常的处理方法是采用对编译好的程序进行加壳加密处理的办法,然而这样处理很多时候反而会加大误报可能性,推荐的做法是采用静态编译易语言程序或者在安全软件中信任或排除以语言编写的程序。如果你设计的软件需要提供给其他人使用,那么告知他们软件是安全的,要求他们设定信任或排除即可。