Разбор списков MRU Microsoft Office 2013 в реестре с использованием Perl
В настоящее время я пытаюсь проанализировать ключи в реестре Windows 7, содержащем списки MRU для Microsoft Office 2013. Однако, когда я пытаюсь запустить скрипт Perl в RegRipper, он говорит, что плагин не был успешно запущен. Я не уверен, есть ли синтаксическая ошибка в моем коде или если он не может проанализировать реестр, как я его написал. Самая большая проблема заключается в том, что один из ключей назван в честь LiveId пользователя (он отображается как LiveId_XXXXXXX), и он меняется от пользователя к пользователю, поэтому я хотел бы, чтобы этот плагин работал независимо от того, какой у него LiveId. Спасибо!
my $reg = Parse::Win32Registry->new($ntuser);
my $root_key = $reg->get_root_key;
# ::rptMsg("officedocs2013_File_MRU v.".$VERSION); # 20110830 [fpi] - redundant
my $tag = 0;
my $key_path = "Software\\Microsoft\\Office\\15.0";
if (defined($root_key->get_subkey($key_path))) {
$tag = 1;
}
if ($tag) {
::rptMsg("MSOffice version 2013 located.");
my $key_path = "Software\\Microsoft\\Office\\15.0";
my $of_key = $root_key->get_subkey($key_path);
if ($of_key) {
# Attempt to retrieve Word docs
my $word_mru_key_path = 'Software\\Microsoft\\Office\\15.0\\Word\\User MRU';
my $word_mru_key = $of_key->get_subkey($word_mru_key_path);
foreach ($word_mru_key->get_list_of_subkeys())
{
if ($key->as_string() =~ /LiveId_\w+/)
{
$word = join($key->as_string(),'\\File MRU');
::rptMsg($key_path."\\".$word);
::rptMsg("LastWrite Time ".gmtime($word_key->get_timestamp())." (UTC)");
my @vals = $word_key->get_list_of_values();
if (scalar(@vals) > 0) {
my %files
# Retrieve values and load into a hash for sorting
foreach my $v (@vals) {
my $val = $v->get_name();
if ($val eq "Max Display") { next; }
my $data = getWinTS($v->get_data());
my $tag = (split(/Item/,$val))[1];
$files{$tag} = $val.":".$data;
}
# Print sorted content to report file
foreach my $u (sort {$a <=> $b} keys %files) {
my ($val,$data) = split(/:/,$files{$u},2);
::rptMsg(" ".$val." -> ".$data);
}
}
else {
::rptMsg($key_path.$word." has no values.");
}
else {
::rptMsg($key_path.$word." not found.");
}
::rptMsg("");
}
}
1 ответ
Регулярное выражение
LiveId_(\w+)
возьму строку после LiveId_
и вы можете сослаться на это с \1
вот так