応答が少し遅いことはわかっていますが、後で誰かがこれを使用する可能性があります。私はローマ1.0でそれをやった。
独自のコンバーターとジェネレーターを定義できます。
私が必要としていたのは、アイテムにソース フィールドがある RSS 2.0 フィードでした。したがって、コンバーターとジェネレーターの両方について、ROME による RSS 2.0 の実装を拡張します。
まずコンバーターが必要です。それはソースを埋める人です
/**
* This is a convertor for RSS 2.0 setting source on output items
*/
public class ConverterForRSS20WithSource extends ConverterForRSS20 {
/**
* Default Constructor
*/
public ConverterForRSS20WithSource() {
this("rss_2.0_withSource");
}
/**
* Constructor with type
* @param type
*/
protected ConverterForRSS20WithSource(String type) {
super(type);
}
/**
* @see com.sun.syndication.feed.synd.impl.ConverterForRSS094#createRSSItem(com.sun.syndication.feed.synd.SyndEntry)
*/
@Override
protected Item createRSSItem(SyndEntry sEntry) {
Item item = super.createRSSItem(sEntry);
if(sEntry.getSource() != null
&& StringUtils.isNotBlank(sEntry.getSource().getUri())) {
Source s = new Source();
s.setUrl(sEntry.getSource().getUri());
s.setValue(sEntry.getSource().getTitle());
item.setSource(s);
}
return item;
}
}
次に、ジェネレーターが必要です。特別なことは何もありません。それはただでなければならなかった
/**
* Rss 2.0 Generator with source field
*/
public class RSS020GeneratorWithSource extends RSS20Generator {
/**
*
*/
public RSS020GeneratorWithSource() {
super("rss_2.0_withSource","2.0");
}
}
最後に、クラスをローマに宣言する必要があります。そのためには、リソースのルートに rome.properties を配置するだけです。dublin コアを rss.items に追加することを忘れないでください...そのファイルに
Converter.classes=my.package.ConverterForRSS20WithSource
WireFeedGenerator.classes=my.package.RSS020GeneratorWithSource
# Parsers for RSS 2.0 with source item modules
#
rss_2.0_withSource.item.ModuleParser.classes=com.sun.syndication.io.impl.DCModuleParser
# Generators for RSS_2.0 entry modules
#
rss_2.0_withSource.item.ModuleGenerator.classes=com.sun.syndication.io.impl.DCModuleGenerator
それだけです。