尝试解析原子Feed时收到以下错误。 org.apache.abdera.parser.ParseException:java.lang.ArrayIndexOutOfBoundsException 在org.apache.abdera.parser.stax.FOMParser.parse(FOMParser.java:128) 在org.apache.abdera.util.AbstractParser.parse(AbstractParser.java:73) 在testfeedreader.TestFeedReader.main(TestFeedReader.java:44) 引起:java.lang.ArrayIndexOutOfBoundsException ....
这是我的读者代码。我硬编码了测试网址:
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package testfeedreader;
import java.io.IOException;
import java.net.URL;
import java.util.List;
import org.apache.abdera.Abdera;
import org.apache.abdera.model.Document;
import org.apache.abdera.model.Entry;
import org.apache.abdera.model.Feed;
import org.apache.abdera.model.Category;
import org.apache.abdera.model.Link;
import org.apache.abdera.parser.ParseException;
import org.apache.abdera.parser.Parser;
/**
*
* @author srieger
*/
public class TestFeedReader {
private static Abdera abdera = null;
/**
*
* @return
*/
public static synchronized Abdera getInstance() {
if (abdera == null) {
abdera = new Abdera();
}
return abdera;
}
public static void main(String[] args) {
Parser parser = getInstance().getParser();
try {
URL url = new URL("http://connect.lmsnet.com/files/basic/anonymous/api/documents/feed");
Document<Feed> doc = parser.parse(url.openStream(), url.toString());
Feed feed = doc.getRoot();
// Get the feed title
System.out.println("Feed Title: " + feed.getTitle());
// Get the entry items...
for (Entry entry : feed.getEntries()) {
System.out.println("Title: " + entry.getTitle());
System.out.println("Unique Identifier: " + entry.getId().toString());
System.out.println("Updated Date: " + entry.getUpdated().toString());
System.out.println("Published Date: " + entry.getPublished());
System.out.println("Content: " + entry.getContent());
// Get the links
for (Link link : (List<Link>) entry.getLinks()) {
System.out.println("Link: " + link.getHref());
}
// Get the categories
for (Category category : (List<Category>) entry.getCategories()) {
System.out.println("Category: " + category.getTerm());
}
}
} catch( IOException | ParseException e )
{
e.printStackTrace();
}
}
}
答案 0 :(得分:1)
基于讨论,答案是:代码将记录页面作为响应,因此发生解析错误。
的可能性:
SSO配置 - 研究SBT SDK文档并使用SSO进行身份验证。
将代码移至客户端 - 因此在后台处理SSJS / Java,使用一些小部件和JS解析向用户显示所需信息。这样,呼叫将通过用户在浏览器中的身份进行身份验证。
答案 1 :(得分:0)
apache abdera使用org.apache.axiom
lib,因此将其用作pom文件中的依赖项。您可以使用另一个catch块对其进行检查,它将抛出NoClassDefFoundError
。此答案可帮助正在寻找此内容的人。