HEXキーを持つ文字列に対してビット単位のXORを実行する次のPerlスクリプトがあります。
#!/usr/bin/perl
$key = pack("H*","3cb37efae7f4f376ebbd76cd");
print "Enter string to decode: ";
$str=<STDIN>;chomp $str; $str =~ s/\\//g;
$dec = decode($str);
print "Decoded string value: $dec\n";
sub decode{ #Sub to decode
@subvar=@_;
my $sqlstr = $subvar[0];
$cipher = unpack("u", $sqlstr);
$plain = $cipher^$key;
return substr($plain, 0, length($cipher));
}
それを実行したサンプル出力:
$ perl deXOR.pl
Enter string to decode: (?LM-D\=^5DB$ \n
Decoded string value: Bx3k8aaW
私はそれをRubyに移植しようとしましたが、何か間違ったことをしています。結果は同じではありません。
#!/usr/bin/env ruby
key = ['3cb37efae7f4f376ebbd76cd'].pack('H*')
print "Enter string to decode: "
STDOUT.flush
a_string = gets
a_string.chomp!
a_string = a_string.gsub(/\//, "")
dec = String(key)
puts "Decoded string value: "+dec
class String
def xor(key)
text = dup
text.length.times {|n| text[n] = (text[n].ord ^ key[n.modulo key.size].ord).chr }
text
end
end
サンプル出力:
$ ruby deXOR.rb
Enter string to decode: (?LM-D\=^5DB$ \n
Decoded string value: <³~úçôóvë½vÍ
私は何が間違っているのですか?何かご意見は?ありがとう!
変更されましたが、まだ混乱しています...
key = ['3cb37efae7f4f376ebbd76cd'].pack('H*')
def xor(text, key)
text.length.times {|n| text[n] = (text[n].ord ^ key[n.modulo key.size].ord).chr}
text
end
print "Enter string to decode: "
STDOUT.flush
a_string = gets
a_string.chomp!
a_string = a_string.gsub(/\//, "")
dec = xor(a_string, key)
puts "Decoded string value: "+dec
出力:
$ ruby deXOR.rb
Enter string to decode: (?LM-D\=^5DB$ \n
Decoded string value: 2·Ê°¯Kµ2"
Digitakaの助けを借りた作業バージョン:
key = ['3cb37efae7f4f376ebbd76cd'].pack('H*')
def decode(str, key)
text = str.dup
text.length.times { |n| text[n] = (text[n].ord ^ key[n.modulo key.size].ord).chr }
text
end
print "Enter string to decode: "
STDOUT.flush
a_string = gets
a_string.chomp!
a_string = a_string.gsub(/\\n/, "")
a_string = a_string.gsub(/\\/, "")
a_string = a_string.unpack('u')[0]
dec = decode(a_string,key)
puts "Decoded string value: "+dec
出力:
$ ruby deXOR.rb
Enter string to decode: (?LM-D=^5DB$ \n
Decoded string value: Bx3k8aaW