Hey, ich schreibe ein Programm, das einen @INC-Hook verwendet, um den echten Perl-Quellcode von Blowfish zu entschlüsseln. Ich habe ein ziemlich ärgerliches Problem, das nicht mit Warnungen oder einer meiner Standardtricks auftaucht... Wenn ich zum Erstellen des neuen Cipher-Objekts komme, springt die Schleife zum nächsten Objekt in @INC, ohne dass ein Fehler oder irgendetwas.... Ich weiß nicht, was ich tun soll!
#!/usr/bin/perl -w
use strict;
use Crypt::CBC;
use File::Spec;
sub load_crypt {
my ($self, $filename) = @_;
print "Key?\n: ";
chomp(my $key = <STDIN>);
for my $prefix (@INC) {
my $buffer = undef;
my $cipher = Crypt::CBC->new( -key => $key, -cipher => 'Blowfish');
my $derp = undef;
$cipher ->start('decrypting');
open my $fh, '<', File::Spec->($prefix, "$filename.nc") or next;
while (read($fh,$buffer,1024)) {
$derp .= $cipher->crypt($buffer);
}
$derp .= $cipher->finish;
return ($fh, $derp);
}
}
BEGIN {
unshift @INC, \&load_crypt;
}
require 'gold.pl';
Auch wenn ich den tatsächlichen Schlüssel in die Initialisierungsmethode einfüge, schlägt es immer noch fehl