0

私は Apache Jackrabbit を使用しています。

例外を見つけました。いろいろ試しましたが、この例外の背後にある理由がわかりませんでした。

これを解決するのを手伝ってください。

例外 :-

javax.jcr.RepositoryException: This session has been closed.
    at org.apache.jackrabbit.jcr2spi.SessionImpl.checkIsAlive(SessionImpl.java:922)
    at org.apache.jackrabbit.jcr2spi.ItemImpl.checkStatus(ItemImpl.java:436)
    at org.apache.jackrabbit.jcr2spi.NodeImpl.getProperties(NodeImpl.java:489)
    at edu.uci.ics.crawler4j.frontier.DocIDServer.getDocId(DocIDServer.java:112)
    at edu.uci.ics.crawler4j.crawler.WebCrawler.processPage(WebCrawler.java:286)
    at edu.uci.ics.crawler4j.crawler.WebCrawler.run(WebCrawler.java:189)
    at java.lang.Thread.run(Thread.java:722)

編集 No.1

コードは次のとおりです。

Repository repository = JcrUtils.getRepository("http://localhost:4502/crx/server");
Session session = repository.login(new SimpleCredentials("admin", "admin".toCharArray()));

// Obtain the query manager for the session via the workspace ...
QueryManager queryManager = session.getWorkspace().getQueryManager();

// Create a query object ...
String expression = "SELECT * FROM [sling:OrderedFolder] AS s WHERE ISDESCENDANTNODE([/docIDsDB])";
Query query = queryManager.createQuery(expression, javax.jcr.query.Query.JCR_SQL2);

// Execute the query and get the results ...
QueryResult result = query.execute();

// Iterate over the nodes in the results ...
NodeIterator nodeIter = result.getNodes();

session.logout();

while(nodeIter.hasNext()){
    Node node = nodeIter.nextNode();
    System.out.println(node.getProperty("url").getString());
    System.out.println(node.getProperty("docid").getString());

}

例外

javax.jcr.RepositoryException: This session has been closed.
    at org.apache.jackrabbit.jcr2spi.SessionImpl.checkIsAlive(SessionImpl.java:922)
    at org.apache.jackrabbit.jcr2spi.ItemImpl.checkStatus(ItemImpl.java:436)
    at org.apache.jackrabbit.jcr2spi.NodeImpl.getProperty(NodeImpl.java:471)
    at jackrabbit.JackRabbit.main(JackRabbit.java:111)

111号線は

System.out.println(node.getProperty("url").getString());

Jackrabbit では、ノードと子はすべて sling:orderedFolder タイプです。

4

2 に答える 2

1

JCR セッションが提供するノードにアクセスしている限り、JCR セッションを開いたままにしておいてください。

Session.logout() 呼び出しを、セッションが提供するものを使用するすべてのコードの後に​​ある finally 句に移動する必要があります。

于 2013-06-20T07:59:08.600 に答える
0

session.isLive()保存された を再利用する前にテストSessionし、このメソッドが を返す場合は再取得する必要がありますfalse

于 2013-06-20T10:04:22.110 に答える