草庐IT

openssl_call

全部标签

ruby - 使用 SHA256 摘要签名的 OpenSSL RSA

我正在尝试找出与我拥有的小型ruby​​脚本等效的shell脚本。这是ruby脚本:require'openssl'require'base64'k=OpenSSL::PKey::RSA.new(File.read("key.pem"))res=File.read("res.tmp")digest=OpenSSL::Digest::SHA256.newsignature=k.sign(digest,res)File.write("foo1.txt",Base64.strict_encode64(signature))就是这样。它需要一些数据,获取它的SHA256哈希值,然后用我拥有的私

ruby-on-rails - rails : link_to calls custom method in controller

我希望使用link_to来调用我的Controller中的方法。但是,由于某些奇怪的原因,路由会寻找show方法。在我看来:..beverage.id)%>..在我的config/routes.rb中match'beverages/archive'=>'beverages#archive'在我的beverages_controller.rb中defarchivebeverage=Beverage.find(params[:id])respond_todo|format|#format.html#show.html.erbformat.json{renderjson:beverage}e

ruby - Ruby 1.9.3 的 OpenSSL 问题

我在Ubuntu12.04上遇到OpenSSL1.0.1+Ruby1.9.3的半严重问题。所有的ruby都是用rvm安装的require'uri'require'net/http'require'net/https'endpoint="https://secure.mmoagateway.com/api/transact.php"RUBY_184_POST_HEADERS={"Content-Type"=>"application/x-www-form-urlencoded"}body="orderid=ae5dd847d9f31209cbffeeea076ed966&orderdes

ruby-on-rails - rails 3 : Call functions inside controllers

如果我想在Controller内部调用函数,我应该把它们放在哪里? 最佳答案 如果您希望它在Controller本地,那么您需要做的就是将它添加到您希望使用的Controller。privatedefmyfunctionfunctioncode.....end对于所有Controller,您可以将它放在应用程序Controller中,因为所有Controller都是子类。应用程序Controllerprotecteddefmyfunctionfunctioncode.....end如果你想访问你的View,那么你可以创建一个助手应用

OpenSSL 证书

目录证书标准编码格式PEM:PrivacyEnhancedMailDER:DistinguishedEncodingRules编码转换: 文件扩展名自签证书签发根证书 生成CA私钥生成CA申请文件签发根证书 导出Java的CA证书签发服务端证书签发客户端证书证书标准X.509数字证书标准,定义证书文件的结构和内容。证数结构图:编码格式证书的编码格式:一般包括PEM和DER两种。PEM:PrivacyEnhancedMailDER:DistinguishedEncodingRules编码转换:PEM转DERopensslx509-inxxx.pem-outformder-outxxx.der D

ruby-on-rails - Rails 3 和加密字符串 Gem - 获取 OpenSSL::Cipher::CipherError: bad decrypt error

我正在使用rails3.2、Ruby1.9.3和encrypted_stringsgem,尝试以下操作:"wC6234sdf234234cCY1Lag==\n".decrypt(:symmetric,:key=>"mykeynottelling")我收到这个错误:OpenSSL::Cipher::CipherError:baddecrypt然而,这不会发生在Ruby1.8.7中。我对此有点迷茫,有人知道是什么原因造成的吗?更新1:如果我在ruby​​1.8.7中加密一个字符串:"password".encrypt(:symmetric,:key=>"www.buyandsell.ie"

ruby - 当我不提供方法名称时,为什么 Ruby 会调用 `call` 方法?

给定以下模块:moduleFoodefself.call'foo'endend我当然希望以下内容有效:putsFoo.call#outputs"foo"但是,我没想到这会起作用:putsFoo.()#outputs"foo"显然,当方法名称被省略时,Ruby假定我想调用call方法。这在哪里记录,为什么它会这样? 最佳答案 Proc#call:Invokestheblock,settingtheblock’sparameterstothevaluesinparamsusingsomethingclosetomethodcalling

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 - OpenSSL::SSL::SSLError: SSL_connect returned=1 errno=0 state=unknown 状态:未知协议(protocol)

我关注了很多关于这个问题的帖子,但没有一个对我有帮助。我正在尝试使用最简单的irb命令进行连接:require'open-uri'open('https://aristo4stu3.bgu.ac.il')奇怪的是,对于我尝试过的任何其他httpsuri,它都工作正常(即https://google.com)。出于调试目的,我什至尝试使用以下方法禁用SSL验证:OpenSSL::SSL::VERIFY_PEER=OpenSSL::SSL::VERIFY_NONE这似乎也没有帮助。我的设置是(在AWS上):$rvm-vrvm1.21.3(stable)byWayneE.Seguin,Mic

ruby-on-rails - ruby rails : no such file to load -- openssl on RedHat Linux Enterprise

我正在尝试执行“rakedb:migrate”并收到错误消息“没有要加载的文件--openssl”。“openssl”和“openssl-devel”包都已安装。Debian或Ubuntu上的其他人似乎能够通过安装“libopenssl-ruby”来摆脱这种情况,这不适用于RedHat。有没有人遇到过这个问题并有解决方案? 最佳答案 升级到8.10后,我在Ubuntu上遇到了这个问题。Ubuntu的解决方案是sudoapt-get安装libopenssl-ruby 关于ruby-on-r