草庐IT

tcp_header

全部标签

linux - 从 TCP 连接获取 HTTP header

我正在用golang为Linux编写类似应用程序的代理程序。该应用程序在执行时将监听所有TCP连接并将它们重定向到代理服务器地址。在应用程序之间还向HTTPheader添加了“Proxy-Authorisation:Basic...”header。当我看到TCPheader时,我无法获得HTTPheader。我哪里出错了或如何提取HTTP数据?还有其他方法可以实现吗? 最佳答案 我也是golang的新手,但就从tcp套接字获取HTTP数据而言,下面的代码对我有用。packagemainimport"net"import"fmt"im

http - TCP 是同一主机中 Go 程序之间通信的最佳方法吗?

假设我有两个独立的Go程序在我的本地主机上运行,​​就性能而言,TCP是否是在两个程序之间传输数据的最佳方法? 最佳答案 简短的回答是否定的。TCP/IP堆栈很慢,尤其是TCP部分。因此,就性能而言,您最好使用本地进程间通信方法,例如应用程序或Unix套接字之间的共享内存。如果您必须使用网络堆栈进行通信(例如,您计划在主机之间移动应用程序),那么UDP或原始套接字是性能方面的最佳选择。只有当你:必须使用网络并且您需要一个可靠的通信channel,那么TCP是一个不错的选择。因此,只需浏览您的要求并确定它是否是最适合您的方法。

在 go 中解析 set-cookie header

我想将POST请求返回的cookie解析到cookiejar中,但找不到任何相关文档。那里有一些好的包裹吗?或者我该怎么做?编辑:它不是重复的。我问的是解析set-cookie返回的cookie,而不是仅仅通过发送来发送cookie。 最佳答案 不希望您手动构建cookiejar。而是在发出请求时将http.CookieJar接口(interface)传递给http.Client,cookie将自动为您处理。更多信息请参见thisSOanswer基本上,您将使用http客户端和此处的cookiejar实现:https://golan

go - 使用 Golang 获取 GRPC 请求和响应 header

尝试使用golang语言提取GRPC请求和响应header。有没有办法提取标题。 最佳答案 您可以使用元数据客户端一元:varheader,trailermetadata.MD//variabletostoreheaderandtrailerr,err:=client.SomeRPC(ctx,someRequest,grpc.Header(&header),//willretrieveheadergrpc.Trailer(&trailer),//willretrievetrailer)//dosomethingwithheadera

Go 中的 HTTP header 名称

我需要收集一堆httpheader。我找到的唯一方法是*http.Request.Header.Get("%headername%")%headername%是否有任何名称约定?例如在PHP中所有键都是大写的,单词用下划线分隔。 最佳答案 header中的键在canonicalformat中.Header方法为您规范化key。如果应用程序直接访问header映射,则应用程序负责确保key采用规范格式。规范格式的header名称的一些示例是:Content-LengthEtag您可以使用范围查找所有header:forname,val

go - 在 TCP 连接的端口上发送 UDP 数据包

关闭。这个问题需要detailsorclarity.它目前不接受答案。想改善这个问题吗?通过editingthispost添加详细信息并澄清问题.3年前关闭。Improvethisquestion我有一个GolangTCP服务器,即net.TCPConn,连接在一个端口上,除了TCP流之外,它还必须接收UDP数据包并以UDP数据包进行响应。传入的UDP数据包在服务器上弹出(来自net.TCPConn.Read()),但我不知道如何再次发回UDP数据包。所有UDP写入方法仅适用于net.UDPConn.net.UDPConn.WriteMsgUDP()诱人地谈论它是应用于连接的还是非连接

for-loop - 从 go 中的 tcp 连接读取数据是否需要 for 循环?

有一个func来处理tcp连接:for{select{caseconn:=我的问题是,如果你使用for循环,你必须写return否则它会是一个死循环。如果它返回,这个handleClient函数将只执行一次。所以这里不需要for,对吧?我们仍然可以在没有for的情况下读取所有数据,这是正确的思考方式吗? 最佳答案 服务器处理连接的常见模式可能是funchandleClient(connnet.Conn){r:=bufio.NewReader(conn)for{line,err:=r.ReadBytes(byte('\n'))swit

unit-testing - 尝试在 TCP 监听器上提供服务时,由于超时,Go 测试模棱两可地失败

我有这个单元测试:funcTestServer(t*testing.T){db:=prepareDBConn(t)deferdb.Close()lis:=bufconn.Listen(1024*1024)t.Logf("Openedlistener:%v",lis)grpcServer:=grpc.NewServer(withUnaryInterceptor(),)t.Logf("Openedgrpcserver:%v",grpcServer)signKey:=getSignKey()ifsignKey==nil{t.Fatal("FailedtofindorparseRSApriva

sockets - 通过 TCP 处理多个客户端

好的,我刚开始学习golang,到目前为止我很喜欢它。但是我没有发现他们的文档适合入门者,这是我的问题。我想编写接受连接并向客户端写入内容的小服务器程序。到目前为止没有问题。然而,一旦它获得真正的功能,我就需要能够处理多个客户端,我认为这也是goroutines的一个很好的练习。listener,error:=net.Listen("tcp",remote)con,error:=listener.Accept()gohandleClient(&con);funchandleClient(con*net.Conn){我已经删除了大部分代码。问题是,无论我尝试什么,我都无法通过con。co

Golang tcp客户端服务器程序

我可以做服务器程序或客户端程序,但我不知道如何做客户端/服务器程序。有人知道这段代码有什么问题吗?谢谢。packagemainimport("net""os""bufio""io")funcmain(){listen,_:=net.Listen("tcp","localhost:9001")dial,_:=net.Dial("tcp","localhost:9002")scanner:=bufio.NewScanner(os.Stdin)forscanner.Scan(){conn,_:=listen.Accept()ifscanner.Text()=="a"{conn.Close()