« Поставить закладку » « Сделать стартовой »

« Форумы » « Блоги » « Статьи » « Новости » « Файлы » « Realcoding IRC » « Site map » « Поиск »


Главная Главная
Анонсы Анонсы
Форумы Форумы
Каталог Каталог
Поиск Поиск
Опросы Опросы
Книжный магазин Книжный магазин
Реклама на сайте
Публикации Публикации
Партнеры Партнеры
Карта Карта сайта
Рассылки Рассылки
RSS экспорт
Настройки Настройки
О нас пишут О нас пишут
Контакты Контакты
Гостевая книга Гостевая книга


ПнВтСрЧтПтСбВс
    1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 29 30 31    
    Популярное
Функция GetRgnBox

Как хранить настройки программ

Стандартные диалоги.

Запуск запроса на выполнение

Функция AccessResource

Ошибки

Определяемое Преобразование Типа

Функция GetPrivateProfileInt

Инкапсуляция ISL и 802.1Q

Работа с буфером обмена


    Архив файлов



    Сообщества



    Документация

Статьи:: Интернет технологии :: PHP :: Создание собственной RSS ленты


отправить ссылку другу версия для печати  Обсудить на форуме

Создание собственной RSS ленты

Создание собственной RSS ленты. Подробное описание.

  В этой статье мы будем создавать собственную RSS-ленту с помощью PHP и MySQL. Что бы не быть голословным, рассмотрим создание RSS-ленты на примере сайта http://devoid.com.ua. Сама RSS-лента находится здесь и содержит 10 новых статей сайта.
  Для начала немного теории без которой нельзя приступать к программированию. Итак, как гласит спецификация RSS 2.0:
  RSS - формат передачи веб-контента. Название технологии — акроним "Really Simple Syndication", то есть, "по-настоящему простая передача информации". Пример RSS-ленты можно найти здесь и здесь

.

  RSS — диалект XML. Все файлы RSS обязаны соответствовать спецификации XML 1.0.
  Каждая RSS-лента в подтверждение вышесказанному должна начинаться со строк:

<?xml version="1.0" encoding="windows-1251" ?>
<rss version="2.0">
  Элементы RSS бывают обязательные и необязательные.
  В рамках теоретической части этой статьи мы рассмотрим только обязательные элементы.
Итак, для <channel> обязательными элементами являются:
  • <title> - краткое название канала. В нашем случае например: www.devoid.com.ua - портал программистов!
  • <description> - описание канала. Например: 10 новых статей сайта www.devoid.com.ua.
  • <link> - URL сайта связанного с каналом (www.devoid.com.ua).
  Каждая наша статья будет содержаться в элементе <item>, для которого обязательными являются:
  • <title> - в нашем случае название статьи.
  • <link> - ссылка на статью.
  • <description> - текст самой статьи.
Необязательными тегами которые используются на сайте http://devoid.com.ua является <pubDate> для <item>, и <img>, <copyright> для <channel>.
  На этом теоретическую часть можно закончить. О дополнительных элементах RSS-ленты можно прочитать в Спецификации RSS 2.0. Обычно все статьи хранятся в базе данных. Потому следующие этапы я опишу в общих чертах:
  • Подключаемся к БД используя стандартную функцию mysql_connect();
  • Получаем 10 новых статей. Примерный запрос выглядит так: mysql_query("SELECT * FROM `articles` ORDER BY `date` DESC LIMIT 0,10");
  • Потом форматируем нашу RSS-ленту.
Далее я привожу код в общих чертах, который формирует XML:
echo("<?xml version="1.0" encoding="windows-1251" ?>rn");
echo("<rss version="2.0">rn");
echo("<channel>rnrn");

echo("<title>www.devoid.com.ua - портал программистов. Здесь есть все для программиста!</title>rn");
echo("<link>http://devoid.com.ua</link>rn");
echo("<description>Портал программистов - статьи, исходники, FAQ, форум, блог.</description>rn");
echo("<copyright>Copyright 2007, devoid.com.ua</copyright>rnrn");

echo("<img>rn");
echo("<url>http://devoid.com.ua/design/img/button.gif</url>rn");
echo("<title>www.devoid.com.ua - портал программистов. Здесь есть все для программиста!</title>rn");
echo("<link>http://devoid.com.ua</link>rn");
echo("</img>rnrn");

connect_to_db(); // функция соединения с БД MySQL
$query = "SELECT * FROM `articles` ORDER BY `data` DESC LIMIT 0,10";
$res = mysql_query($query);
while($item = mysql_fetch_array($res))
{
	$descr = "";
	$descr = stripslashes($item["description"]);
	$item["title"] = htmlspecialchars($item["title"]);

	echo("rn<item>rn");
	echo("<title>".$item["title"]."</title>rn");
	echo("<link>".$link.".html</link>rn");
	echo("<description><![CDATA[".$descr."]]></description>rn");
	echo("<pubDate>".$item["data"]."</pubDate>rn");
	echo("</item>rnrn");
}
echo("</channel>rn");
echo("</rss>rn");
  Код сам по себе не сложный, но есть определенные моменты, которые требуют рассмотрения:
 
  • сначала формируем "хедер" нашего файла, где указываем версию RSS и XML.
  • Далее заполняем обязательные элементы <channel> и в цикле, выводим все элементы <item>, динамически заполняя нужные элементы.
  • Перед выводом текста статьи, применяя к нему функцию stripslashes().
  • К названию статьи применяем функцию htmlspecialchars(), которая преобразует специальные символы в HTML сущности.
  • Для того чтобы можно было сохранять разметку гипертекста в теле статьи, нужно текст статьи добавлять в таком виде <![CDATA[".$descr."]]>.
