ホームページ > バックエンド開発 > PHPチュートリアル > PHP を使用して検索フォームを設計することについて語る私のストーリー

PHP を使用して検索フォームを設計することについて語る私のストーリー

WBOY
リリース: 2016-06-23 13:19:43
オリジナル
915 人が閲覧しました

    


我的classmate用dreamweaver做了一个网站,没有动态的内容,只是一些个人收藏的文章,个人介绍等等。现在内容比较多了,想叫我帮他做一个搜索引擎。说实在的,这是一个不难的问题,于是就随手做了一个。现在我在其它论坛上也看到有人想做这个,于是就想说说这方面的知识,重在了解一下方法。


朋友用dreamweaver做了一个网站,没有动态的内容,只是一些个人收藏的文章,个人介绍等等。现在内容比较多了,想叫我帮他做一个搜索引擎。说实在的,这是一个不难的问题,于是就随手做了一个。现在我在其它论坛上也看到有人想做这个,于是就想说说这方面的知识,重在了解一下方法。 写程序前先要想好一个思路,下面是我的思路,可能谁有更好的,但注意这只是一个方法问题 :遍历所有文件  读取内容  搜索关键字,如果匹配就放入一个数组  读数组。在实现这些步骤之前,我假定你的网页都是标准的,就是有标题(),也有(),如果你是用dreamweaver或者frontpage设计的,那么除非你故意删掉,它们都在存在的。next,我来修改

一,设计搜索表单
在网站的根目录下建个search.htm,内容如下


搜索表单




 



 









次に、検索プログラム
処理用の search.php ファイルをルート ディレクトリに作成します。 search.htm フォームの内容は以下の通りです
//検索キーワードを取得します
$keyword=trim($_POST["keyword"]);
//空かどうかを確認します
if($キーワード ==""){
echo "検索したいキーワードを空にすることはできません";
exit;// プログラムを終了します
}
?>

このように、訪問者が入力したキーワードが空の場合、 、ヒントを作ることができます。以下はすべてのファイルのループです。

関数 opendir、readdir、または PHP Directory クラスを使用して、すべてのファイルを再帰的に走査できます。現在は前者を使用します。
//すべてのファイルを走査する関数
function listFiles($dir){
$handle=opendir($dir);
while(false!==($file=readdir( $ handle))){
if($file!="."&&$file!=".."){
//ディレクトリの場合は検索を続行
if(is_dir("$dir/$file" )){
listFiles("$dir/$file");
}
else{
//ここで処理
}
}
}
}

?> 赤いテキストでファイルを検索できます。読み取りと処理 以下は、ファイルの内容を読み取り、その内容にキーワード $keyword が含まれているかどうかを確認し、含まれている場合はファイルのアドレスを配列に代入します。

