
Быстрый поиск
Введите фрагмент названия статьи для поиска
Автоматическое получение Яндекс тИЦ для сайтов
13.12.2011 | Категория: Web-мастеру и не только | Автор: ManHunter
Тематический индекс цитирования (тИЦ) используется в поисковой системе Яндекс и определяет "авторитетность" интернет-ресурсов. Этот индекс используется в различных СЕО-инструментах, однако сам Яндекс не предоставляет никаких средств для его легального получения. Но нам на помощь может прийти разработка самого Яндекса - Яндекс.Бар, в котором при серфинге отображается тИЦ открытого сайта. Очевидно, что эти данные Яндекс.Троян получает от самого сервера, осталось отследить любым сниффером, куда идет обращение и в каком формате. В отличие от Google PR, с Яндексом проблем нет. Никаких дополнительных контрольных сумм для ссылки считать не надо, да и тИЦ единый для всего домена. В итоге все ограничивается одним простым запросом типа:http://bar-navig.yandex.ru/u?ver=2&show=32&url=http://www.manhunter.ru
В качестве значения последнего параметра url передается имя проверяемого домена. В ответ вернется XML-файл, подобный приведенному ниже:
Code: Убрать нумерацию
- <?xml version="1.0" encoding="windows-1251" ?>
- <urlinfo>
- <url domain="www.manhunter.ru"><![CDATA[/]]></url>
- <yaca url="www.manhunter.ru"/>
- <tcy rang="3" value="70"/>
- <topics></topics>
- <textinfo></textinfo>
- </urlinfo>
Просмотров: 6475 | Комментариев: 8
Релевантный поиск по базе MySQL
04.11.2011 | Категория: Web-мастеру и не только | Автор: ManHunter

