eclipse中的SaxParseException:XML文档结构必须在同一个实体内开始和结束

时间:2014-04-18 14:36:57

标签: java xml eclipse sax last.fm

我正在使用jAVA的last.fm API,可以找到 here

我有一个巨大的Dataset我只使用该文件与用户的艺术家历史和戏剧。我用Java编写了一个代码,它提取了这些艺术家的名字,并根据Artist.getSimilar()方法返回了类似的艺术家。

我跑了一次,但不是所有的艺术家。我终止了一半的调试。但是,下次,我的结果将从缓存中返回,并且不再将请求发送到Web服务器。问题是,这次我得到的结果只有我终止结果的艺术家。我尝试使用artists=Artist.getTopAlbums()的另一种方法,我在中途终止并且下次遇到同样的问题。我得到的错误是:

[Fatal Error] :513:9: <strong>XML document structures must start and end within the same entity.</strong>
Exception in thread "main" de.umass.lastfm.CallException: org.xml.sax.SAXParseException; lineNumber: 513; columnNumber: 9; XML document structures must start and end within the same entity.
Caused by: org.xml.sax.SAXParseException; lineNumber: 513; columnNumber: 9; XML document structures must start and end within the same entity.
    at com.sun.org.apache.xerces.internal.parsers.DOMParser.parse(DOMParser.java:251)
    at com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:300)

以及其他一些不是重要部分的例外。

我尝试重新安装eclipse,以-clean模式启动eclipse并清理工作区。没有任何效果。我也创建了一个新的工作区,但缓存不断回来。我正在使用Eclipse 3.8。也许在eclipse中清除缓存的有效方法会有所帮助吗?我该怎么做似乎没什么用。 (此外,没有选项可以在Window&gt;偏好设置中手动清除缓存,如许多文章中所建议的那样)。

或者我还需要做别的事吗?任何帮助深表感谢。提前谢谢。

我的java代码(工作正常,没有错误):

//in main
BufferedReader inp = new BufferedReader (new InputStreamReader(System.in));
String sinput=inp.readLine();
System.out.println(sinput+"\t \t \t"+getSimilarartists(sinput));


//to fetch similar artists
public static StringBuilder getSimilarartists(String artist){
String key = "af2bfbcb4dd49870fdb8e92f128f4ff7";
StringBuilder sb = new StringBuilder();
String art=(Artist.getSimilar(artist, key)).toString();
int i=0;
while(i<art.length()-5){
    if((art.substring(i, (i+4))).equalsIgnoreCase("name")){
        i=i+6;

        while(art.charAt(i)!='\''){
            sb.append(art.charAt(i));
            i++;
        }

        break;
    }
    i++;
}
return sb;
}  

输出(只是最后几行):

hans zimmer;     I recommend=Hans Zimmer & James Newton Howard<br>
nelly furtado;   I recommend=Jennifer Lopez<br>
madonna;     I recommend=Kylie Minogue<br>
blink-182;   I recommend=Box Car Racer<br>
dave gahan;  I recommend=Depeche Mode<br>
kelly clarkson;  I recommend=Carrie Underwood<br>
lucie silvas;    I recommend=Delta Goodrem<br>
natalie imbruglia;   I recommend=Melanie C<br>
michelle branch;     I recommend=The Wreckers<br>
delta goodrem;   I recommend=Ricki-Lee<br>
new order;   I recommend=Electronic<br>
seal;    I recommend=Simply Red<br>
atomic kitten;   I recommend=Liberty X 

 *** (this is where I had terminated my previous run) ***

[Fatal Error] :513:9: XML document structures must start and end within the same entity.<br>
Exception in thread "main" de.umass.lastfm.CallException: org.xml.sax.SAXParseException; lineNumber: 513; columnNumber: 9; XML document structures must start and end within the same entity.
    at de.umass.lastfm.Caller.call(Caller.java:268)<br>
    at de.umass.lastfm.Caller.call(Caller.java:189)<br>
    at de.umass.lastfm.Caller.call(Caller.java:185)<br>
    at de.umass.lastfm.Artist.getSimilar(Artist.java:144)<br>
    at de.umass.lastfm.Artist.getSimilar(Artist.java:132)<br>
    at Recommender.getSimilarartists(Recommender.java:89)<br>
    at Recommender.main(Recommender.java:58)<br>
Caused by: org.xml.sax.SAXParseException; lineNumber: 513; columnNumber: 9; XML document structures must start and end within the same entity.<br>
    at com.sun.org.apache.xerces.internal.parsers.DOMParser.parse(DOMParser.java:251)
    at     <br>
com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:300)<br>
    at de.umass.lastfm.Caller.createResultFromInputStream(Caller.java:324)<br>
    at de.umass.lastfm.Caller.call(Caller.java:256)<br>
    ... 6 more

2 个答案:

答案 0 :(得分:2)

这样的错误通常表示格式错误的文档:

  

引起:org.xml.sax.SAXParseException; lineNumber:513;   columnNumber:9; XML文档结构必须在内部开始和结束   同一实体。在

您可以采取一些措施进行调试:

  1. 将XML文档打印到日志中,并通过某种XML验证器运行它。
  2. 检查以确保没有无效字符(UTF-8文件中的UTF-16字符除外)

答案 1 :(得分:0)

在执行常规I / O时,Eclipse和Java都不会缓存Web内容。但是,内容可以缓存在其他地方。也许您正在使用的de.umass.lastfm API正在执行此操作。也许您的操作系统或网络上有一些东西。