草庐IT

图像安全

全部标签

go - 从指针并发读取是否安全?

我正在开发一个图片uploader,并希望同时将图片调整为不同的大小。一旦我将文件作为[]byte读取,我就会将该缓冲区的引用传递给正在同时运行的调整大小函数。这样安全吗?我在想通过传递一个大文件的引用来由调整大小函数读取会节省我的内存,并发会节省我的时间。谢谢! 最佳答案 只读数据通常适合并发访问,但在传递引用(指针、slice、映射等)时必须非常小心。今天,当您还在阅读时,也许没有人在修改它们,但明天可能有人会。如果这是一次性脚本,您会没事的。但如果它是更大程序的一部分,我建议通过明智地保护并发访问来使您的代码面向future。

go - 在 Go 模板中显示可变图像

我在Go网络应用程序中使用一个模板,它应该根据访问者来自哪个国家/地区显示图像。图片我用的是FileServerhttp.Handle("/images/",http.StripPrefix("/images/",http.FileServer(http.Dir("images"))))在模板中传递了变量国家,因此应用程序知道要显示哪个标志。但是,由于某种原因,我传递的字符串添加了%0a,这导致img的src错误。预期的输出应该是以下代码用于抓取国家字符串resp3,err:=http.Get("https://ipinfo.io/country")iferr!=nil{fmt.Pri

在 Windows 10 64 位分割错误上使用 Fitz 将 PDF 转换为图像

我正在OSX和Windows(VM)上编译以下程序packagemainimport("fmt"fitz"github.com/gen2brain/go-fitz")funcmain(){doc,err:=fitz.New("ML-XX-XX-XX.000_REV1.pdf")iferr!=nil{panic(err)}fmt.Println("finished")deferdoc.Close()}在OSX上这运行得非常好,在Windows上我得到一个段错误,并且输出消息(在命令提示符中)为exitstatus3221225477谷歌搜索似乎是缓冲区溢出,但不完全确定如何调试/处理它。

go - 发送前调整图像大小

我想要一个带有gin的路由,它将发送图像(jpeg)作为响应,但我不想发送保存到磁盘的原始图像,而是先调整它的大小(缩略图大小)。到目前为止,我可以使用c.File(filepathstring)发送图像,但这不允许我调整图像的大小。有什么方法可以做到这一点而不必在磁盘上创建新文件吗? 最佳答案 是的,您可以使用内置包"image"调整它的大小,我刚刚为您构建了它,具有不同的调整大小选项和字节/纯图像输出,选择您想要的。我过去没有使用过这个特定的包,所以欢迎对这段代码进行任何更正/建议。代码:packagemainimport("b

go - 我如何使用接口(interface)定义安全划分并反射(reflect)?

我想定义一个安全分区,例如:funcsafeDivide(a,binterface{})interface{}{ifb==0{return0}returna/b}很明显,这个功能是行不通的。我们不能划分界面。一种解决方案是判断输入的类型并进行除法。switchreflect.ValueOf(x).Kind(){casereflect.Int://balabala...虽然看起来很多余,但我必须处理每一个案子。那么我是否可以使用反射来保证输入的类型?我试过reflect.TypeOf()但失败了。顺便说一句,我注意到了这一点:a:=uint32(0)ifZero(a)//outputs"

go - 在 Go 中安全地获取 slice 的一部分

我知道您可以通过以下方式在Go中获取slice的一部分test:=[]int{0,1,2,3,4}subsection:=test[:2]但是如果你尝试类似的东西subsectionError:=test[:10]你会得到一个越界错误。目前我正在做类似的事情length:=10iflen(test)为了避免这个错误,但是有更好的方法吗?这对我来说感觉很老套,但话又说回来,Go通常似乎是一种非常明确的语言。 最佳答案 在Go中,答案通常是在函数或方法中隐藏丑陋之处。例如,一个min函数,packagemainimport"fmt"fu

http.Get() 从 url 获取图像并写入 GridFS

我想从url请求图像并将该图像写入mongoDbGridFS数据库。我得到的唯一可行方法是将请求的正文保存到操作系统上的文件中,然后再次打开它。...response,err:=http.Get("https://via.placeholder.com/350x150")deferresponse.Body.Close()file,_:=os.Create("file-name-placeholder.jpg")b,_:=io.Copy(file,response.Body)file.Close()file,err=os.Open("file-name-placeholder.jpg"

go - 如何优雅地使 slice 追加安全

slice:=[]int{10,20,30,40,50,60}newSlice:=slice[2:4:5]fmt.Printf("oldsliceis%d\n",slice)fmt.Printf("newsliceis%d\n",newSlice)newSlice=append(newSlice,70)fmt.Printf("oldsliceis%d\n",slice)fmt.Printf("newsliceis%d\n",newSlice)newSlice=append(newSlice,80)fmt.Printf("oldsliceis%d\n",slice)fmt.Printf(

image - Go GC 似乎没有收集我未引用的图像加载指针?

关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭4年前。Improvethisquestion我正在使用OpenGL使用Go开发一个项目,并且拥有通过go/image库加载图像文件的代码。这个函数没有留下永久指针,然后我离开了函数的范围。我希望这段内存在下一个GC周期中被清除,但它似乎没有。我希望了解go的人能帮我看看为什么图像没有被清除。代码要点:https://gist.github.com/gjh33/62a75ccde6a7d849311804d31d7ee9ff不调用此方法时,内

Go 服务器在 arm64 上返回损坏的图像

我写了一个简单的HTTP图像服务器:go/src/demo/demo.go:packagemainimport("net/http""github.com/gorilla/mux")funcmain(){router:=mux.NewRouter()router.HandleFunc("/foobar",func(whttp.ResponseWriter,r*http.Request){http.ServeFile(w,r,"/home/foobar/test.jpg")})http.ListenAndServe(":5000",router)}我编译它(PWD=$HOME/go/sr