Релевантный поиск по базе MySQL
Я уже писал о возможностях поиска с учетом морфологии, а теперь обещанная статья о релевантном поиске по базе MySQL. Как разъясняют словари, релевантность - в поисковых системах - мера соответствия результатов поиска задаче поставленной в запросе. То есть чем ближе найденный результат соответствует искомому, тем выше в результатах поиска он должен находиться. Применительно к выборке из базы, в строках результата релевантность должна быть представлена неким числовым значением, по которому эта выборка должна быть отсортирована.
Начнем с теории. Если мы ищем строку из нескольких слов среди нескольких текстов, то наибольшей релевантностью обладает текст, в котором встречается вся эта строка целиком и точно в том виде, как ее задали к поиску. Затем идут тексты, где есть все слова из искомой фразы, но расположенные не по порядку. После них идут тексты, где встречаются только отдельные слова, и, чем меньше слов из фразы, тем ниже релевантность. К тому же слова из заголовка текста должны иметь поисковый вес больше, чем такие же слова из текста.
Читать статью целиком »
Просмотров: 19416 | Комментариев: 13
Поиск с учетом морфологии русского языка
20.07.2011 | Категория: Web-мастеру и не только | Автор: ManHunter
Семантический поиск текста с учетом морфологии - серьезная задача, с которой даже крупные поисковики справились с разной степенью успеха. Но частично реализовать поиск с учетом разных форм слов русского языка вы можете самостоятельно. Для этого лучше всего воспользоваться PHP-классом phpMorphy. Это очень удобное средство для организации поиска с учетом морфологии русского, английского, украинского, эстонского или немецкого языков. Словари для каждого языка суммарно занимают около 10 Мб, а сам подключаемый скрипт - чуть меньше 30 Кб. При этом не требуется устанавливать на сервер дополнительное программное обеспечение, все будет работать на самом обычном хостинге. Обновленные версии phpMorphy с поддержкой современных версий PHP7 и PHP8 можно скачать с репозитория.Начнем с подключения phpMorphy. Это делается очень просто. Сперва скачайте дистрибутив, словари, распакуйте все это в отдельную папку, соблюдая структуру вложенных каталогов. Словари разместите в папке dict. Теперь откроем файл примера из папки examples и посмотрим настройки:
Code (PHP) : Убрать нумерацию
- // подключение движка phpMorphy
- require_once('src/common.php');
- // настройки движка
- $opts = array(
- ...
- );
- // подключение словарей русского языка
- $dir = 'dicts';
- $dict_bundle = new phpMorphy_FilesBundle($dir, 'rus');
- // создание класса
- $morphy = new phpMorphy($dict_bundle, $opts);
Читать статью целиком »
Просмотров: 21318 | Комментариев: 18
Как сделать свой сервис коротких ссылок
02.06.2011 | Категория: Web-мастеру и не только | Автор: ManHunter
С ростом популярности социальных сетей типа Twitter, где длина сообщения ограничена, возникла необходимость в специальных сервисах для сокращения длинных ссылок. В результате появилось много сайтов, где вы можете ввести длинную ссылку и вместо нее получить короткую. При переходе по такой ссылке вы сперва попадаете на сайт-редиректор, а уже с него выполняется автоматический переход на нужную ссылку. Я даже встречал такие сокращенные ссылки в печатных изданиях, а не только в интернете. Ничего сложного в реализации такого сервиса нет, и сейчас мы сделаем что-нибудь подобное.Начинается все с покупки короткого доменного имени. Все красивые имена уже разобраны или захвачены киберсквоттерами, но кое-что еще можно найти. В конце концов, рядовому пользователю нет особой разницы, по красивой ссылке идти или по некрасивой, главное чтобы она помещалась в его сообщение. Хорошо, домен у нас есть, едем дальше.
А дальше нам надо продумать структуру базы данных, в которой будут храниться короткие ссылки и их соответствия. Поскольку мы делаем сейчас самый простейший сервис, то пусть структура базы будет такой:
CREATE TABLE IF NOT EXISTS `redirector_links` (
`link_id` INT(11) NOT NULL AUTO_INCREMENT COMMENT 'ID ссылки в базе',
`link_hash` VARCHAR(32) COMMENT 'Хэш ссылки',
`link_url` TEXT COMMENT 'Адрес ссылки',
PRIMARY KEY (`link_id`),
KEY `link_hash` (`link_hash`)
) ENGINE=MyISAM
Хэш ссылки нужен для того, чтобы не создавать в базе дубли для повторяющихся ссылок. В принципе, сюда же можно добавить счетчик для сбора статистики переходов, добавить принадлежность к какому-нибудь владельцу и т.п. Все зависит от поставленных задач.
Читать статью целиком »
Просмотров: 31287 | Комментариев: 24
Создание древовидного списка из массива
01.05.2011 | Категория: Web-мастеру и не только | Автор: ManHunter
Еще одна из часто встречающихся задач при разработке сайтов - создание многоуровневых древовидных списков. Отдельные элементы списков хранятся в массиве и объединяются между собой через связку полей "ID элемента" - "Родительский элемент". Это могут быть выпадающие меню с несколькими уровнями субменю, каталоги товаров по категориям, карты сайта и т.п. Попробуем описать трехуровневое вложенное меню. Для этого зададим массив вручную, а в реальной ситуации он может быть, например, получен из базы. Количество уровней вложенности может быть произвольным, три уровня выбраны исключительно для примера.Code (PHP) : Убрать нумерацию
- // Построение из массива древовидного списка без использования рекурсии
- $menu=array(
- 1=>array('name'=>'Овощи', 'parent'=>0),
- 6=>array('name'=>'Капуста', 'parent'=>1),
- 7=>array('name'=>'Помидоры', 'parent'=>1),
- 9=>array('name'=>'Салат', 'parent'=>1),
- 18=>array('name'=>'Китайский салат', 'parent'=>9),
- 12=>array('name'=>'Тыква', 'parent'=>1),
- 16=>array('name'=>'Редиска', 'parent'=>1),
- 2=>array('name'=>'Фрукты', 'parent'=>0),
- 13=>array('name'=>'Бананы', 'parent'=>2),
- 14=>array('name'=>'Ягоды', 'parent'=>2),
- 19=>array('name'=>'Арбуз', 'parent'=>14),
- 20=>array('name'=>'Клубника', 'parent'=>14),
- 3=>array('name'=>'Животные', 'parent'=>0),
- 4=>array('name'=>'Растения', 'parent'=>0),
- 8=>array('name'=>'Конопля', 'parent'=>4),
- 11=>array('name'=>'Мак', 'parent'=>4),
- 17=>array('name'=>'Сахарный тростник', 'parent'=>4),
- 5=>array('name'=>'Насекомые', 'parent'=>0),
- 10=>array('name'=>'Тараканы', 'parent'=>5),
- );
Code (PHP) : Убрать нумерацию
- // Построение дерева за один проход
- foreach($menu as $menu_id=>$data) {
- // Прописать в родительском узле ссылку на пункт меню
- $menu[$data['parent']]['child'][$menu_id]=&$menu[$menu_id];
- }
- // Готовый массив находится в $menu[0]['child']
- $sorted_menu=(array)$menu[0]['child'];
Читать статью целиком »
Просмотров: 11711 | Комментариев: 11


