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

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


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

Тестирование 64-битных приложений

ПнВтСрЧтПтСбВс
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          
    Популярное
Метод Callee

Восстановление паролей к PWL-файлам

Функция DialogBoxIndirect

FreeBSD 7.0 и ZFS

Сделайте мне красиво - Часть I - Введение в Docking Windows и wxAUI

Запуск процесса печати

FAQ по работе с Дисками и Файлами

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

HTTP Установка защиты на страницу используя MySQL и PHP

Глава 1 Введение




    Архив файлов



    Сообщества



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

Статьи:: C# C Sharp) :: Документация :: Работа с RSS в C# (Csharp). Создание своего RSSReader


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

Работа с RSS в C# (Csharp). Создание своего RSSReader



  Уже несколько лет очень популярной технологией является RSS. Почти на каждом сайте мы можем встретить RSS-ленты в которых содержатся новости сайта, статьи, последние топики форумов, и т.д. Для того чтобы написать свою программу чтения RSS сначала нужно прочитать спецификацию RSS. Краткие сведения о RSS можно почитать в моей статье "Создание собственной RSS-ленты".



  Если говорить в общих чертах, то RSS представляет собой диалект XML. Обязательными элементами которого являются channel, item, title, description, link, pubDate.
  Наша программа будет запрашивать RSS-ленту сайта devoid.com.ua, которая находится здесь и содержит 10 новых статей портала.
  Приступим к программированию. Запускаем Visual Studio 2005 и создаем новый проект под названием, скажем RssReader. На форме кнопка (Button) и Веб-браузер (WebBrowser). Форма выглядит примерно так:

Как видно из дизайнера формы, загружать наш RSS-поток мы будем по нажатию кнопки "Загрузить". Все возможные элементы RSS-ленты мы парсить не будем, ограничимся лишь channel, item и img.
  Следующим шагом и будет написание классов, которые будут отвечать за отпарсенную информацию из RSS-потока.
Класс, который отвечает за настройки канала (channel) будет выглядеть так:

        // Класс который отвечает за настройки канала
        public class ChannelClass
        {
            public string title;
            public string description;
            public string link;
            public string copyright;

            public ChannelClass()
            {
                title = "";
                description = "";
                link = "";
                copyright = "";
            }
        }
  Как видно класс Канала содержит в себе четыре поля, которые говорят сами за себя. Название канала, Описание канала, ссылка, и копирайт (является необязательным).
  Следующим классом который мы создадим будет класс, который будет отвечать за рисунок канала (рисунок является необязательным элементом канала, но в целях получения опыта научимся работать и с ним):
        // Класс рисунка канала
        public class ImageOfChanel
        {
            public string imgTitle;
            public string imgLink;
            public string imgURL;

            public ImageOfChanel()
            {
                imgTitle = "";
                imgLink = "";
                imgURL = "";
            }
        }
Класс довольно простой, и содержит в себе 3 обязательных элемента: Название канала, URL-рисунка, и URL-сайта.
Далее пишем класс, который отвечает за элементы <item> канала:
        // Класс статей
        public class Items
        {
            public string title;
            public string link;
            public string description;
            public string pubDate;

            public Items()
            {
                title = "";
                link = "";
                description = "";
                pubDate = "";
            }
        }
Здесь тоже ничего нового мы не увидели, названия говорят всё за себя.
  Отметим что основным методом нашего RssReadera будет метод считывания данных из RSS-ленты и заполнение данными соответствующих обьектов классов, которые нужно обьявить перед телом метода:
        ImageOfChanel imageChanel = new ImageOfChanel(); // обьект класса рисунка
        Items[] articles; // создаем массив элементов item канала
        ChannelClass channel = new ChannelClass(); // создаем обьект класса ChannelClass
