Golang 如何限制木馬圖片上傳服務器的實例
項目背景
自己開發(fā)了一個云對象存儲服務,用于存儲某個項目中所有的文件資源。
問題
在進行安全測試時,自己遇到了一個問題:無法限制木馬病毒模擬的圖片文件進行上傳。看似是一個圖片后綴的文件,其實是一個木馬腳本。比如圖片文件:muma.jpeg,我們使用 UltraEdit 編輯器打開這個文件,文件內(nèi)容如下圖所示:
然而,一個正常的 jpeg 圖片文件的內(nèi)容如下圖所示:
解決
那么如何解決這個問題呢?毫無疑問,我們要做的就是區(qū)分正真的圖片和木馬圖片。
經(jīng)過我一頓猛如虎的調(diào)研,終于找到了解決辦法,那就利用 Golang 語言的標準庫 —— image。
但是,有一個問題,image 庫并沒有支持所有圖片類型的校驗,目前僅支持 jpeg、gif、png 三種圖片格式。我們封裝一個方法,同時支持三種圖片格式的真實性校驗。
參考代碼如下:
func CheckImageFile(path, style string) (string, error) { f, err := os.Open(path) if err != nil { fmt.Errorf("打開文件失敗 %s", err.Error()) } switch strings.ToUpper(style) { case "JPG", "JPEG": _, err = jpeg.Decode(f) case "PNG": _, err = png.Decode(f) case "GIF": _, err = gif.Decode(f) } if err != nil { fmt.Errorf("校驗文件類型失敗 %s", err.Error()) return "", err } return "", nil }
調(diào)用上述方法時,只需要傳入圖片路徑和后綴類型,就可以校驗文件的真實性。非常方便,本人已經(jīng)驗證通過。
到此這篇關于Golang 如何限制木馬圖片上傳服務器的實例的文章就介紹到這了,更多相關Golang 限制木馬圖片上傳 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
- golang?gin框架實現(xiàn)大文件的流式上傳功能
- Golang實現(xiàn)圖片上傳功能的示例代碼
- golang?Gin上傳文件返回前端及中間件實現(xiàn)示例
- Golang實現(xiàn)http文件上傳小功能的案例
- golang實現(xiàn)的文件上傳下載小工具
- golang語言實現(xiàn)的文件上傳與文件下載功能示例
- Golang實現(xiàn)異步上傳文件支持進度條查詢的方法
- Golang+Android基于HttpURLConnection實現(xiàn)的文件上傳功能示例
- golang簡單獲取上傳文件大小的實現(xiàn)代碼
- golang實現(xiàn)文件上傳并轉(zhuǎn)存數(shù)據(jù)庫功能