Как было замечено, каждая статья в оглавлении подключена к сценарию Perl arti-cle.cgi, который получает идентификатор статьи в качестве входного параметра. Этот сценарий использует идентификатор статьи для поиска всего текста статьи и отображения ее в виде сформатированной Web-страницы.
Ниже представлен программный код этого сценария.
Листинг 20.34.
#!/usr/bin/perl
# считать необходимые модули use DBI;
use CGI;
# инициировать объект CGI $cgi = new CGI();
# распечатать HTTP- заголовки print $cgi->header();
# проверка отправки идентификатора статьи
# если да - очистить его и использовать if (! $cgi->param(' aid'))
{
print "Невозможно найти идентификатор статьи, завершение работы
die;
}
else
{
$aid = $cgi->param('aid');
}
# распечатать заголовок страницы print $cgi->start_html;
# подключиться к базе данных
my $dbh = DBI->connect("DBI:mysql:database=dbl;host=localhost", "root", "pass", {'RaiseError' => 1});
# выполнить запрос
my $sth = $dbh->prepare("SELECT atitle, abody FROM articles WHERE aid='$aid'");
$sth->execute();
# если результат имеется
# распечатать содержимое статьи
# иначе - распечатать ошибку if ($sth->rows() > 0)
{
$ref = $sth->fetchrow_hashref();
print "<font face="Verdana, Arial" size="4"
color="#66CCOO">n";
print $ref->{'atitle'}, "n";
print "</font>n"; print "<p>n";
print "<font face="Verdana, Arial" size="2"
color="Black">n";
print $ref->{ 'abody'}, "n"; print "</font>n";
}
else
{
print " Невозможно найти содержимое страницы, завершение работы
die;
}
# закрыть соединение с базой данных $sth->finish(); $dbh->disconnect();
# распечатать нижний колонтитул страницы
# со ссылкой на комментарии print <<EOF;
<font face="Verdana, Arial" size="2" color="Black">
<a href="post.cgi?aid=$aid"> Прокомментировать</a> эту статью. <!font>
EOF
print $cgi->end_html;
Так как для правильного функционирования этого сценария требуется идентификатор статьи, первым шагом является проверка наличия этого идентификатора. Модуль CGI.pm существенно упрощает эту задачу. Метод param() применяется для передачи параметров через переданную сценарию строку запроса или из отправленных методом POST данных. Если идентификатор статьи не найден, сценарий завершает свою работу и выводит сообщение об ошибке.
Предположим, что идентификатор статьи передан сценарию правильно и методы Perl DBI-интерфейса используются для создания запроса после получения полного текста статьи. Тогда полученный полный текст статьи выводится в виде отформатированной Web-страницы. В нижней части страницы содержится ссылка для размещения комментариев посетителей. Для этого используется сценарий post.cgi. Заметим, что сценарий передает идентификатор статьи с помощью метода GET.
Содержание статьи представлено на рис. 20.4.
Конечно, можно удивиться, почему еще не сформировано дерево комментариев, о котором шла речь. Мы вернемся к этому сценарию в разделе "Создание древовидного оглавления комментариев", где и добавим такую возможность.
ТОП-10 популярных
Для работы с вещественными числами в MySQL предусмотрено три типа данных - это типы FLOAT, DOUBLE, DECIMAL. Числовой тип FLOAT...
БОЛЬШЕ БОЛЬШИХ LCD-мониторов
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...
Больше больших LCD-мониторов
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...
НОУТБУК с блестящим экраном
Eсли выпустившая ноутбук фирма предлагает его в качестве «замены настольному ПК», то это должно подразумевать под собой нечто большее, чем...
Eсли выпустившая ноутбук фирма предлагает его в качестве «замены настольному ПК», то это должно подразумевать под собой нечто большее, чем...
Иди и пиши. TravelMate C100
Планшетный компьютер платформы Tablet PC обязан в первую очередь быть легким, способным достаточно долго работать без подзарядки батарей. Эти требования...
Планшетный компьютер платформы Tablet PC обязан в первую очередь быть легким, способным достаточно долго работать без подзарядки батарей. Эти требования...
Магнито-оптический дисковод DynaMO
Cейчас, когда традиционные флоппи-дисководы на долгие годы замерли в своем развитии, поиск альтернативных носителей продолжается, и ситуация, казалось бы, разрешилась...
Cейчас, когда традиционные флоппи-дисководы на долгие годы замерли в своем развитии, поиск альтернативных носителей продолжается, и ситуация, казалось бы, разрешилась...
Компьютер для гурманов.«Эксимер ДМ»
Российская компания «Эксимер ДМ», известная как производитель настольных компьютеров, рабочих станций, серверов и ноутбуков, выступила техническим спонсором проведения торжеств, посвященных...
Российская компания «Эксимер ДМ», известная как производитель настольных компьютеров, рабочих станций, серверов и ноутбуков, выступила техническим спонсором проведения торжеств, посвященных...
Для длинных строк, т.е. строк длиннее 255 символов, в MySQL предусмотрены типы BLOB (Binary Large Object, большой двоичный объект) и...
В дополнение к календарным типам, предназначенным для хранения даты и времени отдельно, MySQL также поддерживает гибридные типы данных DATETIME и...
Вообще, к изменению настроек сервера прибегают очень редко. В MySQL программа заранее настроена так, чтобы соответствовать самым распространенным и основным...
Все о MySQL. Выборка содержимого статьи
28-12-2009
<< Предыдущая статья | Следующая статья >> |
Все о MySQL. Вспомогательные функции. Продолжение. | Все о MySQL. Добавление комментариев |