Golang 如何限制木馬圖片上傳服務(wù)器的實(shí)例
項(xiàng)目背景
自己開發(fā)了一個(gè)云對象存儲服務(wù),用于存儲某個(gè)項(xiàng)目中所有的文件資源。
問題
在進(jìn)行安全測試時(shí),自己遇到了一個(gè)問題:無法限制木馬病毒模擬的圖片文件進(jìn)行上傳。看似是一個(gè)圖片后綴的文件,其實(shí)是一個(gè)木馬腳本。比如圖片文件:muma.jpeg,我們使用 UltraEdit 編輯器打開這個(gè)文件,文件內(nèi)容如下圖所示:
然而,一個(gè)正常的 jpeg 圖片文件的內(nèi)容如下圖所示:
解決
那么如何解決這個(gè)問題呢?毫無疑問,我們要做的就是區(qū)分正真的圖片和木馬圖片。
經(jīng)過我一頓猛如虎的調(diào)研,終于找到了解決辦法,那就利用 Golang 語言的標(biāo)準(zhǔn)庫 —— image。
但是,有一個(gè)問題,image 庫并沒有支持所有圖片類型的校驗(yàn),目前僅支持 jpeg、gif、png 三種圖片格式。我們封裝一個(gè)方法,同時(shí)支持三種圖片格式的真實(shí)性校驗(yàn)。
參考代碼如下:
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("校驗(yàn)文件類型失敗 %s", err.Error()) return "", err } return "", nil }
調(diào)用上述方法時(shí),只需要傳入圖片路徑和后綴類型,就可以校驗(yàn)文件的真實(shí)性。非常方便,本人已經(jīng)驗(yàn)證通過。
到此這篇關(guān)于Golang 如何限制木馬圖片上傳服務(wù)器的實(shí)例的文章就介紹到這了,更多相關(guān)Golang 限制木馬圖片上傳 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- golang?gin框架實(shí)現(xiàn)大文件的流式上傳功能
- Golang實(shí)現(xiàn)圖片上傳功能的示例代碼
- golang?Gin上傳文件返回前端及中間件實(shí)現(xiàn)示例
- Golang實(shí)現(xiàn)http文件上傳小功能的案例
- golang實(shí)現(xiàn)的文件上傳下載小工具
- golang語言實(shí)現(xiàn)的文件上傳與文件下載功能示例
- Golang實(shí)現(xiàn)異步上傳文件支持進(jìn)度條查詢的方法
- Golang+Android基于HttpURLConnection實(shí)現(xiàn)的文件上傳功能示例
- golang簡單獲取上傳文件大小的實(shí)現(xiàn)代碼
- golang實(shí)現(xiàn)文件上傳并轉(zhuǎn)存數(shù)據(jù)庫功能
相關(guān)文章
Golang中Channel實(shí)戰(zhàn)技巧與一些說明
channel是Go語言內(nèi)建的first-class類型,也是Go語言與眾不同的特性之一,下面這篇文章主要給大家介紹了關(guān)于Golang中Channel實(shí)戰(zhàn)技巧與一些說明的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11Go錯(cuò)誤和異常CGO?fallthrough處理教程詳解
這篇文章主要為大家介紹了Go錯(cuò)誤和異常CGO?fallthrough使用教程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08go使用Gin框架利用阿里云實(shí)現(xiàn)短信驗(yàn)證碼功能
這篇文章主要介紹了go使用Gin框架利用阿里云實(shí)現(xiàn)短信驗(yàn)證碼,使用json配置文件及配置文件解析,編寫路由controller層,本文通過代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2021-08-08Go整合captcha實(shí)現(xiàn)驗(yàn)證碼功能
最近在使用Go語言搞一個(gè)用戶登錄&注冊的功能,我們油然會產(chǎn)生一種增加驗(yàn)證碼的想法。后來在GitHub上找到了這個(gè)名叫captcha的插件,于是就利用文檔進(jìn)行了初步的學(xué)習(xí),并融入到自己的項(xiàng)目中,整個(gè)過程下來感覺這個(gè)插件的設(shè)計(jì)非常巧妙2023-03-03