-
Notifications
You must be signed in to change notification settings - Fork 0
/
chal5.pl
executable file
·36 lines (25 loc) · 1.23 KB
/
chal5.pl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
#!/usr/bin/perl -w
# chal5.pl - Encrypt a string with a repeating XOR key to test it.
#
# Copyright (C) 2015 Andrew J. Zimolzak <andyzimolzak@gmail.com>
# Full notice is found in the file 'LICENSE' in the same directory
# as this file.
use strict;
use Cryptopals qw(key_xor_hex_to_text ascii2hex);
my $plaintext = "Burning 'em, if you ain't quick and nimble\nI go crazy when I hear a cymbal";
#print ascii2hex($plaintext);
print ascii2hex(key_xor_hex_to_text("ICE", ascii2hex($plaintext))), "\n";
my $target = "0b3637272a2b2e63622c2e69692a23693a2a3c6324202d623d63343c2a26226324272765272a282b2f20430a652e2c652a3124333a653e2b2027630c692b20283165286326302e27282f";
die unless ascii2hex(key_xor_hex_to_text("ICE", ascii2hex($plaintext))) eq $target;
#print key_xor_hex_to_text("A", "70");
print "Encrypting 4 misc plaintexts.\n";
print " plaintext\t|\tpure ascii\t|\thex\n";
for my $plaintext ("Hello", "Testing this", "asdfsdfwef", "Bruce lee was a german swiss physicist.") {
print " $plaintext\t|\t";
my $ascii = key_xor_hex_to_text("sucka mcs", ascii2hex($plaintext));
my $asub = $ascii;
$asub =~ s/[\r\v\t\n]//g;
print $asub, "\t|\t";
print ascii2hex($ascii), "\n";
}
warn "Passed assertions $0.\n";