為什麼殺毒軟體都喜歡編譯的程序
⑴ 易語言編寫的程序為什麼容易被報毒
「編譯」出來的程序幾乎不報毒,而「靜態編譯」出來的軟體就很容易報毒。
編譯:直接將代碼轉換為程序,程序運行時要求系統或該軟體運行目錄里有該程序運行時所需要的庫文件!靜態編譯:將代碼編譯為程序,再將軟體運行所需要的壓進程序里,當程序運行時釋放庫文件,再從指定位置讀取調用庫文件,使程序運行!
「靜態編譯」的程序就很類似於捆綁木馬:1.程序運行,2.釋放文件,3.調用文件!幾乎都差不多把!只是最後一步有點差別!
「靜態編譯」的程序裡面含有程序運行所需要的庫文件,運行程序後就像是捆綁了東西的文件,釋放文件愛你,並調用!使殺毒軟體誤以為程序是被捆綁後的的軟體,所以報毒!而現在大多數人都應該用的是靜態編譯,所以就有了網上鬧得沸沸揚揚的「易語言誤報門」了!
「編譯」出來的程序,直接調用庫文件,類似於C++,而靜態編譯則需要先將庫文件釋放出來在加以調用,就類似於「winrar自解壓」,使得殺毒軟體檢測到程序里包含了其他文件,而且程序里也含有將文件釋放出來的命令,觸動殺毒神經,所導致殺毒誤認為是捆綁了木馬的程序,故殺毒軟體認為「靜態編譯」出來的程序是病毒!
⑵ 為什麼易語言寫的程序都會被殺
易語言的程序為何常被殺毒軟體誤殺?答案在於其歷史背景、程序結構認知不足與病毒撰寫者的不當利用。
首先,易語言雖在5.0版本後改用靜態編譯和VC鏈接庫,其結構接近標准程序,然而,過往遺留的"支持庫"問題,導致殺毒軟體在識別程序時難以准確判斷。
其次,主流殺毒軟體廠商對於易語言程序結構的認知不夠深入,一旦發現疑似易語言特徵,便會採取通殺策略,缺乏精準識別能力。
再者,國內部分易語言愛好者可能濫用其特性撰寫病毒,使得病毒特徵碼與雲查殺系統對易語言程序產生警覺,誤判為可疑程序。
特別提到360殺毒軟體的識別機制較為粗放,面對易語言程序往往缺乏細致判斷,僅憑特徵即進行殺毒處理。
為使易語言避免此類誤殺,需要網友們的廣泛使用與支持,通過增加使用人群,促使殺軟廠商深入研究易語言,提升識別准確率。
實現易語言成為主流編程語言的目標,不僅需要網友們的努力,還需要開發者吳濤等人的持續優化與推廣。
⑶ 怎樣讓易語言編的程序不被殺毒軟體當成病毒
易語言本身極容易被殺毒軟體報毒,尤其是360安全衛士(或360殺毒軟體),因此使用易語言編寫軟體需要做相應的信任或排除工作。
易誤報的原因:主要是因為易語言的使用簡單,因此有許多人是用易語言來開發軟體程序,這其中也包括了很多居心叵測的人,他們同樣會使用這樣一種簡單方便的語言來設計各種帶有惡意功能的程序或軟體,比如:病毒、木馬等。由於以易語言設計的程序的特殊結構以及必須攜帶運行庫(支持庫)的特殊性,因此不少殺毒軟體在提取病毒特徵碼時常常選擇(或誤選擇)這些本身無害的支持庫作為目標樣本或者選擇易語言程序的特殊結構作為樣本,因此導致所有使用易語言設計的程序都攜帶有這些錯誤的特徵碼,從而導致殺毒軟體誤報正常程序。
處理方法:通常的處理方法是採用對編譯好的程序進行加殼加密處理的辦法,然而這樣處理很多時候反而會加大誤報可能性,推薦的做法是採用靜態編譯易語言程序或者在安全軟體中信任或排除以語言編寫的程序。如果你設計的軟體需要提供給其他人使用,那麼告知他們軟體是安全的,要求他們設定信任或排除即可。