python的常見命令注入威脅
ah!其實(shí)沒(méi)有標(biāo)題說(shuō)的那么嚴(yán)重!
不過(guò)下面可是我們開發(fā)產(chǎn)品初期的一些血淋淋的案例,更多的安全威脅可以看看北北同學(xué)的《python hack》PPT,里面提及了不只命令執(zhí)行的威脅,那些都是我們親身經(jīng)歷的代碼。
千萬(wàn)要記得執(zhí)行命令的時(shí)候,不要信任其他傳入數(shù)據(jù)就行了,既然意識(shí)到問(wèn)題,那么修復(fù)方法是多種多樣的。
在我們的系統(tǒng)中,多處出現(xiàn)問(wèn)題然后修修補(bǔ)補(bǔ)是不靠譜的,那么我們需要一個(gè)通用的安全執(zhí)行接口,這個(gè)接口過(guò)后更新進(jìn)來(lái)。
此外,我們?cè)陂_發(fā)新功能的時(shí)候,也要掌握安全編程的規(guī)范技巧,這些技巧不局限在命令執(zhí)行安全。
總結(jié)了一下,就是一下幾點(diǎn)要素啦:
•命令執(zhí)行的字符串不要去拼接輸入的參數(shù),非要拼接的話,要對(duì)輸入?yún)?shù)進(jìn)行白名單過(guò)濾
•對(duì)傳入的參數(shù)一定要做類型校驗(yàn),例如知道是數(shù)字型的,就int測(cè)試一下,會(huì)安全許多
•對(duì)于拼接串,也要嚴(yán)格一些,例如int類型參數(shù)的拼接,對(duì)于參數(shù)要用%d,不要%s。
•使用subprocess來(lái)傳入多個(gè)參數(shù),就可以防止命令行注入
拿我們?cè)?jīng)的代碼(當(dāng)時(shí)是最新版=,=時(shí)過(guò)境遷了)存在的bug來(lái)做教程:
示例1(變量沒(méi)過(guò)濾):
a.py
site變量其實(shí)是個(gè)url格式的串,未經(jīng)過(guò)濾。由于老版本中site格式?jīng)]有出現(xiàn)問(wèn)題,新版本支持url格式,就可以傳入各種符號(hào)了。
cmd = 'python /a.py --task_id=%s --site=%s -b' % (taski, site)
示例2(不牢靠的過(guò)濾):
util/update.py
downloadFile函數(shù)盡管對(duì)fileName使用了過(guò)濾,但繞過(guò)的方法很多。
linux下面的命令分隔方法非常多,黑名單法是不牢靠的。
fileName = downloadInfo[0]
fileName = fileName.replace(';','').replace('&','') #過(guò)濾文件名
localMd5 = os.popen('md5sum %s%s' %(path,fileName)).read()
修復(fù)的方法就是對(duì)fileName進(jìn)行白名單格式檢查,比如,只允許出現(xiàn)字符數(shù)字以及.。
示例3(不安全的格式化字符串):
b.py
target是個(gè)url格式的串,未經(jīng)過(guò)濾。并且還有潛在威脅,deep使用了%s,其實(shí)它必須是個(gè)int,使用%d才對(duì),假如以后有機(jī)會(huì)感染deep變量,那就xxoo了。
cmd = 'python b.py --task_id "%s" -s %s --deep %s --check_level %s -b' %(taski,target,deep,check_level)
示例4(無(wú)法利用的命令注入):
c.py
site_report函數(shù),tid參數(shù)未經(jīng)格式化,目前無(wú)法利用是因?yàn)橛幸粋€(gè)查詢數(shù)據(jù)庫(kù)的語(yǔ)句:
get_object_or_404(Task, get_domain_query(request), id=tid)#這里會(huì)讓帶了特殊符號(hào)的tid查不到記錄,所以變?yōu)?04,暫時(shí)保護(hù)了位于下文的cmd拼接。
一旦該語(yǔ)句變更,就會(huì)導(dǎo)致新的命令注入漏洞
cmd = 'sh /opt/report %s >/tmp/export_report.log 2>&1' % tid
相關(guān)文章
django 開發(fā)忘記密碼通過(guò)郵箱找回功能示例
這篇文章主要介紹了django 開發(fā)忘記密碼通過(guò)郵箱找回功能示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-04-04Python實(shí)現(xiàn)簡(jiǎn)單購(gòu)物車小程序
這篇文章主要為大家詳細(xì)介紹了Python實(shí)現(xiàn)簡(jiǎn)單購(gòu)物車小程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02Django把SQLite數(shù)據(jù)庫(kù)轉(zhuǎn)換為Mysql數(shù)據(jù)庫(kù)的過(guò)程
之前我們默認(rèn)使用的是SQLite數(shù)據(jù)庫(kù),我們開發(fā)完成之后,里面有許多數(shù)據(jù),如果我們想轉(zhuǎn)換成Mysql數(shù)據(jù)庫(kù),那我們先得把舊數(shù)據(jù)從SQLite導(dǎo)出,然后再導(dǎo)入到新的Mysql數(shù)據(jù)庫(kù)里去,這篇文章主要介紹了Django如何把SQLite數(shù)據(jù)庫(kù)轉(zhuǎn)換為Mysql數(shù)據(jù)庫(kù),需要的朋友可以參考下2023-05-05基于Python實(shí)現(xiàn)定時(shí)自動(dòng)給微信好友發(fā)送天氣預(yù)報(bào)
這篇文章主要介紹了基于Python實(shí)現(xiàn)定時(shí)自動(dòng)給微信好友發(fā)送天氣預(yù)報(bào)的實(shí)現(xiàn)代碼,,需要的朋友可以參考下2018-10-10python切片中內(nèi)存的注意事項(xiàng)總結(jié)
在本篇文章里小編給大家整理的是一篇關(guān)于python切片中內(nèi)存的注意事項(xiàng)總結(jié)內(nèi)容,有需要的朋友們可以學(xué)習(xí)參考下。2021-08-08python爬蟲MeterSphere平臺(tái)執(zhí)行報(bào)告流程解析
這篇文章主要為大家介紹了python爬蟲MeterSphere平臺(tái)執(zhí)行報(bào)告流程解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12