java rss xml_如何使用java代码获取RSS中信息

展开全部

以下内容来自32313133353236313431303231363533e78988e69d8331333339666662互联网,版权归原作者,仅供参考:

以下是一个RSS文件的标准结构:

...

...

...

...

...

...

...

...

...

...

...

...

其中rss元素是其根元素,它吧所有的内含信息包含在一个频道中,频道有许多meta信息,就是出现 在前面的所有子元素。而rss中的所有摘要,都以元素的形式出现,一个 可以有多个。每个同样有元信息,最重要的是描述和链 接。

现在有很多工具可以生成RSS,事实上,因为本质上RSS是一个XML文件,所以你完全可以以手工编写XML 文件的形式编写RSS,但是还是推荐用工具来简化操作和减少错误,我最喜欢用的工具是:http://www.onlinedown.net/soft /73066.htm

其实,不仅仅RSS阅读器可以获取RSS信息,我们用java API也是可以的。比较有名的是sourceforge的rsslib4j 包,我们这里就展示这个包的用法:

这个包可以到http://sourceforge.net/projects/rsslib4j/ 去下,对应的javadoc地址是http://rsslib4j.sourceforge.net/javadoc/

实验部分:

我们演示2个例子,一个是读取本地rss文件的信息,一个是读取网络上某rss文件的信息:

首先我们开发了一个工具类,这个类的工具方法可以分离出相关信息并且转为字符串形式:

package com.charles.learnrss;

import java.util.List;

import org.gnu.stealthp.rsslib.RSSChannel;

import org.gnu.stealthp.rsslib.RSSHandler;

import org.gnu.stealthp.rsslib.RSSImage;

import org.gnu.stealthp.rsslib.RSSItem;

/*

* This file is confidential by Charles.Wang

* Copyright belongs to Charles.wang

* You can make contact with Charles.Wang (charles_wang888@126.com)

*/

public class RSSInfoRetriever {

public static String getRSSInfo(RSSHandler handler){

StringBuffer rssInfo = new StringBuffer();

//取得rss提要的频道信息(Channel)

RSSChannel channel = handler.getRSSChannel();

//Part1: 分离出rss频道的元信息

//(1)频道的标题

String titleInfo = channel.getTitle();

//(2)频道的链接信息

String linkInfo = channel.getLink();

//(3)频道的描述信息

String descriptionInfo = channel.getDescription();

//(4)频道使用的语言

String languageInfo = channel.getLanguage();

//(5)频道版权信息

String copyrightInfo = channel.getCopyright();

//(6)频道的generator的信息

String generatorInfo = channel.getGenerator();

//(7)频道的image信息

RSSImage channelImage = channel.getRSSImage();

String channelImageUrl = channelImage.getUrl();

rssInfo.append("频道标题: "+titleInfo+"n");

rssInfo.append("频道相关Link信息: "+linkInfo+"n");

rssInfo.append("频道描述信息: "+descriptionInfo+"n");

rssInfo.append("频道使用的语言: "+languageInfo+"n");

rssInfo.append("频道版权信息: "+copyrightInfo+"n");

rssInfo.append("频道产生器信息: "+generatorInfo+"n");

rssInfo.append("频道图片URL: "+channelImageUrl+"n");

//Part2: 分离出rss频道的所有摘要(feed),这里用item表示

List channelItems = channel.getItems();

int itemSize= channelItems.size();

if(itemSize >=1){

rssInfo.append("n");

rssInfo.append("一共有 "+itemSize+"个摘要在这个频道中");

rssInfo.append("n");

for (int i=0;i

int itemNo = i+1;

RSSItem item = (RSSItem)channelItems.get(i);

rssInfo.append("n");

rssInfo.append("摘要"+itemNo+":");

//(1)摘要的作者

String itemAuthor = item.getAuthor();

//(2)摘要的标题

String itemTitle = item.getTitle();

//(3)摘要的描述

String itemDescription = item.getDescription();

//(4)摘要的链接

String itemLink = item.getLink();

//(5)摘要的发布日期

String itemPubDate = item.getPubDate();

rssInfo.append("作者: "+itemAuthor+"n");

rssInfo.append("标题: "+itemTitle+"n");

rssInfo.append("描述: "+itemDescription+"n");

rssInfo.append("链接: "+itemLink+"n");

rssInfo.append("发布日期: "+itemPubDate+"n");

rssInfo.append("n");

}

}

return rssInfo.toString();

}

}

然后我们写了一个驱动类,这个驱动类封装了个实验:

package com.charles.demo;

import java.net.URL;

import org.gnu.stealthp.rsslib.RSSChannel;

import org.gnu.stealthp.rsslib.RSSException;

import org.gnu.stealthp.rsslib.RSSHandler;

import org.gnu.stealthp.rsslib.RSSParser;

import com.charles.learnrss.RSSInfoRetriever;

/**

*

* Description:

*

* @author charles.wang

* @created May 10, 2012 9:07:13 AM

*

*/

public class RSSInfoRetrieverDemo {

// 这里定义一个本地的rss摘要,(对应我的博客空间)

public static final String localRSS = "charles.rss";

//这里定义一个远程的rss摘要的地址(对应人民网)

public static final String remoteRSS="http://www.people.com.cn/rss/politics.xml";

public static void main(String[] args) throws Exception {

// DEMO 1: 让RSSParser去解析本地某个rss文件

// 取得本地的rss

RSSHandler localRSSHandler = new RSSHandler();

RSSParser.parseXmlFile(localRSS, localRSSHandler, false);

// 取得rss元素的信息并且打印在控制台上

String localRSSInfo=RSSInfoRetriever.getRSSInfo(localRSSHandler);

System.out.println("*************Charles博客的 rss信息如下****************");

System.out.println(localRSSInfo);

System.out.println("****************************************************");

// DEMO 2: 让RSSParser去解析远程rss的url

// 取得远程的rss

RSSHandler remoteRSSHandler = new RSSHandler();

RSSParser.parseXmlFile(new URL(remoteRSS), remoteRSSHandler, false);

// 取得rss元素的信息并且打印在控制台上

String remoteRSSInfo=RSSInfoRetriever.getRSSInfo(remoteRSSHandler);

System.out.println("****************人民网的 rss信息如下******************");

System.out.println(remoteRSSInfo);

System.out.println("****************************************************");

}

}

实验:读取本地的rss文件(charles.rss)

这个文件部分内容为:

双击代码全选

Thu, 01 Jan 1970 00:00:00 GMT

跨域访问一直是困扰很多开发者的问题之一。因为涉及到安全性问题,所以跨域访问默认是不可以进行的,否则假设今天我写了一段js去更改google的图标,明天他写了一段代码去吧google首页的文字全部变成梵文,那还得..【继续阅读全文

]]>

http://supercharles888.blog.51cto.com/609344/856886

]]>

Tue, 08 May 2012 04:02:42 GMT

...

2Q==

已赞过

已踩过<

你对这个回答的评价是?

评论

收起

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值