我在Rails中有一个具有以下方法的应用程序,该方法可以加密和解密文本并与Java客户端通信。defencrypt(string,key)cipher=OpenSSL::Cipher::AES.new(128,:CBC)cipher.encryptcipher.padding=1cipher.key=hex_to_bin(Digest::SHA1.hexdigest(key)[0..32])cipher_text=cipher.update(string)cipher_textexcenddefhex_to_bin(str)[str].pack"H*"enddefbin_to_hex(
我正在使用Ruby的OpenSSLbindings进行AES-256加密。我可以加密一个非空字符串。但是,当尝试加密空字符串时,Ruby会引发异常,提示数据不能为空。如何使用Ruby的OpenSSL绑定(bind)加密空字符串?重现问题的代码require"openssl"KEY=OpenSSL::Cipher::Cipher.new("aes-256-cbc").random_keydefencrypt(plaintext)cipher=OpenSSL::Cipher::Cipher.new("aes-256-cbc")cipher.encryptiv=cipher.random_i
在执行cipher.final时,提示baddecrypt错误。我试图找出问题所在。但是,我找不到。你能告诉我我的代码有什么问题吗?这是我的代码:require'openssl'require'base64'require'hex_string'result_h="4fcd6b1ac843a2f8bf13f2e53dd5c1544fcd6b1ac843a2f8"key=result_h.to_byte_stringencrypt_str="79994A6EF73DA76C";cipher=OpenSSL::Cipher.new("DES-EDE3-CBC")cipher.decrypt
我需要在我的Rails应用程序中进行加密和解密。我正在尝试使用ezcrypto,但每当我进行解密时,我都会收到此错误。OpenSSL::Cipher::CipherErrorinProfilesController#showwrongfinalblocklength需要更改什么才能停止此错误。我尝试像这样使用openssl的另一个实现(从我的模型中调用的方法)defencrypt_attr(unencrypted)c=OpenSSL::Cipher.new("aes-256-cbc")c.encryptc.key=Digest::SHA1.hexdigest('pass')e=c.up
我正在使用rails3.2、Ruby1.9.3和encrypted_stringsgem,尝试以下操作:"wC6234sdf234234cCY1Lag==\n".decrypt(:symmetric,:key=>"mykeynottelling")我收到这个错误:OpenSSL::Cipher::CipherError:baddecrypt然而,这不会发生在Ruby1.8.7中。我对此有点迷茫,有人知道是什么原因造成的吗?更新1:如果我在ruby1.8.7中加密一个字符串:"password".encrypt(:symmetric,:key=>"www.buyandsell.ie"
我需要编写一个简单的工具来加密/解密文件。我想最好的方法是使用OpenSSL:生成key:opensslrand-base642048>secret_key加密文件:opensslaes-256-cbc-a-e-infile-outfile.enc-ksecret_key解密文件:opensslaes-256-cbc-d-infile.enc-outfile-ksecret_key有没有一种简单的方法可以在Ruby中实现它?有更好的方法吗?也许使用PGP? 最佳答案 Ruby的OpenSSL是OpenSSL本身的一个薄包装器,提供了
全新的Rails应用程序。Rails版本5.0.0.1,Ruby版本2.4.0preview2。创建应用程序“demo”,运行一个简单的脚手架生成产品,并在尝试查看脚手架的概览页面时出现错误(基本索引文件仍然可以正常加载欢迎使用Rails屏幕):ProductsController中的参数错误#indexkey必须是32字节:cipher=new_ciphercipher.encryptcipher.key=@secret#RelyonOpenSSLfortheinitializationvectoriv=cipher.random_iv问题行显然是cipher.key=@secret
我有一个网站需要加密和存储上传到服务器的二进制文件。上传和存储工作正常,但在尝试写入加密文件时出现此错误:Encoding::UndefinedConversionError("\xDD"fromASCII-8BITtoUTF-8):导致它的代码如下所示:fd_in=IO.sysopen(self[:name].tempfile.path,"rb")file_in=IO.open(fd_in)fd_out=IO.sysopen(self[:name].tempfile.path+".encrypted","wb")file_out=IO.open(fd_out)cipher=OpenS
在Rails3.0(Ruby1.9.2)应用程序中,我正在尝试使用如下方式加密一些数据:cipher=OpenSSL::Cipher.new'aes-256-cbc'cipher.encryptcipher.key=cipher.random_keycipher.iv=cipher.random_ivencrypted=cipher.update'mostsecretdataintheworld'encrypted这将进入UTF-8数据库。我的问题是>encrypted.encoding=>#>encrypted.encode'utf-8'Encoding::UndefinedConv
我需要对一些文本字符串进行简单的加密。我想创建优惠券代码并使它们看起来很酷,因此随后创建的代码应该看起来非常不同。(除了看起来很酷之外,猜出密码也不是一件容易的事。)但我希望能够再次解密它们。所以算法必须是可逆的。我已经尝试过一些移动位的东西,所以它们看起来已经有点随机了。但是后续的两个代码(只有一点不同)当然看起来非常相似。有什么建议吗?我想在不使用外部gem的情况下做到这一点。菲利普 最佳答案 你可以使用OpenSSL::Cipher#formoreinfo,seehttp://ruby-doc.org/stdlib-1.9.3