日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 >

python调用virustota接口api实现上传文件返回查毒结果

發(fā)布時(shí)間:2023/12/18 72 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python调用virustota接口api实现上传文件返回查毒结果 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

virustotal是一個(gè)可以檢測文件與url,以及接口ip病毒的網(wǎng)站,如果要訪問,可能要翻墻,這一就不詳解了。在網(wǎng)上查看相關(guān)的知識的話,都是python2的代碼,好多已經(jīng)不能用了。因此在這里我就分享一下python3調(diào)用virustotal的api接口實(shí)現(xiàn)本地文件上傳到該網(wǎng)站并返回查毒結(jié)果的功能。

這里一般是exe文件,如果有其他格式文件,就需要其他操作,這里先不講解。
下面是實(shí)現(xiàn)代碼,這里的apikey保密,大家可以自己去網(wǎng)站注冊,私有的api可能要聯(lián)系網(wǎng)站。

代碼如下:

#www.virustotal.com/vtapi/v2/import requests import jsondef getFileScanId(url,apikey,a,b):# /file/scan# /文件/掃描# 上傳并掃描文件# 限制為32MBparams = {'apikey': apikey}files = {'file': (a, open(b, 'rb'))}response = requests.post(url, files=files, params=params)my_scan_id = str(response.json()['scan_id'])return my_scan_iddef getFieReportResult(url,apikey,my_scan_id):#/file/report# /文件/報(bào)告# 檢索文件掃描報(bào)告#該resource參數(shù)可以是要獲取最新的病毒報(bào)告文件的MD5SHA-1SHA-256。#還可以指定/ file / scan端點(diǎn)scan_id返回的值。#如果allinfo參數(shù)設(shè)置為true除了返回防病毒結(jié)果之外的其他信息。get_params = {'apikey': apikey, 'resource': my_scan_id,'allinfo': '1'}response2 = requests.get(url, params=get_params)jsondata = json.loads(response2.text)with open("jsonResult.json","w") as f:json.dump(jsondata, f, indent=4)return jsondatadef getResult(json):result = {}for k,v in json["scans"].items():result[k] = v['detected']print(result)print("一共有{0}條殺毒數(shù)據(jù)".format(len(result)))with open("result.txt","w") as g:g.write(str(result))def main():file_name = input("請輸入文件名:")a = str(file_name)file_src = input("請輸入文件路徑:")b = str(file_src)url1 = 'https://www.virustotal.com/vtapi/v2/file/scan'url2 = "https://www.virustotal.com/vtapi/v2/file/report"#需要提供密鑰,否者會(huì)出現(xiàn)403錯(cuò)誤apikey = "保密"#獲得文件scan_idscan_id = getFileScanId(url1,apikey,a,b)#獲得返回的json結(jié)果并寫入result文件#getFieReportResult(url2, apikey, scan_id)json = getFieReportResult(url2,apikey,scan_id)getResult(json)if __name__ == '__main__':main()

結(jié)果如下:
如果是False,則是安全的;如果出現(xiàn)了True,這可能有病毒。
沒有病毒的文件:


有病毒的文件:

但有時(shí)可能會(huì)出現(xiàn):

這里就是沒有返回結(jié)果,為什么會(huì)這樣,看一下官方的api文檔的一些規(guī)則就知道了:


這段英文的意思是:
Public API限制為每分鐘4個(gè)請求。
Public API不得用于商業(yè)產(chǎn)品或服務(wù)。
Private API返回更多威脅數(shù)據(jù)并公開更多端點(diǎn)。
Private API由SLA管理,可確保數(shù)據(jù)準(zhǔn)備就緒。

原來我們的公共api只能夠這樣訪問了,不過這些就夠用了。如果大家想要一些高級功能的話,就可以聯(lián)系官方,獲得私有apikey,就可以獲得更多功能了。

總結(jié)

以上是生活随笔為你收集整理的python调用virustota接口api实现上传文件返回查毒结果的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。