PHP 8.1.28 Released!

SolrUtils::escapeQueryChars

(PECL solr >= 0.9.2)

SolrUtils::escapeQueryCharsEscapes a lucene query string

Açıklama

public static SolrUtils::escapeQueryChars(string $str): string|false

Lucene supports escaping special characters that are part of the query syntax.

The current list special characters are:

+ - && || ! ( ) { } [ ] ^ " ~ * ? : \ /

These characters are part of the query syntax and must be escaped

Bağımsız Değişkenler

str

This is the query string to be escaped.

Dönen Değerler

Returns the escaped string başarısızlık durumunda false döner.

add a note

User Contributed Notes 1 note

up
-8
Ian
10 years ago
A way of doing that with a regular expression:

<?php
// Lucene characters that need escaping with \ are + - && || ! ( ) { } [ ] ^ " ~ * ? : \
$luceneReservedCharacters = preg_quote('+-&|!(){}[]^"~*?:\\');
$query = preg_replace_callback(
'/([' . $luceneReservedCharacters . '])/',
function(
$matches) {
return
'\\' . $matches[0];
},
$query);
?>
To Top