草庐IT

ruby - 如何使用 ssl 通过 smtp 使用 ruby​​ 发送邮件(不使用 rails,gmail 没有 TLS)

我只想使用SSL通过SMTP从我的ruby​​脚本发送电子邮件。我只找到从Rails或使用TLS的Gmail执行此操作的示例。我发现人们在谈论ruby​​1.8.5对SMTPS的支持,但是libdoc没有提到它。谁有在端口465上使用SSL通过SMTP发送邮件的示例?ruby-vruby1.8.7(2008-08-11patchlevel72)[i486-linux] 最佳答案 我用下面的配置解决了这个问题:config.action_mailer.perform_deliveries=trueconfig.action_maile

ruby - 如何在 Ruby 中设置 TLS 上下文选项(如 OpenSSL::SSL::SSL_OP_NO_SSLv2)

在C中使用OpenSSL时,我们在上下文中设置选项以删除SSLv2和SSLv3等薄弱和受伤的协议(protocol)。来自ssl.h,这里是一些有用选项的位掩码:#defineSSL_OP_NO_SSLv20x01000000L#defineSSL_OP_NO_SSLv30x02000000L#defineSSL_OP_NO_TLSv10x04000000L#defineSSL_OP_NO_TLSv1_20x08000000L#defineSSL_OP_NO_TLSv1_10x10000000L但是,我在Ruby中设置它们时遇到了问题:ifuri.scheme=="https"http

ruby-on-rails - 来自 Ruby on Rails 应用程序的 FTPS (TLS/SSL)

我有一个FTP服务器,它只接受通过运行FTPS(基于TLS的显式FTP)的连接。我需要能够使用RubyonRails应用程序连接到它。有人知道执行此操作的方法吗?我已经尝试了Net::FTP库,但这似乎不支持FTPS连接。 最佳答案 使用Net::FTPTLS怎么样? 关于ruby-on-rails-来自RubyonRails应用程序的FTPS(TLS/SSL),我们在StackOverflow上找到一个类似的问题: https://stackoverflow

ruby - 如果运行了 tls_start,EventMachine 会在 close_connection 上发出 close_notify 吗?

我正在尝试编写一个基于EventMachine的简单FTPS服务器。控制socket工作正常。当使用数据套接字进行数据传输时,似乎一切正常(TLS握手成功完成并接收到数据),但随后我收到一条错误消息。这是我在Filezilla中得到的:Command:LISTResponse:150OpeningASCIImodedataconnectionforfilelistTrace:CFtpControlSocket::TransferParseResponse()Trace:code=1Trace:state=4Trace:CFtpControlSocket::SendNextCommand

ruby - 是否可以在 Ruby 中启用 TLS v1.2?如果是这样,如何?

是否可以将TLSv.1.2或TLSv1.1与Ruby一起使用?我使用OpenSSL1.0.1c(最新可用)编译了一个Frankenstein版本的Ruby,唯一的区别是SSLv2现在是OpenSSL::SSL::SSLContext::METHODS下的一个选项是否可以将TLSv1.2添加到该列表? 最佳答案 是的,我们添加了TLS1.1和1.2支持recently.就像在SSLContext上设置ssl_version一样简单:ctx=OpenSSL::SSL::SSLContext.newctx.ssl_version=:TLS

javascript - 使用 node.js 调试 TLS 客户端连接

我正在尝试使用node.js和TLS建立与服务器的客户端连接,但失败了。我的问题是如何获取有关连接失败原因的更多信息。理想情况下类似于使用openssl(连接良好)时显示握手和证书交换。目前我得到的只是{[错误:套接字挂起]代码:'ECONNRESET'}。我正在使用类似于以下基于互联网博客的代码。vartls=require('tls'),fs=require('fs');//callbackforwhensecureconnectionestablishedfunctionconnected(stream){if(stream){stream.write('Hello');}els

go - go get 的 TLS 问题

我正在尝试从github安装etcctl。(P.S我不懂golang)gitconfig--globalhttp.sslVerifyfalse去获取github.com/coreos/etcd/etcdctl但我正在点击以下内容。github.com/coreos/etcd/vendor/go.uber.org/zap/root/projects/src/src/github.com/coreos/etcd/vendor/go.uber.org/zap/field.go:33:语法错误:类型声明中的意外=github.com/coreos/etcd/pkg/tlsutil/root/p

go - [golang]是否可以不用证书写TLS服务器?

从客户端我已经有了将InsecureSkipVerify设置为true的tls配置。如何为这个客户端编写服务器,它接受任何证书。tls.config也可以帮助服务器吗?比如将InsecureSkipVerify设置为true? 最佳答案 不,正如@JimB告诉您的那样,TLS没有证书就无法工作。道理很简单:TLS是关于安全和证书的是提供安全性的加密key(TLS使用所谓的“非对称密码学”,其中每一方都有一个key对,包括私有(private)和公共(public)部分;公共(public)部分是发送给另一方的内容在进行TLS握手时)

ssl - 为什么 grpc 服务器示例使用 net.Listen 而不是 tls.Listen

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭5年前。Improvethisquestion我正在设置一个将使用TLS进行客户端授权/身份验证的golanggrpc服务器。我见过的所有服务器设置示例都使用net.Listen()而不是tls.Listen()。这是为什么?import("crypto/tls""github.com/pkg/errors""google.golang.org/grpc""google.golang.org/grpc/credentials""net

go - 如果未提供证书,单元测试 tls.LoadX509KeyPair 将失败

cert,err:=tls.LoadX509KeyPair(os.Getenv("CERT"),os.Getenv("KEY"))iferr!=nil{returnerr}我想为包含这段代码的函数编写单元测试。但是,我的测试环境永远不会有os.Getenv("CERT")/os.Getenv("KEY")中的任何内容。这使得代码(tls.LoadX509KeyPair())返回一个错误,这不允许我测试函数。我应该如何模拟/修改此代码段? 最佳答案 这通过为certFile和keyFile定义变量然后在测试环境中覆盖它们来实现。//.