草庐IT

ssl_socket

全部标签

sockets - Golang - 为到不同服务器的多个连接扩展 websocket 客户端

我有一个websocket客户端。实际上,它比下面显示的基本代码复杂得多。我现在需要扩展此客户端代码以打开到多个服务器的连接。最终,从服务器接收到消息时需要执行的任务是相同的。处理这个问题的最佳方法是什么?正如我上面所说,接收消息时执行的实际代码比示例中显示的要复杂得多。packagemainimport("flag""log""net/url""os""os/signal""time""github.com/gorilla/websocket")varaddr=flag.String("addr","localhost:1234","httpserviceaddress")funcm

sockets - 无需使用 http.Serve 即可激活 Go TLS Socket 服务器服务

我有以下代码和systemd单元文件。我想要做的是激活监听器,而不必使用http.Serve来接受和接收传入连接。如果我将ln,err:=tls.Listen("tcp",listen,config)更改为ln,err:=activation.TLSListener(config)我看到我可以接收数据的唯一方法是使用http.Serve。我在使用ln,err:=activation.TLSListeners.(config)时得到的错误是ln.Acceptundefined(type[]net.ListenerhasnofieldormethodAccept)packagemainim

ssl - RabbitMQ - Tls 连接 - Golang

我使用以下链接配置了RabbitMQ连接:https://github.com/streadway/amqp/blob/master/examples_test.go我根据此处的说明创建的证书:https://www.rabbitmq.com/ssl.html#enabling-tls-paths我使用安装在docker中的RabbitMQ3.7.0。调用amqp.DialTLS后,我在服务器端(在docker日志中)收到“证书错误”错误。我想问题是证书应该包含服务器名称,如果是这样,如果RabbitMQ安装在docker中,我应该在证书中设置哪个服务器名称?除此之外,还有什么想法吗?

ssl - 是否有用于解码 ASN.1 格式的 TLS 证书的接口(interface)

我正在解析从PCAP文件中获取的TLS记录。我有ASN.1格式的TLS证书字节(在[]byte中)。我想将这个byteslice解码为一个有用的结构(避免手动解析ASN.1)。我似乎无法找到遵循RFC的TLS证书的接口(interface)在encoding/asn1也不crypto/tls.这是在我找不到的地方创建的还是我需要自己编写? 最佳答案 该结构在x509package中 关于ssl-是否有用于解码ASN.1格式的TLS证书的接口(interface),我们在StackOver

ssl - 如何在 Go 中建立到 memsql 的基于 ssl 的 tcp 连接

我正在尝试使用Go设置到memsql的基于ssl的tcp连接。应用程序/服务作为openshiftpod运行并用Go编写。我可以从该服务对memsql进行单向身份验证吗?我是否需要在memsql中启用任何端口来监听基于tls的ssl连接?除了将我的服务中的DSN更新为tls=true之外,还有什么方法可以自定义此配置。有人可以建议一种有效的方法来连接启用ssl的memsql吗?我已经关注了memsqldocumentation并将证书插入到memsqlmaster和聚合器中,并启用了权限检查,但我仍然能够进入memsql而无需在登录中提供rootCertificate。目前连接是通过以

sockets - 为什么当我在许多 goroutine 中发送一个 tcp shake packet(SYN) 时,我在每个 goroutine 中读取了很多响应包

我正在构建一个端口扫描器来检查远程机器上的某个TCP端口是否打开。为了提高性能,我只是构建一个TCPSYN数据包并将其发送到远程端口,而不是进行完整的3次握手。如果我成功接收到SYN-ACK数据包,那么该端口将被视为打开。这是我的部分代码:conn,_:=net.Dial("ip4:tcp",target)tcpSynPacket:=BuildTcpSynPacket()//hereIbuildatcpsynpacketconn.Write(tcpSynPacket.Marshal())deadlineTime:=time.NewTicker(time.Second*2)deferde

sockets - 通过端口获取服务名称

我正在编写简单的网络扫描器,并坚持按端口号解析服务名称。最好的方法是什么?我认为它应该类似于python的socket.getservbyport()并创建了thislib,但不幸的是开发环境基于Windows,我也想要内置解决方案而不是解析器。packagemainimport("fmt""net""strings""sync""time")typePortScannerstruct{ipstring}funcScanPort(ipstring,portint,timeouttime.Duration){target:=fmt.Sprintf("%s:%d",ip,port)conn

sockets - 如何找到 IP :Port of incoming client in TCP Connection

收到来自conn,err:=listener.Accept()的连接后,我想在conn的另一端找到客户端的地址。我已经尝试使用conn.LocalAddr()和conn.RemoteAddr()(Documentation)来执行此操作。.LocalAddr()只是给出服务器进程的地址。.RemoteAddr()为客户端提供了正确的IP,但与我所知道的客户端绑定(bind)的端口号截然不同。如果它有什么不同,我用在同一台机器上运行的两个独立进程来做这件事。一个是客户端,一个是服务器。关于如何找到客户端的正确IP:Port的任何想法?我是要使用LocalAddr还是RemoteAddr?

sockets - 没有可用的缓冲区空间(tcp.cpp :69) when setting SNDBUF and RCVBUF ZeroMQ, golang,MacOSX

我在MacOSX上使用brew安装了zeromq:stable4.1.4,并编写了一个简单的PUB/SUB程序来测试zeromq。但是当我使用标志--bufsize>5运行示例程序时(使用大小>5MB的缓冲区)(去运行go_zmq_pubsub.go--bufsize=6);它抛出以下异常:没有可用的缓冲区空间(tcp.cpp:69)SIGABRT:中止PC=0x7fff9911c286m=0cgo执行时信号到达下面是我用来测试zeromq4.x的程序packagemainimport("fmt""flag""strconv""sync"log"github.com/Sirupsen/

sockets - 如何读取在 Golang 中接收到的 UDP 数据报的输入接口(interface)和远程套接字地址?

PacketConn.ReadFrom()可以为输入接口(interface)提供包含ifIndex的ControlMessage。UDPConn.ReadFromUDP()返回带有数据报的源套接字地址(srcIP+srcPort)的net.UDPAddr。但是,如何同时获取两个信息:输入接口(interface)ifIndexAND远程套接字地址(srcIP+srcPort)?编辑:我已经填写了一个问题:https://github.com/golang/go/issues/14362 最佳答案 当底层套接字是UDP时,.Read