Для ясности я сначала приведу код метода получения данных, а далее подробно распишу:
        bool getNewArticles(string fileSource)
        {
            try
            {
                XmlDocument doc = new XmlDocument();
                doc.Load(fileSource);

                XmlNodeList nodeList;
                XmlNode root = doc.DocumentElement;
                articles = new Items[root.SelectNodes("channel/item").Count];
                nodeList = root.ChildNodes;
                int count = 0;

                foreach (XmlNode chanel in nodeList)
                {
                    foreach (XmlNode chanel_item in chanel)
                    {
                        if (chanel_item.Name == "title")
                        {
                            channel.title = chanel_item.InnerText;
                        }
                        if (chanel_item.Name == "description")
                        {
                            channel.description = chanel_item.InnerText;
                        }
                        if (chanel_item.Name == "copyright")
                        {
                            channel.copyright = chanel_item.InnerText;
                        }
                        if (chanel_item.Name == "link")
                        {
                            channel.link = chanel_item.InnerText;
                        }

                        if (chanel_item.Name == "img")
                        {
                            XmlNodeList imgList = chanel_item.ChildNodes;
                            foreach (XmlNode img_item in imgList)
                            {
                                if (img_item.Name == "url")
                                {
                                    imageChanel.imgURL = img_item.InnerText;
                                }
                                if (img_item.Name == "link")
                                {
                                    imageChanel.imgLink = img_item.InnerText;
                                }
                                if (img_item.Name == "title")
                                {
                                    imageChanel.imgTitle = img_item.InnerText;
                                }
                            }
                        }

                        if (chanel_item.Name == "item")
                        {
                            XmlNodeList itemsList = chanel_item.ChildNodes;
                            articles[count] = new Items();

                            foreach (XmlNode item in itemsList)
                            {
                                if (item.Name == "title")
                                {
                                    articles[count].title = item.InnerText;
                                }
                                if (item.Name == "link")
                                {
                                    articles[count].link = item.InnerText;
                                }
                                if (item.Name == "description")
                                {
                                    articles[count].description = item.InnerText;
                                }
                                if (item.Name == "pubDate")
                                {
                                    articles[count].pubDate = item.InnerText;
                                }
                            }
                            count += 1;
                        }


                    }
                }
                return true;
            }
            catch (Exception ex)
            {
                return false;
            }
        }
  Не стоит пугаться столь большого обьема кода, на самом деле он довольно прост. Следует отметить также, что так как RSS является диалектом XML, то и работать мы будем с ним как с XML-документом. Для этого нужно в uses добавить XML:
using System.Xml;
using System.IO;
using System.IO; - тоже добавьте, это нам понадобится позже.
  Итак, функция getNewArticles(string fileSource) принимает в качестве параметра ссылку на RSS-поток, и возвращает либо true при успешной работе, либо false при неудачной попытке. Весь код помещен в try...catch для отслеживания исключительных ситуаций.
Далее идем по коду:
  XmlDocument doc = new XmlDocument();
  doc.Load(fileSource);
Создаем обьект класса doc и загружаем в него наш RSS-поток методом Load(fileSource).
                XmlNodeList nodeList;
                XmlNode root = doc.DocumentElement;
                articles = new Items[root.SelectNodes("channel/item").Count];
                nodeList = root.ChildNodes;
                int count = 0;
  Создаем XmlNode root - который будет содержать корневой элемент XML.
  Далее получаем количество элементов item в нашем RSS-потоке, используя SelectNodes() и выражение XPath, которое позволяет это сделать.
  nodeList получает все элементы channel.
  count - используется как индексатор массива articles[].
foreach (XmlNode chanel in nodeList)
{
	...
}
  Этим циклом мы проходим по всем элементам cnannel. Обрабатывая название канала, описание, ссылку - этими строками:
