Используйте quotemeta
или \Q...\E
.
Рассмотрим следующую тестовую программу, которая соответствует $str
как есть, quotemeta
и \Q...\E
:
#! /usr/bin/perl
use warnings;
use strict;
my $str = "www.abc.com";
my @test = (
"www.abc.com",
"www/abc!com",
);
sub ismatch($) { $_[0] ? "MATCH" : "NO MATCH" }
my @match = (
[ as_is => sub { ismatch /$str/ } ],
[ qmeta => sub { my $qm = quotemeta $str; ismatch /$qm/ } ],
[ qe => sub { ismatch /\Q$str\E/ } ],
);
for (@test) {
print "\$_ = '$_':\n";
foreach my $method (@match) {
my($name,$match) = @$method;
print " - $name: ", $match->(), "\n";
}
}
Обратите внимание на вывод, что использование строки как есть может привести к ложным совпадениям:
$ ./try
$_ = 'www.abc.com':
- as_is: MATCH
- qmeta: MATCH
- qe: MATCH
$_ = 'www/abc!com':
- as_is: MATCH
- qmeta: NO MATCH
- qe: NO MATCH
Для программ, которые принимают ненадежные входные данные, будьте предельно осторожны при использовании таких потенциально неприятных битов, как регулярные выражения: это может привести к непредвиденным ошибкам во время выполнения, уязвимостям отказа в обслуживании и дырам в безопасности.