草庐IT

iOS安全

全部标签

go - 拆分io.Reader-使用ReadWriter吗?

假设以下示例:funcExecute(rio.Reader){//dosoemthing}funcBatchFromCSV(crcsv.Reader,batchSizeint){n:=0for{r,err:=cr.Read()iferr!=nil{iferr!=io.EOF{panic(err)}break}n=n+1//Execute()whenbatchSize==n}}有没有办法在不创建某种缓冲区,然后使用bytes/string.newreader()的情况下拆分传入的读取器?这是读写员的地方吗?如果是,如何实现readwriter? 最佳答案

http - 从 golang 中的 reader.io 对象获取属性

我是golang的新手,遇到了一些小问题:当我像这里这样发出http请求时,我得到了remoteApi给我一些响应:res,err:=http.DefaultClient.Do(req)响应的正文包含一些json,例如:{a:'hello'b:5c:[1,2,3]}我需要将“a”的值赋给其他变量。访问res.Body属性之一的最佳方式是什么?我尝试转换为json/string等但没有成功谢谢 最佳答案 像这样的东西应该可以工作:varsstruct{Astring}err:=json.NewDecoder(response.Body

google-app-engine - 在服务器端处理带有 "io.Pipe"的大文件上传

作为我学习过程的一部分,我最近开始了一项新的挑战,即使用golang创建一个照片马赛克Web应用程序。由于我计划将其托管在AppEngine上,因此我将其分为2个服务:1个用于处理图像上传,另一个用于处理图像。我在这里想要完成的是在接收到第一个字节后立即开始处理图像。在做我的研究时,我遇到了这个要点cryptix/client.go.我需要使用这种方法将请求读入io.Pipe,然后将其动态传输到我的图像处理服务,但我的谷歌搜索没有任何帮助:我想要Go时,只能看到GO客户端发送文件服务器接收文件。注意:这两个服务通过HTTP进行通信。我正在使用REST模式(无html形式:使用POSTM

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

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

Golang GUI fyne-io 帮忙设置?

我只是无法配置GUIfyne-io.gogetfyne.io/fyne出错了packagefyne.io/fyne:unrecognizedimportpath"fyne.io/fyne"(httpsfetch:Gethttps://fyne.io/fyne?go-get=1:dialtcp:lookupfyne.io:nosuchhost)JetBrains的IDE从导入安装它很好导入(“fyne.io/fyne/widget”“fyne.io/fyne/app”)然后在gorun出现错误exec:“gcc”:executablefilenotfoundin%PATH%安装TDM-G

go - coveralls.io 和 Golang 中的错误处理

我写了一个libraryforInstagramAPI并告诉coveralls.io检查我的存储库但coveralls.io告诉我,我的源代码中的所有错误处理程序都不好。seethis我怎样才能完美地处理错误并且coveralls.io说它很好:smile:sorryformyEnglish 最佳答案 我认为它试图告诉您您的测试没有涵盖该路径。这意味着您编写的测试可能只测试“快乐路径”,而不是进入那些错误处理分支。 关于go-coveralls.io和Golang中的错误处理,我们在St

go - 不能在 func 参数中使用 bytes.Buffer 作为 io.WriterAt 类型

今天在go上苦苦挣扎..我不得不问的第二个问题。我有2个测试写入函数Write(),它采用writerio.WriterAt和contentinterface{}.我正在处理为函数编写的(2)个测试,TestWriteSuccessful和TestWriteFail。我在测试这两个函数时得到的错误是:cannotuse&b(type*bytes.Buffer)astypeio.WriterAtinargumenttoWrite:问题什么实现了我可以在这些测试中替换bytes.Buffer以使测试正常运行的WriterAt?我尝试过的将b的类型更改为os.File-b.len()>0将失

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

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(