请教2047的各位信息安全专家:任何格式的文件都有可能携带计算机病毒吗?
我有时候会想分享几个音频文件,有没有办法证明这些文件不是或不包含窃取信息或破坏软件系统的病毒?
请教2047的各位信息安全专家:任何格式的文件都有可能携带计算机病毒吗?
我有时候会想分享几个音频文件,有没有办法证明这些文件不是或不包含窃取信息或破坏软件系统的病毒?
任何格式的文件都有可能携带计算机病毒吗?
可执行文件才能携带病毒
有没有办法证明这些文件不是或不包含窃取信息或破坏软件系统的病毒?
可以用VirusTotal检测。参考编程随想的博文 在线查毒工具 VirusTotal 的 N 种玩法——从“误报/漏报”聊到“攻击者对它的利用”
js和py是可执行文件。计算机中的文件有的只包含数据,有的包含数据和指令。指令就是能被计算机执行的代码,比如exe文件本质上是一长串二进制代码。在Windows系统中包含exe、dll等后缀的文件是可执行文件;在Unix/Linux系统中任何文件都可以是可执行文件(主要看用户给不给执行权限),但只有真正包含指令的可执行文件会被计算机执行。
病毒只可能存在于包含指令的可执行文件中。计算机病毒本质上是恶意指令,通常嵌入在一些正常的指令中,只有当指令被计算机系统执行后病毒才能获得系统权限并且破坏系统。
像txt、jpg、mp3等纯数据文件不包含指令,自然不可能包含病毒。在Unix/Linux系统中有的可执行文件没有执行权限,即使这些可执行文件中包含病毒,只要没有执行的机会,病毒也不可能破坏系统。
有些包含病毒的可执行文件可能伪装成txt、jpg、mp3等纯数据文件骗用户执行。
证明与证明是不一样的,分两种情况:
1.向有技术知识的人证明:对于图像、音频视频,如果他实在不放心,可以让他先执行一次压缩或转码,这样处理后就算有病毒也被破坏了。
2.向无技术知识的人证明:你跟他讲原理没用,你用自己的名义证明没用,他要是不信你,你怎么说都没用。因此只能通过第三方机构,比如杀毒软件之类的,看他信谁信什么机构。
另外可以考虑使用一些可以在线播放的网站,或者自己搭建一个网站,只要他平时用浏览器看别的网站,就没理由不信你,除非你的信誉比一般人差并且能力比一般人强。
@SuperMild #175360 好的,谢谢
音频文件没必要证明; 证明音频文件是否包含病毒,这件事本身很荒谬。
按照thphd的说法,任何文件都有用软件打开的机会,如果用来读取该文件的应用软件有bug,例如thphd举的缓冲区溢出bug,那文件可以恶意地编写,以至于触发bug后可以执行任意代码(execute arbitrary code)。
现在计算机系统别说软件了,硬件上还有防御措施,禁止你执行溢出的代码。
而且其实编写相关的攻击文件难度是很大的,因为大部分文件不是单一软件打开的,例如音频文件,常见的播放器有许多种,如果某个bug只在某一播放器的某一版本中存在,那怎么有效地攻击大量的计算机呢?
我有时候会想分享几个音频文件,有没有办法证明这些文件不是或不包含窃取信息或破坏软件系统的病毒?
用杀毒软件扫描,是一种常见的“证明”方式,既然楼主这么问,我猜楼主关心的是能否“严格证明”,即能否100%排除一个音频文件为病毒的可能性。
在讨论这个问题之前,应该先定义什么是“病毒”,什么是“音频文件”。
有人说病毒是恶意程序,而音频文件不是程序,所以不可能是病毒,这种说法是错误的。
可执行文件才能携带病毒
其实音频文件也可以包含程序,所以也可以携带病毒,例如将病毒程序放在音频文件的metadata(作曲家名字)中,利用播放器程序的漏洞触发执行。
而病毒也可以伪装成音频文件,例如 song.mp3.exe。如果这病毒是手工打造,甚至不会被杀毒软件识别出来。在计算机系统中,所谓的可执行文件和不可执行文件,除文件名以外是没有任何区别的,实际上任何文件都可能是可执行文件。
换言之,任何文件内部都可能包含可执行程序。而可执行的定义也是模糊的,在windows上不可执行的文件,在别的系统上也许就可执行了。即便确定一个文件包含可执行程序,如果这个程序没有恶意,也不能说它是病毒。那怎么判断一个程序是否恶意呢?从源代码/机器码去判断?如何区分善意和恶意?
所以从文件本身去严格地证明一个文件没有携带可执行的恶意程序,是不可能实现的任务,杀毒软件也只能识别那些已经出了名的常见病毒。
正因如此,人们往往会借助其他渠道辅助判断。既然识别可执行程序很难,那就识别恶意,例如安全专家经常会说“不要打开来源不明的文件”,也就是把“来源不明”约等同于“恶意”。
最后补充一点,目前对信息安全威胁最大的不是病毒,而是木马。