草庐IT

net-your-first-application

全部标签

json - 使用 net/http 在 PUT "Body length 0"上出现错误

我在我的应用程序上使用这个GoAPI客户端https://github.com/heroku/docker-registry-client使用Go与dockerregistry交互。这种情况是在使用包“net/http”进行PUT请求时在内部遇到一些问题。当我运行以下代码时,出现错误Puturl:http:ContentLength=2821withBodylength0。所以看起来net/httpClient.Do()函数没有得到我在函数的某个点设置的主体。但是正如您在下面的代码中看到的那样,我仍然有我想要在[]byte中发送的JSON内容。body,err:=manifest.Ma

go - 为 GOOGLE_APPLICATION_CREDENTIALS 设置凭据的替代方法

我有一个使用GoogleVisionAPI和GoogleVideointelligenceAPI的Go应用程序。为了输入我的凭据,我设置了名为GOOGLE_APPLICATION_CREDENTIALS的环境变量。为此,我为此变量分配了一个文件路径,该路径指向存储我的凭据的目录。问题:我的凭证最初没有保存在文件中。相反,它们被分配给我的应用程序中的一个字符串变量。作为解决方法,我将该值存储到一个临时文件,然后将其路径分配给GOOGLE_APPLICATION_CREDENTIALS,如上所述。问题:是否可以在没有此文件的情况下为cloud.google.com/go/vision/ap

go - 使用系统调用调用 mono-2.0-sgen.dll 得到 "not a valid Win32 application"

我想通过Go使用附带的Mono框架执行HelloWorldConsole.exe。所以我想调用mono-2.0-sgen.dll函数“mono_main”来执行exe。mono-2.0-sgen.dll是适用于MSWindows的PE32可执行文件,see.但我收到错误“不是有效的Win32应用程序”_=os.Setenv("MONO_PATH",`\mono\lib\mono\4.5;C:\DEV\HelloWorldConsole\HelloWorldConsole\bin\Debug`)_=os.Setenv("MONO_CFG_DIR",`"C:\ProgramFiles(x8

go - 使用具有特定本地端口的 net.DialTimeout

我正在尝试使用特定的源IP端口,但net.DialTimeout没有laddr参数my_dial,err:=net.DialTimeout("tcp",addr,3*time.Second)conn:=tls.Client(my_dial,tlsconf)然后我查了下文档,唯一支持laddr的方法是:funcDialIP(networkstring,laddr,raddr*IPAddr)(*IPConn,error)但它返回的是net.IPConn而不是net.Conn。有什么想法吗? 最佳答案 Dial和DialTimeout只是

go - 允许超过内容类型 : application/json in gorilla

使用优秀的Gorillamux,我有一个特殊的API请求处理程序,使用application/json作为内容类型:apiRouter:=router.PathPrefix("/api").Headers("Content-Type","application/json").Subrouter()然而,有些用户喜欢提供的不仅仅是那个字符串,即application/json;字符集=UTF-8。设置此header值后,处理程序将返回404。通过允许json和任何字符集规范来处理此问题的最佳方法是什么? 最佳答案 使用正则表达式的其他

go - x/net/websocket 获取类似 *http.Request 的 cookie

我正在尝试获取一个cookie,就像*http.Request所做的那样(r.Cookie("cookie_key")),我如何在没有连接升级的情况下实现这一点(纯ws) 最佳答案 引用thiscommit,实际上你可以调用ws.Request().Cookie("guid") 关于go-x/net/websocket获取类似*http.Request的cookie,我们在StackOverflow上找到一个类似的问题: https://stackoverfl

go - 如何修复 `kafka: client has run out of available brokers to talk to (Is your cluster reachable?)` 错误

我正在开发一个应用程序,该应用程序从sqs队列中读取一条消息,对该数据执行一些操作,然后获取结果并将其发布到kafka主题。为了在本地进行测试,我想在我的docker构建中设置一个kafka图像。我目前能够使用docker-compose在本地启动aws-cli、localstack和我的应用程序的容器。另外,我也可以毫无问题地启动kafka和zookeper。我无法让我的应用程序与kafka通信。我试过使用两个单独的撰写文件,也尝试过网络。最后,我引用了:https://rmoff.net/2018/08/02/kafka-listeners-explained/。这是我的docke

go - net/http/transport.go 中的 Transport struct 在哪里实现 RoudTripper 接口(interface)

RoundTripper界面是这样的typeRoundTripperinterface{RoundTrip(*Request)(*Response,error)}内部net/http/transport.go我只能找到一个名为roundTrip(小写)的函数,所以我想知道这个structTransport在哪里实现RoundTripper接口(interface)? 最佳答案 您要查找的函数在https://golang.org/src/net/http/roundtrip.go中而不是https://golang.org/src/

http - 如何在 net/http 中为 HTTP2 配置帧大小

我正在尝试使用net/http库在HTTP/2服务器中将帧大小设置为16MB。默认大小为16KB。尝试以下:http2Server=http2.Server{MaxReadFrameSize:2但在客户端仍然得到16KB的帧大小(通过打印响应主体的长度验证)。有没有其他方法可以在客户端和服务器端设置最大帧大小? 最佳答案 2是~32MB,你可能想要1 关于http-如何在net/http中为HTTP2配置帧大小,我们在StackOverflow上找到一个类似的问题:

windows - Golang、net.TCPConn、SetReadTimeout?

我在Mac上创建了一个简单的Go应用程序,用于在TCP连接中写入和读取数据。我用过GAEGo版本。后来,我把那个程序移植到Windows上,我得到了这个错误:Connection.SetReadTimeoutundefined(type*net.TCPConnhasnofieldormethodSetReadTimeout)我猜netpackageinformationontheGolangwebsite仅描述GAE版本的包。我如何在非GAEGo版本中正确设置超时? 最佳答案 对于最新的每周(又名Go1RC2),必须使用net.Co