検索
ホームページphp教程php手册PHP を使用して Lucene パッケージを呼び出し、全文検索を実装します。

全文検索

仕事の都合上、多数の Web サイトの全文検索を実装するには PHP を使用する必要があります
全文検索用の最も人気のある検索エンジン ライブラリは、Apache Jakarta のサブプロジェクトです。は、シンプルで実用的な API を提供します。
これらの API を使用すると、あらゆる基本的なテキスト データ (データベースを含む) に対して全文検索を実行できます。
PHP 自体が外部 Java クラスの呼び出しをサポートしているため、最初に Java でクラスを作成しました。
このクラスは、Lucene の API を呼び出して 2 つのメソッドを実装します。 )
ここで、createIndex はインデックス作成メソッドです。
渡される 2 つのパラメーターは、indexDir_path (インデックス付きファイルのディレクトリ)、dataDir_path (インデックス付きファイルのディレクトリ)、そしてインデックス付きファイルのリスト文字列が返されます。
もう 1 つは、検索する searchword です。渡されたキーワード パラメータ (ss) によるインデックスは、インデックス ファイルのディレクトリです。取得したすべてのファイルを返します。
これがソース コードです。非常に単純です。参照してください:
TxtFileIndexer.java

PHP プログラムは、フルテキスト検索の目的を達成するために、Lucene への呼び出しを実現するためにこれら 2 つのメソッドを呼び出します。 PHPの呼び出し方法は以下の通りです: まず先ほど作成したTxtFileIndexerクラスのインスタンスを作成し、
$tf = new Java('TestLucene.TxtFileIndexer');
その後は通常のPHPクラス呼び出しと同様に呼び出します。メソッドでは、最初にインデックスを作成します:
$data_path = "F:/test/php_lucene/htdocs/data/manual"; //インデックス付きコンテンツのディレクトリを定義します
$index_path = "F:/test/php_lucene/htdocs/data/search "; // 生成されたインデックス ファイルが保存されるディレクトリを定義します
$s = $tf->createIndex($index_path,$data_path); // Java クラス メソッドを呼び出します
print $s; // 返された結果を出力します
今回取得してみる :
$index_path = "F:/test/php_lucene/htdocs/data/search" //生成したインデックスファイルの格納ディレクトリを定義
$s = $tf->searchword("ここにキーワードがありますsearch",$index_path );
print $s;
PHPで設定できるJavaクラスのパスにも注意してください
java_require("F:/test/php_lucene/htdocs/lib/"); //これは例です。私のクラスと Lucene をすべてこのディレクトリに置きます
それだけです。非常に簡単ではありませんか?
PHP ソース コード:
test.php

次に、環境構成について説明します。 まず、Java SDK が必要です。私はバージョン 1.4.2 を使用していますが、他のバージョンも必要です。大丈夫。 PHP5、PHP4を試してみました。動作するはずです。
PHP5 が提供する Java 拡張機能が調整されておらず、以前は Java の呼び出しが非常に非効率で遅かったため、
Php/Java Bridge
プロジェクトを使用しました。
1. JavaBridge をダウンロードしますURL:http://sourceforge.net/projects/php-java-bridge/

現在のバージョンはphp-java-bridge_3.0.8_j2ee.zipです

解凍して配置しますJavaBridgeWEB -INFcgijava-x86-windows.dllJavaBridgeWEB-INFlibJavaBridge.jar
c:phpextディレクトリにコピーし、
java-x86-windows.dllの名前をphp_java.dll
2に変更します。php.ini (例)
extension = php_java.dll
[Java]
java.class.path = "C:phpextJavaBridge.jar;F:testphp_lucenehtdocs"
java.java_home = "C:j2sdk1.4.2_10"
java.library.path = "c:phpext ; F:testphp_lucenehtdocs"
3. Apache を再起動するだけです。
4. インデックス作成用のファイルがいくつか見つかります。
test.php でインデックス ファイルとデータ ファイルのパスを変更できます。
TxtFileIndexer.java の 37 行目は、インデックス作成を html サフィックスを持つファイルのみに制限しており、必要に応じて変更できます。
現在の状況 (JavaBridge は Linux と Freebsd をサポート) によれば、
linux または freebsd/apache2/php4/lucene/JavaBridge
環境で完全に実行できます。




声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。