Maison >développement back-end >tutoriel php >Développement PHP et Manticore Search : implémentation d'une interface de recherche hautement personnalisable

Développement PHP et Manticore Search : implémentation d'une interface de recherche hautement personnalisable

WBOY
WBOYoriginal
2023-08-05 18:41:061123parcourir

Développement PHP et Manticore Search : Implémentation d'une interface de recherche hautement personnalisable

Introduction :
Dans le développement Web, la fonctionnalité de recherche est une exigence très importante et courante. Afin d'améliorer les performances de recherche et l'expérience utilisateur, nous devons utiliser un moteur de recherche hautement personnalisable. Dans cet article, je vais décrire comment développer une interface de recherche puissante et hautement personnalisable à l'aide de PHP et Manticore Search.

Manticore Search est une version améliorée basée sur le moteur de recherche open source Sphinx, qui offre des performances plus élevées et des fonctionnalités plus riches, telles que la recherche en texte intégral, l'indexation distribuée et des options de personnalisation flexibles. En tant que langage de développement Web couramment utilisé, PHP peut être intégré de manière transparente à Manticore Search pour obtenir des fonctions de recherche flexibles et personnalisables.

Étape 1 : Installer Manticore Search
Tout d'abord, nous devons installer Manticore Search sur le serveur. Vous pouvez télécharger le package d'installation via le site officiel (https://manticoresearch.com/) et l'installer et le configurer conformément aux documents officiels. Une fois l'installation terminée, nous pouvons démarrer le service Manticore Search via la ligne de commande du terminal.

Étape 2 : Créer un index
Avant d'utiliser Manticore Search, nous devons créer un index pour stocker nos données. La création d'index peut être effectuée à l'aide des outils de ligne de commande fournis par Manticore Search ou à l'aide de code PHP. Voici un exemple de création d'un index à l'aide de code PHP :

<?php
require_once 'vendor/autoload.php';

use ManticoresearchDocumentsBuilder;

$index = 'my_index';
$client = new ManticoresearchClientClient();
$client->setHost('localhost');
$client->setPort(9308);

$builder = new DocumentsBuilder($client);
$builder->index($index);

$data = [
    [
        'id' => 1,
        'title' => 'Manticore Search',
        'content' => 'Manticore Search is a powerful search engine',
    ],
    [
        'id' => 2,
        'title' => 'PHP',
        'content' => 'PHP is a popular programming language for web development',
    ],
    // ... more data items
];

foreach ($data as $item) {
    $builder->create([
        'id' => $item['id'],
        'title' => $item['title'],
        'content' => $item['content'],
    ]);
}

$builder->commit();

Avec l'exemple de code ci-dessus, nous pouvons créer un index appelé my_index et y ajouter des données. my_index的索引,并向其中添加一些数据。

步骤三:实现搜索功能
在创建索引后,我们可以使用PHP代码调用Manticore Search的API来实现搜索功能。下面是一个实现基本搜索功能的示例:

<?php
require_once 'vendor/autoload.php';

use ManticoresearchClientClient;

$index = 'my_index';
$query = 'Manticore Search';

$client = new Client();
$client->setHost('localhost');
$client->setPort(9308);

$search = $client->search($index);
$result = $search->search($query);

foreach ($result['hits']['hits'] as $hit) {
    echo 'ID: ' . $hit['_id'] . '<br>';
    echo 'Title: ' . $hit['_source']['title'] . '<br>';
    echo 'Content: ' . $hit['_source']['content'] . '<br>';
    echo '<br>';
}

通过上述示例代码,我们可以使用search

Étape 3 : Implémenter la fonction de recherche

Après avoir créé l'index, nous pouvons utiliser le code PHP pour appeler l'API de Manticore Search afin d'implémenter la fonction de recherche. Voici un exemple d'implémentation de la fonctionnalité de recherche de base :

<!DOCTYPE html>
<html>
<head>
    <style>
        .search-box {
            width: 300px;
            margin-bottom: 10px;
        }

        .search-results {
            list-style: none;
            padding: 0;
        }

        .search-results li {
            padding: 10px;
            background-color: #f5f5f5;
            margin-bottom: 5px;
        }
    </style>
</head>
<body>
    <div class="search-box">
        <input type="text" id="search-input" placeholder="Search...">
        <input type="button" id="search-button" value="Search">
    </div>

    <ul class="search-results"></ul>

    <script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
    <script>
        $(document).ready(function() {
            $('#search-button').click(function() {
                var query = $('#search-input').val();

                $.ajax({
                    url: 'search.php',
                    type: 'GET',
                    data: {query: query},
                    success: function(response) {
                        $('.search-results').empty();

                        response.forEach(function(result) {
                            var li = $('<li></li>');
                            li.text(result.title);
                            $('.search-results').append(li);
                        });
                    }
                });
            });
        });
    </script>
</body>
</html>

Grâce à l'exemple de code ci-dessus, nous pouvons utiliser la méthode search pour rechercher et obtenir des résultats de recherche. Nous pouvons ensuite parcourir les résultats de la recherche et générer des informations pertinentes.

Étape 4 : Personnaliser l'interface de recherche

Afin de fournir une meilleure expérience utilisateur, nous pouvons personnaliser le style et les fonctionnalités de l'interface de recherche selon vos besoins. Voici un exemple d'utilisation de HTML et CSS pour personnaliser l'interface de recherche :
rrreee

L'exemple de code ci-dessus montre une interface de recherche simple dans laquelle les utilisateurs peuvent saisir des mots-clés et cliquer sur le bouton de recherche. La fonction de recherche utilise la bibliothèque jQuery pour charger de manière asynchrone les résultats de recherche et afficher les résultats sur la page.

Conclusion : 
    Grâce à la combinaison de PHP et de Manticore Search, nous pouvons obtenir une interface de recherche hautement personnalisable. Dans cet article, nous avons appris comment installer Manticore Search, créer un index, implémenter des fonctions de recherche de base et comment personnaliser le style et les fonctionnalités de l'interface de recherche via HTML et CSS. À l'aide de ces méthodes et exemples de codes, nous pouvons personnaliser une interface de recherche appropriée en fonction des besoins du projet afin d'améliorer l'expérience utilisateur et les résultats de recherche.
  • Lien de référence :
https://manticoresearch.com/🎜🎜https://github.com/manticoresoftware/manticoresearch-php🎜🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn