Главная / Zend Manual Core
Работа с отдельным сообщением ленты Atom

Изменение структуры лент и их сообщений

Естетственный синтаксис Zend_Feed используется для создания и изменения лент и записей так же, как и для их чтения. Вы можете легко преобразовывать свои новые или измененные объекты обратно в синтаксически корректный XML для сохранения в файл или отправки серверу.

Example #1 Изменение существующего сообщения в ленте

  1. $feed = new Zend_Feed_Atom('http://atom.example.com/feed/1');
  2. $entry = $feed->current();
  3.  
  4. $entry->title = 'This is a new title';
  5. $entry->author->email = 'my_email@example.com';
  6.  
  7. echo $entry->saveXML();

Это выведет полное (включая вступление <?xml ... >) XML-представление новой публикации, включающее в себя необходимые пространства имен XML.

Обратите внимание на то, что вышеприведенный код будет работать даже если существующая запись не имеет тег <author>. Для присвоения вы можете использовать столько уровней доступа через ->, сколько для получения; все промежуточные уровни будут созданы автоматически, если необходимо.

Если вы хотите использовать в своих сообщениях пространство имен, отличное от atom:, rss: или osrss:, то вам нужно зарегистрировать его через Zend_Feed, используя метод Zend_Feed::registerNamespace(). Когда вы изменяете существующий элемент, он всегда будет сохранять свое исходное пространство имен. Когда вы добавляете новый элемент, то он будет включен в пространство имен по умолчанию, если не было указано явно другое пространство имен.

Example #2 Создание сообщения Atom с элементами в специальном пространстве имен

  1. $entry = new Zend_Feed_Entry_Atom();
  2. // id уже присвоен сервером
  3. $entry->title = 'my custom entry';
  4. $entry->author->name = 'Example Author';
  5. $entry->author->email = 'me@example.com';
  6.  
  7. // теперь выполнение специальной части
  8. Zend_Feed::registerNamespace('myns', 'http://www.example.com/myns/1.0');
  9.  
  10. $entry->{'myns:myelement_one'} = 'my first custom value';
  11. $entry->{'myns:container_elt'}->part1 = 'first nested custom part';
  12. $entry->{'myns:container_elt'}->part2 = 'second nested custom part';
  13.  
  14. echo $entry->saveXML();

Работа с отдельным сообщением ленты Atom