Статьи

Создание простого клиента AtomPub с IDE NetBeans 7, Maven, Java и Apache Abdera

В моей последней статье я показал вам, как создать и запустить простой сервер AtomPub с помощью Apache Abdera . Сегодня мы создадим клиента (используя модифицированный код, представленный в этом руководстве, а также примеры Apache Abdera) для размещения некоторых данных на сервере AtomPub.

На данный момент я предполагаю , что у вас уже есть Java и NetBeans IDE 7 работает, если вы не можете пойти сюда , чтобы получить их обоих. Я также предполагаю, что у вас есть некоторые знания по IDE NetBeans и Java.

Запустите среду IDE NetBeans 7 и создайте новый проект Java Maven с именем ATOMPubClient.

Щелкните правой кнопкой мыши по Зависимости и выберите: Добавить зависимость… Когда откроется диалоговое окно, введите в текстовое поле Запрос следующее: abdera-client

В классе App.java (уже создан) измените его так, чтобы код выглядел так:

/*
 * Original code created by the Apache Abdera team
 * http://abdera.apache.org/
 */
package com.giantflyingsaucer.atompubclient;
 
import java.util.Date;
 
import org.apache.abdera.Abdera;
import org.apache.abdera.factory.Factory;
import org.apache.abdera.model.Document;
import org.apache.abdera.model.Entry;
import org.apache.abdera.model.Feed;
import org.apache.abdera.protocol.Response.ResponseType;
import org.apache.abdera.protocol.client.AbderaClient;
import org.apache.abdera.protocol.client.ClientResponse;
 
public class App {
 
    public static void main(String[] args) throws Exception {
 
        Abdera abdera = new Abdera();
        AbderaClient abderaClient = new AbderaClient(abdera);
        Factory factory = abdera.getFactory();
 
        Entry entry = factory.newEntry();
        entry.setId("tag:example.org,2011:foo");
        entry.setTitle("This is the title");
        entry.setUpdated(new Date());
        entry.addAuthor("Chad");
        entry.setContent("Hello World");
        report("The Entry to Post", entry.toString());
 
        Document<Entry> doc = abderaClient.post("http://localhost:9002/employee", entry).getDocument();
        report("The Created Entry", doc.getRoot().toString());
 
        ClientResponse resp = abderaClient.get("http://localhost:9002/employee");
        if (resp.getType() == ResponseType.SUCCESS) {
            Document<Feed> docFeed = resp.getDocument();
            report("The Returned Feed", docFeed.getRoot().toString());
        } else {
          // Error
        }
    }
 
    private static void report(String title, String message) {
        System.out.println("== " + title + " ==");
        if (message != null)
            System.out.println(message);
        System.out.println();
    }
}

Это очень просто, запись создана и канал возвращается — больше ничего. Я проигнорировал возможность редактирования и удаления. Этот код можно улучшить несколькими способами, но моя цель состояла в том, чтобы немного облегчить разработчикам начало работы с Apache Abdera и дополнить существующие документы .

Полный исходный код доступен здесь.

С http://www.giantflyingsaucer.com/blog/?p=2961