我正在構建一個允許用戶上傳PDF文件以供其他用戶下載的Web應用程序(python和Django)。如何防止用戶上傳嵌入在pdf中的病毒?PDF和Django中的病毒
更新: 我在使用clamcv的django片段中發現了此代碼。這會做這份工作嗎?
def clean_file(self):
file = self.cleaned_data.get('file', '')
#check a file in form for viruses
if file:
from tempfile import mkstemp
import pyclamav
import os
tmpfile = mkstemp()[1]
f = open(tmpfile, 'wb')
f.write(file.read())
f.close()
isvirus, name = pyclamav.scanfile(tmpfile)
os.unlink(tmpfile)
if isvirus:
raise forms.ValidationError(\
"WARNING! Virus \"%s\" was detected in this file. \
Check your system." % name)
return file
安裝了病毒掃描和上傳後,以及在存儲之前掃描的文件... –