foreach (XmlNode chanel_item in chanel)
                    {
                        if (chanel_item.Name == "title")
                        {
                            channel.title = chanel_item.InnerText;
                        }
                        if (chanel_item.Name == "description")
                        {
                            channel.description = chanel_item.InnerText;
                        }
                        if (chanel_item.Name == "copyright")
                        {
                            channel.copyright = chanel_item.InnerText;
                        }
                        if (chanel_item.Name == "link")
                        {
                            channel.link = chanel_item.InnerText;
                        }
						...
  Когда мы находим элемент <img> или <item>, который содержит тоже элементы, мы просто запускаем еще один цикл, который обрабатывает их:
if (chanel_item.Name == "img")
    {
       XmlNodeList imgList = chanel_item.ChildNodes;
       foreach (XmlNode img_item in imgList)
       {
            if (img_item.Name == "url")
            {
                imageChanel.imgURL = img_item.InnerText;
            }
            if (img_item.Name == "link")
            {
                imageChanel.imgLink = img_item.InnerText;
            }
            if (img_item.Name == "title")
            {
                imageChanel.imgTitle = img_item.InnerText;
            }
        }
    }

if (chanel_item.Name == "item")
   {
      XmlNodeList itemsList = chanel_item.ChildNodes;
      articles[count] = new Items();

      foreach (XmlNode item in itemsList)
      {
          if (item.Name == "title")
          {
               articles[count].title = item.InnerText;
          }
          if (item.Name == "link")
          {
               articles[count].link = item.InnerText;
          }
          if (item.Name == "description")
          {
              articles[count].description = item.InnerText;
          }
          if (item.Name == "pubDate")
          {
              articles[count].pubDate = item.InnerText;
          }
      }
   count += 1;
   }
После выполнения этой функции, мы имеем обьекты классов, заполненные данными. в imageChanel содержатся все данные о рисунке (если он есть), в channel - все параметры канала, а массив articles - содержит все статьи портала devoid.com.ua (или элементы item в случае парсинга другой RSS-ленты).   Для отображения отпарсенных данных нам и пригодится WebBrowser. Все данные из RSS-потока мы сохраним в виде *.html файла, и потом отобразим его. Для этого напишем простую функцию:
bool generateHtml()
{
 try
 {
   using (StreamWriter writer = new StreamWriter("last_articles.html"))
   {
    writer.WriteLine("<html>");
    writer.WriteLine("<head>");
    writer.WriteLine("<meta http-equiv="content-type" content="text/html; charset=utf-8">");
    writer.WriteLine("<title>");
    writer.WriteLine(channel.title);
    writer.WriteLine("</title>");
    writer.WriteLine("<style type='text/css'>");
    writer.WriteLine("A{color:#483D8B; text-decoration:none; font:Verdana;}");
    writer.WriteLine("pre{font-family:courier;color:#000000;");
	writer.WriteLine("background-color:#dfe2e5;padding-top:5pt;padding-left:5pt;");
    writer.WriteLine("padding-bottom:5pt;border-top:1pt solid #87A5C3;");
    writer.WriteLine("border-bottom:1pt solid #87A5C3;border-left:1pt solid #87A5C3;");
    writer.WriteLine("border-right : 1pt solid #87A5C3;	text-align : left;}");
    writer.WriteLine("</style>");
    writer.WriteLine("</head>");
    writer.WriteLine("<body>");

    writer.WriteLine("<font size="2" face="Verdana">");
    writer.WriteLine("<a href="" + imageChanel.imgLink + "">");
    writer.WriteLine("<img src="" + imageChanel.imgURL + "" border=0></a>  ");
    writer.WriteLine("<h3>" + channel.title + "</h3></a>");

    writer.WriteLine("<table width="80%" align="center" border=1>");
   foreach (Items article in articles)
   {
    writer.WriteLine("<tr>");
    writer.WriteLine("<td>");
    writer.WriteLine("<br>  <a href="" + article.link + ""><b>" + article.title + "</b></a>");
    writer.WriteLine("& (" + article.pubDate + ")<br><br>");
    writer.WriteLine("<table width="95%" align="center" border=0>");
    writer.WriteLine("<tr><td>");
    writer.WriteLine(article.description);
    writer.WriteLine("</td></tr></table>");
    writer.WriteLine("<br>  <a href="" + article.link + "">");
    writer.WriteLine("<font size="1">читать дальше</font></a><br><br>");
    writer.WriteLine("</td>");
    writer.WriteLine("</tr>");
    }
    writer.WriteLine("</table><br>");

    writer.WriteLine("<p align="center">");
	writer.WriteLine("<a href="" + channel.link + "">" + channel.copyright + "</a></p>");

    writer.WriteLine("</font>");
    writer.WriteLine("</body>");
    writer.WriteLine("</html>");
    return true;
   }
 }
 catch (Exception ex)
 {
    MessageBox.Show(ex.Message);
    return false;
 }
}
Функция не сложная и не требует глубоких пояснений, стоит только отметить что мы создаем StreamWriter, который записывает все данные в файл last_articles.html Теперь осталось лишь добавить обработчик нажатия кнопки, который выглядит вот так:
            if (getNewArticles("http://devoid.com.ua/rss.php") == true && generateHtml() == true)
            {
                Browser.Navigate(Environment.CurrentDirectory + "last_articles.html");
            }
После всего вышесказанного, осталось только нажать F5 и получить новые статьи сайта www.devoid.com.ua.
Стоит заметить также что наш парсер является уникальным, и сможет работать со всеми RSS-лентами стандарта 2.0.
Исходники этого RSS-ридера можно скачать отсюда.
Спасибо за внимание, успехов!

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




Рубрика: Документация




Инструменты Internet Explorer 8 Beta 2 для разработчиков.

Вебмастеру

В марте этого года мы уже писали об инструментах для разработчика в IE8 Beta 1, но IE8 Beta2 позволяет более полно использовать инструменты за счет значительных изменений в имеющихся функциях, а также новых возможностей. В принципе инструменты для разработчика должны обладать следующими свойствами: Быть интегрированными и простыми в использовании; Иметь визуальный интерфейсC их помощью можно быстро протестировать сайт.


Подробнее... | Рубрика: Вебмастеру | Добавлено: 05.09.2008

Google Developer Day 2008 в Москве.

Мероприятия

Дата проведения: 28 октября 2008 г.; Место проведения: Амбер Плаза, Москва, Россия. Конференция для веб-разработчиков и разработчиков мобильных приложений в Москве. Узнайте, как наилучшим образом использовать инструменты разработки и API от Google, чтобы создавать социальные, мобильные и картографические приложения, как использовать AJAX/JavaScript инструменты и библиотеки от Google и многое другое из первых уст.


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

ТОП 10 самых раздражающих факторов для программиста.

Разное

Совсем недавно наткнулся в интернете на забавный "хит-парад" наиболее раздражающих вещей для программиста. Поскольку он был на английском — решил перевести текст и несколько адаптировать к нашим реалиям…


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

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

Windows Server 7, 8 и 9
jQuery для JavaScript-программистов
Инновационный веб-броузер Google Chrome стартует уже сегодня
Windows 7: подход к производительности системы
Trac + Subversion @ Ubuntu: Revisited
[g]Vim в режиме Python: Рекомпиляция в Windows
Java + JSON. Пути к дружбе
Драйвер SQL Server 2005 для PHP
Типы данных в MySQL (сжатый справочник для PHP программиста)
PHP класс для работы с Яндекс.XML
Ошибки начинающих PHP разработчиков
Наследование шаблонов в Smarty
Особенности хранения сессий PHP в memcached
Internet Explorer 8 beta 2
9 правил для начинающего Ajax-разработчика
ExtJS 2.2 - полная поддержка Firefox 3, новые виджеты и другие нововведения


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



    Рубрикатор

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

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
Мероприятия

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

Пароль:

Запомнить

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