您现在的位置是:网站首页> 编程资料编程资料
Golang 如何限制木马图片上传服务器的实例_Golang_
2023-05-26
377人已围观
简介 Golang 如何限制木马图片上传服务器的实例_Golang_
项目背景
自己开发了一个云对象存储服务,用于存储某个项目中所有的文件资源。
问题
在进行安全测试时,自己遇到了一个问题:无法限制木马病毒模拟的图片文件进行上传。看似是一个图片后缀的文件,其实是一个木马脚本。比如图片文件:muma.jpeg,我们使用 UltraEdit 编辑器打开这个文件,文件内容如下图所示:

然而,一个正常的 jpeg 图片文件的内容如下图所示:

解决
那么如何解决这个问题呢?毫无疑问,我们要做的就是区分正真的图片和木马图片。
经过我一顿猛如虎的调研,终于找到了解决办法,那就利用 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 }调用上述方法时,只需要传入图片路径和后缀类型,就可以校验文件的真实性。非常方便,本人已经验证通过。
到此这篇关于Golang 如何限制木马图片上传服务器的实例的文章就介绍到这了,更多相关Golang 限制木马图片上传 内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
您可能感兴趣的文章:
相关内容
- 详解golang 定时任务time.Sleep和time.Tick实现结果比较_Golang_
- golang结合mysql设置最大连接数和最大空闲连接数_Golang_
- 详解Golang Map中的key为什么是无序的_Golang_
- 深入理解go缓存库freecache的使用_Golang_
- Go语言切片常考的面试真题解析_Golang_
- Golang语言的多种变量声明方式与使用场景详解_Golang_
- Go语言标准输入输出库的基本使用教程_Golang_
- Go中groutine通信与context控制实例详解_Golang_
- Go语言io pipe源码分析详情_Golang_
- golang数组和切片作为参数和返回值的实现_Golang_