Этого материала достаточно для того чтобы научиться писать свои ленты RSS-новостей. В следующих статьях я напишу о том, как написать на C# Csharp RSS-ридер для чтения лент RSS с сайта http://devoid.com.ua.
  Спасибо за внимание и удачи вам в написании кода!

Макагон Сергей, http://devoid.com.ua  




Рубрика: PHP




XML документация в C#.

XML в .NET

Сегодня речь пойдет об одной интересной и полезной возможности языка С#, которая поможет нам в документировании кода. Она называется «XML документация» или «Документирующие комментарии XML». Это такие специальные теги XML, которые содержаться в комментариях и описывают свойства или методы в конкретном файле. Так вот, есть по крайней мере три веских причины, почему всегда следует заполнять XML комментарии.


Подробнее... | Рубрика: XML в .NET | Добавлено: 08.10.2008

Курсоры в MySQL 5.

MySQL

Начиная с 5-ой версии, MySQL имеет возможность создавать курсоры. Курсор — это виртуальная таблица, предоставляющая альтернативный способ просмотра табличных данных. Курсор не содержит данных, а лишь ссылается на них из других таблиц. Из этого вытекает ряд особенностей, но об этом ниже.


Подробнее... | Рубрика: MySQL | Добавлено: 08.10.2008

Microsoft опубликовала подробности о сессиях Windows 7.

Мероприятия

В преддверии конференции WinHEC компания Microsoft опубликовала подробный список сессий, которые пройдут в рамках конференции. Довольно-таки большое количество выступлений будет посвящено Windows 7, что не может не радовать. Принимая во внимание тот факт, что PDC и WinHEC разделяют несколько дней, а пройдут они в одном здании - Los Angeles Convention Center, - можно несколько дней поиграть в прятки, спрятавшись в какой-нибудь комнате, но зато бесплатно посетить WinHEC.


Подробнее... | Рубрика: Мероприятия | Добавлено: 08.10.2008

Остальные статьи:

Microsoft делится подробностями о том, что будет после Windows
Тестируем новый javascript от нового браузера Google
MySQL Query Cache
Использование провайдеров компиляции в Asp.net
Чего мы ждем от C# 4.0
Delphi 2009 и C++Builder 2009
Джоэл Спольски и Джеф Этвуд запустили новый вебсайт для программистов - StackOve...
Поиск кода Google /* что нового? */
10 jQuery скриптов для улучшения интерфейса
Генераторы отчетов FastReport 4 и QuickReport 5: версии 2008 года
День программиста — набор стерeотипов
Индусские програмисты
Вышел Django 1.0
Портативная версия Google Chrome Portable
Исходные коды .Net Frameword 3.5 SP1 для отладки в Visual Studio
Пишем правильный online WYSIWYG-редактор


Цитата дня (все,добавить):

Портал фрилансеров

    Рубрикатор

Программирование

C/С++
Обучение
Windows API
XAML
Моделирование
Паттерны
Visual Basic 7 .NET
WxWidgets
Функции WinApi
Функции С++
Разработка под Mac OS
Eiffel
Visual Studio 2008
UI дизайн
Алгоритмы
Конкурсные статьи
Turbo Pascal
Visual Studio
CASE-средства
Visual Studio 2005
Без VCL
Delphi
Тех. документация
Тестирование
Software Testing
ООП
TCP/IP
Google Android
Windows Installer
.NET Framework
Драйвера
C# C Sharp
Справка
Проектирование
Информ. системы
Visual Basic
Assembler
Оптимизация кода
Gtk+
Компоненты
Реинжиниринг
Управление проектами
Extreeme programming
Lotus Notes
Алгебраическое проектирование

Интернет технологии

PHP
Perl
ASP
WAP
Cookies
SSI
CGI
Web Servers
VB Script
DNS
CSS
XML
Html
Java Script
Java2ME
Firewall
Flash
.htaccess
Apache
VRML
Протоколы
Поисковые системы
Технология JAVA
Учебник по PHP
Учебник по JavaScript
Учебник по XML
Java Q&A
AJAX
DHTML
XHTML
Dreamweaver
Web 2.0
Python
Вебмастеру
Cisco
Ruby on Rails
Silverlight

Базы данных

Access
InterBase
MySQL
Oracle
ADO .NET
Основы SQL
Учебник по Access 2002
MS
Microsoft FoxPro
Доступ к данным
XML в MS SQL Server 2000
ODBC и MyODBC
Обучение
Caché
DB2
PostgresSQL
Sybase
Теория
Хранилища данных
Безопасность
Реляционные данные
MySQL и mSQL

Остальное:

Разное
Обзоры книг
Безопасность
Графика и дизайн
Юмор
Linux
Фракталы
Microsoft Axapta
Многоядерность
Сети
Microsoft Office
Работа
MS-DOS
Криптография
Графика и игроделание
Новости SDK
Системы защиты
Учебник по AutoCad
CVS
Windows XP
Windows Server 2003
Windows Vista
Windows 7
Мероприятия

    Кто на сайте
Вы не зарегистрированы.
Имя:

Пароль:

Запомнить

Регистрация позволит Вам пользоваться дополнительными сервисами.
Сейчас на сайте:
Гостей: 247
Пользователей: 0