如何使用xAgent阅读RSS feed?

时间:2012-02-26 13:25:04

标签: java xml rss xpages

我正在尝试使用xAgent读取外部rss feed,我似乎是像下面一样的gettig xml错误,我怀疑是因为我使用bufferedReader逐行读取xml

我得到像这样的错误

  • “第32行第1行的错误:文档末尾的额外内容”
  • “第6561行第1行的错误:打开和结束标记不匹配:第0行和第0行通道”

这是我尝试过的事情

<?xml version="1.0" encoding="UTF-8"?>
<xp:view xmlns:xp="http://www.ibm.com/xsp/core" rendered="false">
<xp:this.afterRenderResponse>
<![CDATA[#{javascript:

var u:java.net.URL  = new java.net.URL("http://www.xpages.info/XPagesHome.nsf/NewsFeed.xsp?format=rss");
var br:BufferedReader= new java.io.BufferedReader(new java.io.InputStreamReader(u.openStream()));
var tmp="";
while(br.readLine() != null){
    tmp+= br.readLine();
}

var externalContext = facesContext.getExternalContext();
var writer = facesContext.getResponseWriter();
var response = externalContext.getResponse();
response.setContentType("text/xml");
response.setHeader("Cache-Control", "no-cache");
writer.write(tmp);
writer.endDocument();
}]]>

</xp:this.afterRenderResponse>
</xp:view>

1 个答案:

答案 0 :(得分:3)

您正在使用XAgent作为代理。如果你想要真正做更多,我建议使用更好的课程。最小的是HTTP客户端(处理所有连接的肮脏)或者如果你的源是ATOM,那么Apache Abdera类(在引擎盖下使用HTTP客户端)。

您遇到的问题:流中还包含标头信息,因此您的XML不以&lt;开头。使用HTTP客户端可以避免这种情况。

有点像这样:

public String getURL(String url) {

    System.out.println("Fetching " + url);

    if (this.httpClient == null) {
        this.initializeHTTPSession();
    }

    ResponseHandler<String> responseHandler = new BasicResponseHandler();
    HttpGet get = new HttpGet(url);

    String result = null;

    try {
        result = this.httpClient.execute(get, responseHandler);
    } catch (HttpResponseException e) {
        System.out.println(e.getMessage());
        return null;
    } catch (ClientProtocolException e) {
        e.printStackTrace();
    } catch (UnknownHostException e) {
        result = "The host is invalid: " + url;
    } catch (IOException e) {
        e.printStackTrace();
    }

    return result;
}

此处的完整源代码:http://www.wissel.net/blog/downloads/SHWL-8BQPJD/ $ File / HTTPReader.java

您可能希望为响应处理程序使用除字符串之外的其他内容。