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

PHP を使用して Lucene パッケージを呼び出し、全文検索を実装します。

Jun 21, 2016 am 09:05 AM
java lucene path php

全文検索

仕事の都合上、多数の 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衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

PHPでHTML/XMLを解析および処理するにはどうすればよいですか? PHPでHTML/XMLを解析および処理するにはどうすればよいですか? Feb 07, 2025 am 11:57 AM

このチュートリアルでは、PHPを使用してXMLドキュメントを効率的に処理する方法を示しています。 XML(拡張可能なマークアップ言語)は、人間の読みやすさとマシン解析の両方に合わせて設計された多用途のテキストベースのマークアップ言語です。一般的にデータストレージに使用されます

JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 Apr 05, 2025 am 12:04 AM

JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

母音を文字列にカウントするPHPプログラム 母音を文字列にカウントするPHPプログラム Feb 07, 2025 pm 12:12 PM

文字列は、文字、数字、シンボルを含む一連の文字です。このチュートリアルでは、さまざまな方法を使用してPHPの特定の文字列内の母音の数を計算する方法を学びます。英語の母音は、a、e、i、o、u、そしてそれらは大文字または小文字である可能性があります。 母音とは何ですか? 母音は、特定の発音を表すアルファベットのある文字です。大文字と小文字など、英語には5つの母音があります。 a、e、i、o、u 例1 入力:string = "tutorialspoint" 出力:6 説明する 文字列「TutorialSpoint」の母音は、u、o、i、a、o、iです。合計で6元があります

PHPでの後期静的結合を説明します(静的::)。 PHPでの後期静的結合を説明します(静的::)。 Apr 03, 2025 am 12:04 AM

静的結合(静的::) PHPで後期静的結合(LSB)を実装し、クラスを定義するのではなく、静的コンテキストで呼び出しクラスを参照できるようにします。 1)解析プロセスは実行時に実行されます。2)継承関係のコールクラスを検索します。3)パフォーマンスオーバーヘッドをもたらす可能性があります。

Java 8 Stream Foreachから休憩または戻ってきますか? Java 8 Stream Foreachから休憩または戻ってきますか? Feb 07, 2025 pm 12:09 PM

Java 8は、Stream APIを導入し、データ収集を処理する強力で表現力のある方法を提供します。ただし、ストリームを使用する際の一般的な質問は次のとおりです。 従来のループにより、早期の中断やリターンが可能になりますが、StreamのForeachメソッドはこの方法を直接サポートしていません。この記事では、理由を説明し、ストリーム処理システムに早期終了を実装するための代替方法を調査します。 さらに読み取り:JavaストリームAPIの改善 ストリームを理解してください Foreachメソッドは、ストリーム内の各要素で1つの操作を実行する端末操作です。その設計意図はです

PHPマジックメソッド(__construct、__destruct、__call、__get、__setなど)とは何ですか? PHPマジックメソッド(__construct、__destruct、__call、__get、__setなど)とは何ですか? Apr 03, 2025 am 12:03 AM

PHPの魔法の方法は何ですか? PHPの魔法の方法には次のものが含まれます。1。\ _ \ _コンストラクト、オブジェクトの初期化に使用されます。 2。\ _ \ _リソースのクリーンアップに使用される破壊。 3。\ _ \ _呼び出し、存在しないメソッド呼び出しを処理します。 4。\ _ \ _ get、dynamic属性アクセスを実装します。 5。\ _ \ _セット、動的属性設定を実装します。これらの方法は、特定の状況で自動的に呼び出され、コードの柔軟性と効率を向上させます。

一致式(PHP 8)とそれがスイッチとどのように異なるかを説明します。 一致式(PHP 8)とそれがスイッチとどのように異なるかを説明します。 Apr 06, 2025 am 12:03 AM

PHP8では、一致式は、式の値に基づいて異なる結果を返す新しい制御構造です。 1)Switchステートメントに似ていますが、実行ステートメントブロックの代わりに値を返します。 2)一致式の式は厳密に比較され、セキュリティが向上します。 3)スイッチステートメントの脱落の可能性を回避し、コードのシンプルさと読みやすさを向上させます。

カプセルの量を見つけるためのJavaプログラム カプセルの量を見つけるためのJavaプログラム Feb 07, 2025 am 11:37 AM

カプセルは3次元の幾何学的図形で、両端にシリンダーと半球で構成されています。カプセルの体積は、シリンダーの体積と両端に半球の体積を追加することで計算できます。このチュートリアルでは、さまざまな方法を使用して、Javaの特定のカプセルの体積を計算する方法について説明します。 カプセルボリュームフォーミュラ カプセルボリュームの式は次のとおりです。 カプセル体積=円筒形の体積2つの半球体積 で、 R:半球の半径。 H:シリンダーの高さ(半球を除く)。 例1 入力 RADIUS = 5ユニット 高さ= 10単位 出力 ボリューム= 1570.8立方ユニット 説明する 式を使用してボリュームを計算します。 ボリューム=π×R2×H(4

See all articles