//$dir は検索ディレクトリ、$keyword は検索キーワード、$array は格納された配列です
function listFiles($dir,$keyword,&$array){
$handle=opendir( $ dir);
while(false!==($file=readdir($handle))){
if($file!="."&&$file!=".."){
if(is_dir(" $ dir/$file")){
listFiles("$dir/$file",$keyword,$array);
}
else{
//ファイルの内容を読み取ります
$data=fread(fopen("$dir /$ file","r"),filesize("$dir/$file"));
//それ自体は検索しません
if($file!=”search.php”){
//一致するかどうか
if( eregi("$keyword",$data)){
$array[]="$dir/$file";
}
}
}
}
}
}
// 配列を定義 $array
$array=array ();
//関数を実行
listFiles(".","php",$array);
//検索結果を出力
foreach($array as $value){
echo "$value"." }
?>

次に、この結果を最初のプログラムと組み合わせて、キーワードを入力すると、Web サイト内の関連する結果が検索されたことがわかります。現在改善中です。 1. コンテンツのタイトルをリストします


if(eregi("$keyword",$data)){
$array[]="$dir/$file";
}

if(eregi(" $keyword",$data)){
if(eregi("(.+)",$data,$m)){
$title=$m["1"];
}
else{
$title="No title";
}
$array[]="$dir/$file $title";
}
原則として、xxx< file content /title> を選択し、タイトルとして xxx を取り出します。見つからない場合は、タイトルに「no title」という名前を付けます <br /> <br /> 2. Web ページのコンテンツの件名部分のみを検索します。 </p> Web ページを作成するときは、必ず大量の HTML コードが含まれますが、これらは検索対象ではないため、削除する必要があります。現在、strip_tags で正規表現を使用していますが、すべてを削除できるわけではありません。 <p> Put<br /> $data=fread(fopen("$dir/$file","r"),filesize("$dir/$file"));<br /> // 自身を検索しません<br /> if($file!=” search .php”){<br /> //<br />と一致するかどうか if(eregi("$keyword",$data)){<br /> <br />に変更 $data=fread(fopen("$dir/$file","r") ,filesize ("$dir/$file"));<br /> if(eregi("<body([^>]+)>(.+)</body>",$data,$b)) {<br> $body=strip_tags($b["2"]);<br> }<br> else{<br> $body=strip_tags($data);<br> }<br> if($file!="search.php"){<br> if(エレギ( "$キーワード",$body)){ <br></p> <p> 3. タイトルにリンクを追加します <br> foreach($array as $value){<br> echo "$value"."<br>n";<br /> }<br /> に変更します <br /> foreach($array as $value){<br /> // 分割 <br /> list($filedir,$title)=split(“[ ]”,$value,”2”);<br /> //出力<br /> echo "<a href=$filedir>$value</a>" . "<br>n";<br> }<br> 4 タイムアウトを防ぐ<br> ファイル数が多い場合、PHP の実行時間がタイムアウトしないようにする必要があります。ファイルヘッダーに <br> set_time_limit(“600”);<br> を追加できます。単位は秒なので、上記の制限は 10 分に設定されます。 </p> <p> <br> したがって、完全なプログラムは次のとおりです <br> <?php<br /> set_time_limit("600");<br /> //検索キーワードを取得します<br /> $keyword=trim($_POST["keyword"]);<br /> // キーワードであるかどうかを確認しますempty <br /> if($keyword==""){<br /> echo "検索したいキーワードを空にすることはできません";<br /> exit;//プログラムを終了します<br /> }<br /> function listFiles($dir,$keyword,&$array) {<br /> $handle=opendir($dir);<br /> while(false!==($file=readdir($handle))){<br /> if($file!="."&&$file!="..") {<br /> if(is_dir("$dir/$file")){<br /> listFiles("$dir/$file",$keyword,$array);<br /> }<br /> else{<br /> $data=fread(fopen("$dir /$ file","r"),filesize("$dir/$file"));<br /> if(eregi("<body([^>]+)>(.+)</body> ", $data,$b)){<br> $body=strip_tags($b["2"]);<br> }<br> else{<br> $body=strip_tags($data);<br> }<br> if($file!= search.php"){<br> if(eregi("$keyword",$body)){<br> if(eregi("<title>(.+)",$data,$m)){
$ title=$m["1"];
}
else{
$title="タイトルなし";
}
$array[]="$dir/$file $title";
}
}
}
}
}
}
$array=array();
listFiles(".","$keyword",$array);
foreach($array as $value){
//
list($filedir, $ title)=split("[ ]",$value,"2");
//出力
echo "$title "." }
?>

ここまで、独自の検索エンジンを構築してきました。コンテンツ処理部分を変更することで、タイトル検索やコンテンツ検索の機能を実現することもできます。ページネーションも考慮してください。これは内緒にしておいてください。

ここで、eregi の代わりに preg_match を使用した方がはるかに高速になることを説明しましょう。分かりやすいように一般的に使われているエレギを使用します


完了。 adiOS

テクノロジーが未来を変える

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート