減少蜜罐bug之UnicodeDecodeError

背景

昨天,在開發(fā)onvif蜜罐的過程中,發(fā)現(xiàn)針對3702端口的掃描行為,payload并不是十分規(guī)矩,蜜罐收到部分掃描的數(shù)據(jù)包后,會(huì)出現(xiàn)崩潰的情況。排查發(fā)現(xiàn)傳入的掃描數(shù)據(jù)為:b'<\xaa>\x00'.decode(),報(bào)錯(cuò)信息為:UnicodeDecodeError: 'utf-8' codec can't decode byte 0xaa in position 1: invalid start byte。

回憶之前做MQTT蜜罐時(shí)遇到的十六進(jìn)制數(shù)據(jù)解碼出錯(cuò)的問題,立刻想到了,網(wǎng)絡(luò)中對蜜罐的掃描行為,不僅有ascii的編碼方式,也存在十六進(jìn)制的掃描方式。蜜罐需要做的是,盡量減少報(bào)錯(cuò)和崩潰,記錄下盡可能多的信息。

TODO

其實(shí),TCP和UDP類型的蜜罐在解碼過程中,最好使用try做好解碼的錯(cuò)誤控制,完全就可以避免這種問題產(chǎn)生。

try:
    onvif_info_dict["data"] = data.decode("ascii")
except UnicodeDecodeError:
    onvif_info_dict["data"] = ''.join(['%02X ' % b for b in data])
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容