欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Golang 如何限制木马图片上传服务器的实例

程序员文章站 2023-01-14 14:01:06
项目背景自己开发了一个云对象存储服务,用于存储某个项目中所有的文件资源。问题在进行安全测试时,自己遇到了一个问题:无法限制木马病毒模拟的图片文件进行上传。看似是一个图片后缀的文件,其实是一个木马脚本。...

项目背景

自己开发了一个云对象存储服务,用于存储某个项目中所有的文件资源。

问题

在进行安全测试时,自己遇到了一个问题:无法限制木马病毒模拟的图片文件进行上传。看似是一个图片后缀的文件,其实是一个木马脚本。比如图片文件:muma.jpeg,我们使用 ultraedit 编辑器打开这个文件,文件内容如下图所示:

Golang 如何限制木马图片上传服务器的实例

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

Golang 如何限制木马图片上传服务器的实例

解决

那么如何解决这个问题呢?毫无疑问,我们要做的就是区分正真的图片和木马图片。

经过我一顿猛如虎的调研,终于找到了解决办法,那就利用 golang 语言的标准库 —— image。

但是,有一个问题,image 库并没有支持所有图片类型的校验,目前仅支持 jpeg、gif、png 三种图片格式。我们封装一个方法,同时支持三种图片格式的真实性校验。

参考代码如下:

调用上述方法时,只需要传入图片路径和后缀类型,就可以校验文件的真实性。非常方便,本人已经验证通过。

到此这篇关于golang 如何限制木马图片上传服务器的实例的文章就介绍到这了,更多相关golang 限制木马图片上传 内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!