質問

Ruby用PerlのCrypt :: CBCと同等のものは何ですか?

注:この問題は stackoverflowのPHP / Perlに似ています。 :655691

Perlバージョン

use Crypt::CBC;
use MIME::Base64::Perl;

my $cipher = Crypt::CBC->new(
    -key    => "95A8EE8E89979B9EFDCBC6EB9797528D",
    -keysize => 32, 
    -cipher => "Crypt::OpenSSL::AES"
  );  

$encypted = $cipher->encrypt("ABCDEFGH12345678");
$base64 = encode_base64($encypted);

print("$base64"); # output -> U2FsdGVkX18m1jVqRTxANhcEj6aADeOn+2cccDft2eYAMfOkYCvAAkTIOv01VHc/

$de_base64 = decode_base64($base64);
$decrypted = $cipher->decrypt($de_base64);
$c = $cipher->finish;
print("$decrypted \n");

ルビーのバージョンは次のようになります:

require 'openssl'
require 'base64'

aes = OpenSSL::Cipher::AES128.new("CBC")
aes.encrypt
aes.key = "95A8EE8E89979B9EFDCBC6EB9797528D"

encypted = aes.update("ABCDEFGH12345678") + aes.final
base64 = Base64.encode64(encypted)

puts base64 # outout -> gx1K24LqlRUtNNTDNUJTyn7HrVKK6UkfNA9LNpNjZeE=

Base64は、RubyとPerlで同じように動作するはずです。正しい方法は何ですか?

更新(ソリューション)

use Crypt::CBC;
use MIME::Base64;

my $key = "95A8EE8E89979B9E";
my $iv = "1234567890abcdef";

my $cipher = Crypt::CBC->new(
                  -key        => $key,
                  -cipher     => 'Rijndael',
                  -iv         => $iv,
                  -literal_key => 1,
                  -padding => 'null',
                  -keysize => 128/8,
                  -header     => 'none'
                  );  
my $plaintext = $cipher->encrypt("Hello");
print encode_base64($plaintext); # output -> kJCpQC0+iNF8exHGx3GLYw==

ルビー

require 'openssl'
require 'base64'

aes = OpenSSL::Cipher::Cipher.new("aes-128-cbc")
aes.decrypt
aes.key = "95A8EE8E89979B9E"
aes.iv = "1234567890abcdef"
aes.padding = 0

base64 = Base64.decode64("kJCpQC0+iNF8exHGx3GLYw==")
decrypted = aes.update(base64)
decrypted << aes.final

puts decrypted # guess? It is "Hello"
役に立ちましたか?

解決

Perlとphpで同じことがあります。

http://cpansearch.perl .org / src / FAYLAND / OpenSocialX-Shindig-Crypter-0.03 / sample / crypt.pl http://cpansearch.perl.org/ src / FAYLAND / OpenSocialX-Shindig-Crypter-0.03 / sample / crypt.php

そしてヒントがあります:

my $cipher = Crypt::CBC->new(
    {
        'key'         => 'length16length16',
        'cipher'      => 'Rijndael',
        'iv'          => '1234567890abcdef',
        'literal_key' => 1,
        'padding'     => 'null',
        'header'      => 'none',
        keysize       => 128 / 8
    }
);

キーの長さは16でなければなりません。また、ivの長さも16文字にする必要があります。

お役に立てば幸いです。

ありがとう。

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top