From 6976594a1496ae98adc87e8ffc86a5dc4cd31949 Mon Sep 17 00:00:00 2001 From: Fred Tempez Date: Sun, 16 Aug 2020 21:02:26 +0200 Subject: [PATCH] =?UTF-8?q?Nouveau=20moteur=20de=20recherche=20bas=C3=A9?= =?UTF-8?q?=20sur=20des=20regex=20-=20reste=20=20=C3=A0=20faire=20recherch?= =?UTF-8?q?e=20par=20chaine?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- module/search/search.php | 75 ++++++++++++++---------------- module/search/view/index/index.css | 3 ++ module/search/view/index/index.php | 2 +- 3 files changed, 39 insertions(+), 41 deletions(-) create mode 100644 module/search/view/index/index.css diff --git a/module/search/search.php b/module/search/search.php index ee06f007..540dd4c1 100755 --- a/module/search/search.php +++ b/module/search/search.php @@ -80,7 +80,21 @@ class search extends common { //Pour affichage de l'entête du résultat self::$resultTitle = 'Aucun résultat'; $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) { if ($this->getData(['page', $parentId, 'disable']) === false && $this->getUser('group') >= $this->getData(['page', $parentId, 'group']) && @@ -89,7 +103,7 @@ class search extends common { $titre = $this->getData(['page', $parentId, 'title']); $contenu = $this->getData(['page', $parentId, 'content']); // 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) { @@ -101,7 +115,7 @@ class search extends common { $titre = $this->getData(['page', $childId, 'title']); $contenu = $this->getData(['page', $childId, 'content']); //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']; $contenu = $article['content']; // 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']; $contenu = $article['content']; // 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é. Avez-vous pensé aux accents ?'; $success = false; } else { - $result .= 'Nombre d\'occurrences : '.self::$nbResults; + //$result .= self::$nbResults .' occurrences ont été trouvées.'; $notification = 'Nombre d\'occurrences : '.self::$nbResults; self::$resultTitle = 'Résultat(s) : "' . self::$motclef . '" a été trouvé '. self::$nbResults . ' fois'; $success = true; @@ -189,24 +203,24 @@ class search extends common { $resultat= ''; // Recherche des occurrences do { - $occu = stristr($contenu,$motclef); - if ($occu !== false) { - if ($motentier === true) { - $controle_entier=$this->test_motentier($contenu,$motclef); - } else { - $controle_entier=true; + $occu = preg_match_all($motclef,$contenu,$matches,PREG_OFFSET_CAPTURE); + if ($occu !== false && !empty($matches[0]) ) { + /*echo "
";
+				print_r($matches);
+				echo "
";*/ + if ($titre !== $dejavu) { + $resultat = '

'.$titre.'

'; } - if ($controle_entier) { - if ($titre !== $dejavu) { - $resultat = '

'.$titre.'

'; - } - $dejavu = $titre; - $nboccu++; - $resultat .= '

'.$nboccu.' - "...'.substr($occu,0,200).'..."

'; + $dejavu = $titre; + $nboccu .= count($matches[0]); + $contenu = preg_replace($motclef, '\1', $contenu); + foreach ($matches[0] as $key => $value) { + //$resultat .= '

'.$nboccu.' - "...'.substr($contenu,$value[1] ,200).'..."

'; # code... + $resultat .= '"'.substr($contenu,$value[1] ,200).'..."

'; # code... } - // 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 != ''); self::$nbResults = self::$nbResults + $nboccu; @@ -229,23 +243,4 @@ class search extends common { while($pos1!==false); 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; - } } diff --git a/module/search/view/index/index.css b/module/search/view/index/index.css new file mode 100644 index 00000000..906a9170 --- /dev/null +++ b/module/search/view/index/index.css @@ -0,0 +1,3 @@ +.evidence { + background: yellow; +} \ No newline at end of file diff --git a/module/search/view/index/index.php b/module/search/view/index/index.php index 336f6633..5d06a337 100755 --- a/module/search/view/index/index.php +++ b/module/search/view/index/index.php @@ -17,7 +17,7 @@
false + 'checked' => $module::$motentier ]); ?>