Просмотр файла search.php

Размер файла: 5.85Kb
<?php
define( 'WBCAT', 1 );
require_once ('inc/head.php');
echo '<div class="zag">Поиск сайта</div>';
if ($settings['search'] == false && !$allow) {
echo '<div class="title">Данный модуль закрыт администратором !</div>';
require_once ('inc/foot.php');
exit;
}
if ($allow) { 
echo ''.($settings['search'] == false ? '<div class="title"><img src="images/red.png"/><small> <b>Модуль отключен для гостей ! Включить можно в <a href="adm/index.php?mod=set">Общих настройках</a></b></small></div>' : '<div class="title"><small>Статус модуля</small> : <img src="images/green.png"/></div> ').'';
}

echo '<div class="title"><form action="'.$_SERVER['PHP_SELF'].'" method="POST" name="form">
Введите запрос <small>[min 4 , max 60 символов]</small><br/>
<input type="text" name="search" maxlenght="60" value="'.htmlspecialchars($_POST['search']).'"/><br/>
Параметры поиска :<br/>
<select name="m">
<option value="1">url</option>
<option value="2">название сайта</option>
<option value="3">описание сайта</option>
</select><br/>
<input name="n" type="checkbox" value="1"/> Точный поиск<br/>
<input type="submit" name="go"value="Поиск">
</form></div>';

if (isset($_POST['go']) ) {
     if (empty($_POST['search'])) {
	     $error[1] = 'Вы не ввели адрес сайта !';
	    }
     if (mb_strlen($_POST['search']) < 4 || mb_strlen($_POST['search']) > 64 ) {
	     $error[2] = 'Длина запроса должна быть не менее 4 символов и не привышать 64 символа !';
		}
		}
	 	 if (!empty($error)) {
			     echo '<div class="title">';
			       foreach($error as $value) {
                     echo "<b>$value</b> <br />";
                    } 
					echo '</div>';
					require_once ('inc/foot.php');
					exit();
			}

	              $mm = isset ($_POST['m']) ? intval($_POST['m']) : '';
				  $mm = $mm ? $mm : rawurldecode(trim($_GET['m']));
				  
				  $n = isset ($_POST['n']) ? $_POST['n'] : '';
				  $n = $n ? $n : rawurldecode(trim($_GET['n']));
				  
	 			 $search = isset ($_POST['search']) ? trim($_POST['search']) : '';
				 $search = strtr($search, array('_' => '\\_', '%' => ' ','$' => ' ', '*' => '%'));
                 $search = $search ? $search : rawurldecode(trim($_GET['search']));
				 if ($search) {
				 $search_db = 'LIKE \'' . mysql_real_escape_string('%' . $search . '%') . '\'';
				 if ($_POST['n'] == false) $search_db = 'LIKE \'' . mysql_real_escape_string('%' . $search . '%') . '\'';
				 if ($_POST['n'] == true) {
				      $search_db = '= "'.mysql_real_escape_string($search).'"';
				 }
				 $zap = '`about`';
				 if ($_POST['m'] == 1 || $_GET['mm'] == 1) $zap = '`url`';
				 if ($_POST['m'] == 2 || $_GET['mm'] == 2) $zap = '`name`';
				 if ($_POST['m'] == 3 || $_GET['mm'] == 3) $zap = '`about`';
				 
				 $num = 2; 
                 $page = intval($_GET['page']); 
                 $result = mysql_query('SELECT COUNT(*) FROM `sites` WHERE  '.$zap.' '.$search_db.' '); 
                 $posts = mysql_result($result, 0); 
                 $total = intval(($posts - 1) / $num) + 1; 
                 if(empty($page) or $page < 0) $page = 1; 
                 if($page > $total) $page = $total; 
                 $start = $page * $num - $num; 
                 $result = mysql_query('SELECT * FROM `sites` WHERE '.$zap.' '.$search_db.' ORDER BY `id` DESC LIMIT '.$start.', '.$num.'');
				 $counter= $start;
				 if ($posts > 0) {
	             while ($ms = mysql_fetch_array($result)) { 
                      $counter++;	             
	                  echo '<div class="main">'.$counter.'. '.$ms['name'].' ['.$ms['url'].']<br/>'.$ms['about'].'<br/><a href="'.$settings['url'].'/cat.php?id='.$ms['id_cat'].'&mod=view&site='.$ms['id'].'">Подробнее</a></div>';
				    }
					
					if ($page != 1) $pervpage = ' <a href= "search.php?search='.$search.'&n=0&mm='.$mm.'&page='. ($page - 1) .'">Назад</a> '; 
// Проверяем нужны ли стрелки вперед 
if ($page != $total) $nextpage = ' <a href="search.php?search='.$search.'&n=0&mm='.$mm.'&page='. ($page + 1) .'">Вперед</a>'; 
if ($page !=1 AND $page != $total) $i = '|';
// Перваяя и последняя страницы
if ($page - 4 > 0) $first = '<a href="search.php?search='.$search.'&n=0&mm='.$mm.'&page=1">1</a>...';
if ($page + 4 <= $total) $last = '...<a href="search.php?search='.$search.'&n=0&mm='.$mm.'&page='.$total.'">'.$total.'</a>';
// Находим две ближайшие станицы с обоих краев, если они есть 
if($page - 2 > 0) $page2left = ' <a href= "search.php?search='.$search.'&n=0&mm='.$mm.'&page='. ($page - 2) .'">'. ($page - 2) .'</a> '; 
if($page - 1 > 0) $page1left = '<a href= "search.php?search='.$search.'&n=0&mm='.$mm.'&page='. ($page - 1) .'">'. ($page - 1) .'</a> '; 
if($page + 2 <= $total) $page2right = ' <a href="search.php?search='.$search.'&n=0&mm='.$mm.'&page='. ($page + 2) .'">'. ($page + 2) .'</a>'; 
if($page + 1 <= $total) $page1right = ' <a href="search.php?search='.$search.'&n=0&mm='.$mm.'&page='. ($page + 1) .'">'. ($page + 1) .'</a>';

// Вывод меню 
if ($posts > $num) {
echo '<div class="title"><small>Навигация :<br/>Страница '.$page.' из '.$total.'</small><br/>'.$pervpage.$i.$nextpage.'<br/>'.$first.$page2left.$page1left.'['.$page.']'.$page1right.$page2right.$last.'</div>';
} 
					
				} else {
                     echo '<div class="title">Ничего не найдено !</div>';
                   }				
echo '<div class="zag">Совпадений : '.$posts.'</div>';
}
echo '<div class="main"><a href="'.$settings['url'].'">Главная</a></div>';
require_once ('inc/foot.php');
?>