小编Rya*_*roi的帖子

在Ruby openssl中的AES等价物?

Gibberish图书馆提供了一个不错的CBC算法......

// In Jascascript
GibberishAES.enc("Made with Gibberish\n", "password");
// Outputs: "U2FsdGVkX1+21O5RB08bavFTq7Yq/gChmXrO3f00tvJaT55A5pPvqw0zFVnHSW1o"

# On the command line
echo "U2FsdGVkX1+21O5RB08bavFTq7Yq/gChmXrO3f00tvJaT55A5pPvqw0zFVnHSW1o" | 
  openssl enc -d -aes-256-cbc -a -k password
Run Code Online (Sandbox Code Playgroud)

我怎样才能在ruby中进行解密?直截了当的方式不起作用......

require 'openssl'

def aes(m,k,t)
  (aes = OpenSSL::Cipher::Cipher.new('aes-256-cbc').send(m)).key = k
  aes.update(t) << aes.final
end

def encrypt(key, text)
  aes(:encrypt, key, text)
end

def decrypt(key, text)
  aes(:decrypt, key, text)
end

def p k
  Digest::SHA256.digest(k) ## what goes here???
end

require 'base64'
def t x
  ## also tried.. simply returning x...
  Base64.decode64(x)      
end


text = "U2FsdGVkX1+21O5RB08bavFTq7Yq/gChmXrO3f00tvJaT55A5pPvqw0zFVnHSW1o"
pass …
Run Code Online (Sandbox Code Playgroud)

javascript ruby encryption openssl aes

6
推荐指数
1
解决办法
2775
查看次数

标签 统计

aes ×1

encryption ×1

javascript ×1

openssl ×1

ruby ×1