jjzjj

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

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

go - 来自 xx.xx.xx.xx :14333: EOF 的 TLS 握手错误

我在Linux(RHEL7)中运行HTTPS服务器。我一启动服务器就收到以下错误。2019/09/0415:46:16http:TLShandshakeerrorfromxx.xx.xx.xx:60206:EOF2019/09/0415:46:21http:TLShandshakeerrorfromxx.xx.xx.xx:31824:EOF此错误在终端中自动且持续出现。下面是创建https服务器的代码-packagemainimport("fmt""net/http""github.com/gin-gonic/gin")funcmain(){fmt.Println("Startingw

ssl - Docker Golang 应用程序的工作目录是什么?

当我在官方DockerHub存储库中提供Golang应用程序时,我想知道应用程序启动的默认工作目录是什么?背景:我必须将本地证书颁发机构和服务器key映射到容器中以提供TLShttps,我想知道将它们映射到应用程序的位置将能够从容器内的应用程序的当前工作目录中获取它们? 最佳答案 如果您使用的是golang:1.X-onbuild镜像,来自DockerHub的将被复制到(https://hub.docker.com/_/golang/)/go/src/app这意味着您运行目录的所有文件和目录dockerbuild命令将被复制到容器中

c++ - C++ GRPC客户端与golang服务器连接错误

我正在尝试编写一个与C++和golang客户端通信的GRPC服务器。由于这都是我们系统内部的,因此会有一个自签名证书签署服务器证书,服务器将签署客户端证书。我能够从golang客户端连接到服务器。但是,C++客户端没有连接,我从ssl层看到了一堆错误。我在配置C++grpc客户端时做错了什么?(我的证书目前都使用2048位的RSAkey)以下是我认为等效的客户端代码(省略了错误处理):戈兰:import("crypto/tls""io/ioutil""google.golang.org/grpc""google.golang.org/grpc/credentials")funcgetC

http - 禁用公用名验证 - Go HTTP 客户端

如何在gohttp客户端中禁用通用名称验证。我正在使用通用CA执行双向TLS,因此通用名称验证没有任何意义。TLSdocs说,//ServerNameisusedtoverifythehostnameonthereturned//certificatesunlessInsecureSkipVerifyisgiven.Itisalsoincluded//intheclient'shandshaketosupportvirtualhostingunlessitis//anIPaddress.ServerNamestring我不想执行InsecureSkipVerify但我不想验证通用名称。

ssl - 通过存储与 Wireshark 一起使用的 SSL key 在 golang 中解密 TLS

我正在尝试通过提供tls.Config来建立TLS连接包含Rand的结构应始终返回相同的字段int调用他们时Read方法,参见这里的文档:https://golang.org/pkg/crypto/tls/#Config我写了这个构建器:funcnewZeroRand()*rand.Rand{returnrand.New(rand.NewSource(0))}并进行测试以确保rand.Rand总是返回相同的int什么时候Read被多次调用,注意不同的输入参数"foo"和"bar"提供相同的输出:funcTestPredictableZeroRandGenerator(t*testing

客户端的 ssl 版本和密码套件

我正在开发一个soap服务器,它将为一些带有遗留soap协议(protocol)的旧嵌入式计算机提供服务。我用go编写它,到目前为止只使用普通的http,但在生产中它必须使用ssl加密。所以我刚刚创建了一个key和一个证书(来自thissite)并使用了http.ListenAndServeTLS函数。但是现在计算机无法连接,服务器只是打印握手错误:server.go:2848:http:来自[::1]:38790的TLS握手错误:tls:客户端和服务器均不支持密码套件在文档中,对于计算机来说,不支持ssl版本或密码。所以我想知道,如何找出客户端的ssl版本,以及客户端支持的可用密码套

rest - 去 SSL 监听器

我正在用Go构建一个休息API。我有一个SSL域和一个专用服务器。域指向我的专用域并且工作正常(https://www.myweb.com)。错误是当我向我的API的某些端点发出请求时,我从未从服务器获得响应。funcmain(){router:=NewRouter()handler:=cors.New(cors.Options{AllowedMethods:[]string{"GET","POST","PUT","DELETE","PATCH"},AllowCredentials:true,AllowedOrigins:[]string{"*"},AllowedHeaders:[]s

api - Go 语言 HTTPS API

我在使用Plesk的Windows中有一个服务器。我有一个域(example.com),我还为这个域购买了SSL证书。我刚刚安装成功并在我的服务器中配置了域和ssl。所以现在我可以使用https://www.example.com加入我的网站了或example.com并将重定向到https://....直到一切正常。但是现在我用GoLang开发了一个API,不知为何无法在443端口开始监听。(我想也许是因为已经被使用了?)所以我改成了8081端口。现在,当我想向我的API发出请求时,我必须使用https://www.example.com:8081/api/v1/users例如。问题是

ssl - "Craft"go_lang 中的 TLS Client Hello

我是go编程语言的新手,我正在使用Google的“gopacket”库自己制作以太网框架。我已经成功地在用户空间中实现了用于教育目的的基本TCP功能,并且我可以成功地启动与Web服务器的3次握手。现在我想在此基础上启动TLS握手,我的问题是所有现有的TLS库都使用套接字或Conn接口(interface)来启动TLS连接。是否有一些简单的方法可以在go中制作原始TLSClientHello消息,我可以将其用作我的TCP段的有效负载?我不想实现诸如数据传输之类的花哨的东西。如果我能够向服务器发送Client-Hello并在结束连接之前查看回复内容就足够了。感谢您为go新手提供的任何建议。