Nouveau moteur de recherche basé sur des regex - reste à faire recherche par chaine

This commit is contained in:
Fred Tempez 2020-08-16 21:02:26 +02:00
parent 9b847547f3
commit 6976594a14
3 changed files with 39 additions and 41 deletions

View File

@ -80,7 +80,21 @@ class search extends common {
//Pour affichage de l'entête du résultat //Pour affichage de l'entête du résultat
self::$resultTitle = 'Aucun résultat'; self::$resultTitle = 'Aucun résultat';
$result = ''; $result = '';
if (self::$motclef !== "" && strlen(self::$motclef) > 2) { // protection des guillemets
// ^((("){1}([^"])*("){1})([ ]+))+$
//preg_match('(?:^|(?<=\s))"([^"]+)"(?:$|(?=\s))',self::$motclef,$matches);
//print_r($matches);
// Découpage de la chaîne de mots clés
$keywords = '/(';
$a = explode(' ',self::$motclef);
foreach ($a as $key => $value) {
$keywords .= self::$motentier === false ? $value . '|' : '\\b' . $value . '\\b|' ;
}
$keywords = substr($keywords,0,strlen($keywords) - 1);
$keywords .= ')/i';
//echo $keywords;
if ($keywords !== "" && strlen($keywords) > 2) {
foreach($this->getHierarchy(null,false,null) as $parentId => $childIds) { foreach($this->getHierarchy(null,false,null) as $parentId => $childIds) {
if ($this->getData(['page', $parentId, 'disable']) === false && if ($this->getData(['page', $parentId, 'disable']) === false &&
$this->getUser('group') >= $this->getData(['page', $parentId, 'group']) && $this->getUser('group') >= $this->getData(['page', $parentId, 'group']) &&
@ -89,7 +103,7 @@ class search extends common {
$titre = $this->getData(['page', $parentId, 'title']); $titre = $this->getData(['page', $parentId, 'title']);
$contenu = $this->getData(['page', $parentId, 'content']); $contenu = $this->getData(['page', $parentId, 'content']);
// Pages sauf pages filles et articles de blog // Pages sauf pages filles et articles de blog
$result .= $this->occurrence($url, $titre, $contenu, self::$motclef, self::$motentier); $result .= $this->occurrence($url, $titre, $contenu, $keywords, self::$motentier);
} }
foreach($childIds as $childId) { foreach($childIds as $childId) {
@ -101,7 +115,7 @@ class search extends common {
$titre = $this->getData(['page', $childId, 'title']); $titre = $this->getData(['page', $childId, 'title']);
$contenu = $this->getData(['page', $childId, 'content']); $contenu = $this->getData(['page', $childId, 'content']);
//Pages filles //Pages filles
$result .= $this->occurrence($url, $titre, $contenu, self::$motclef, self::$motentier); $result .= $this->occurrence($url, $titre, $contenu, $keywords, self::$motentier);
} }
@ -114,7 +128,7 @@ class search extends common {
$titre = $article['title']; $titre = $article['title'];
$contenu = $article['content']; $contenu = $article['content'];
// Articles de sous-page de type blog // Articles de sous-page de type blog
$result .= $this->occurrence($url, $titre, $contenu, self::$motclef, self::$motentier); $result .= $this->occurrence($url, $titre, $contenu, $keywords, self::$motentier);
} }
} }
@ -131,7 +145,7 @@ class search extends common {
$titre = $article['title']; $titre = $article['title'];
$contenu = $article['content']; $contenu = $article['content'];
// Articles de Blog // Articles de Blog
$result .= $this->occurrence($url, $titre, $contenu, self::$motclef, self::$motentier); $result .= $this->occurrence($url, $titre, $contenu, $keywords, self::$motentier);
} }
} }
@ -143,7 +157,7 @@ class search extends common {
$result .='Mot clef non trouv&eacute;. Avez-vous pens&eacute; aux accents ?'; $result .='Mot clef non trouv&eacute;. Avez-vous pens&eacute; aux accents ?';
$success = false; $success = false;
} else { } else {
$result .= 'Nombre d\'occurrences : '.self::$nbResults; //$result .= self::$nbResults .' occurrences ont été trouvées.';
$notification = 'Nombre d\'occurrences : '.self::$nbResults; $notification = 'Nombre d\'occurrences : '.self::$nbResults;
self::$resultTitle = 'Résultat(s) : "' . self::$motclef . '" a été trouvé '. self::$nbResults . ' fois'; self::$resultTitle = 'Résultat(s) : "' . self::$motclef . '" a été trouvé '. self::$nbResults . ' fois';
$success = true; $success = true;
@ -189,24 +203,24 @@ class search extends common {
$resultat= ''; $resultat= '';
// Recherche des occurrences // Recherche des occurrences
do { do {
$occu = stristr($contenu,$motclef); $occu = preg_match_all($motclef,$contenu,$matches,PREG_OFFSET_CAPTURE);
if ($occu !== false) { if ($occu !== false && !empty($matches[0]) ) {
if ($motentier === true) { /*echo "<pre>";
$controle_entier=$this->test_motentier($contenu,$motclef); print_r($matches);
} else { echo "</pre>";*/
$controle_entier=true; if ($titre !== $dejavu) {
$resultat = '<p><a href="./?'.$url.'" target="_blank" rel="noopener">'.$titre.'</a></p>';
} }
if ($controle_entier) { $dejavu = $titre;
if ($titre !== $dejavu) { $nboccu .= count($matches[0]);
$resultat = '<p><a href="./?'.$url.'" target="_blank" rel="noopener">'.$titre.'</a></p>'; $contenu = preg_replace($motclef, '<span class="evidence">\1</span>', $contenu);
} foreach ($matches[0] as $key => $value) {
$dejavu = $titre; //$resultat .= '<p>'.$nboccu.' - "...<em>'.substr($contenu,$value[1] ,200).'</em>..."<br/></p>'; # code...
$nboccu++; $resultat .= '"<em>'.substr($contenu,$value[1] ,200).'</em>..."<br/></p>'; # code...
$resultat .= '<p>'.$nboccu.' - "...<em>'.substr($occu,0,200).'</em>..."<br/></p>';
} }
// Pour recherche d'une autre occurrence dans le même contenu
$contenu = substr($occu,10);
} }
// Pour recherche d'une autre occurrence dans le même contenu
$contenu = substr($occu,10);
} }
while($occu != ''); while($occu != '');
self::$nbResults = self::$nbResults + $nboccu; self::$nbResults = self::$nbResults + $nboccu;
@ -229,23 +243,4 @@ class search extends common {
while($pos1!==false); while($pos1!==false);
return $contenu; return $contenu;
} }
// Déclaration de la fonction test_motentier(string $chaine, string $clef) : bool
// Vérifie si dans la string $chaine, $clef est un mot entier
// $clef ne doit pas être précédé ni suivi d'une lettre maj ou min
private function test_motentier($chaine, $clef)
{
$resultat=true;
$pos1=stripos($chaine,$clef);
$avant=ord(substr($chaine,$pos1-1, 1));
$apres=ord(substr($chaine,$pos1+strlen($clef),1));
// Traitement pour le caractère qui précède et celui qui suit
if (($avant>=65 && $avant<=90) ||
($avant>=97 && $avant<=122) ||
($apres>=65 && $apres<=90) ||
($apres>=97 && $apres<=122) ) {
$resultat=false;
}
return $resultat;
}
} }

View File

@ -0,0 +1,3 @@
.evidence {
background: yellow;
}

View File

@ -17,7 +17,7 @@
<div class="row"> <div class="row">
<div class="col12"> <div class="col12">
<?php echo template::checkbox('searchMotentier', true, 'Mot entier uniquement', [ <?php echo template::checkbox('searchMotentier', true, 'Mot entier uniquement', [
'checked' => false 'checked' => $module::$motentier
]); ?> ]); ?>
</div> </div>
</div> </div>