jackrabbit - 如何在 jackrabbit 2.1 存储库中恢复 "versioned node"?

标签 jackrabbit jcr

一旦节点被删除,您如何找到它以便您可以使用 jackrabbit 或 jcr API 恢复它?

最佳答案

我不是 Jackrabbit 版本控制方面的专家,但据我所知,除非您知道其中的一些数据,否则没有简单的方法可以找到这样的节点。如果您确实知道,那么您可以使用查询并导航到作为 javax.jcr.version.Version 实例的下一个父级,然后恢复它。如果你不知道,那么你需要遍历版本存储并打印所有数据。您可以过滤掉未删除的节点,否则这是一项手动工作,因为节点的路径未存储在版本存储中(除非您添加包含路径的属性)。下面是一个关于如何列出版本存储中所有节点的示例。它将恢复它找到的最后一个 javax.jcr.version.Version:

import javax.jcr.Node;
import javax.jcr.NodeIterator;
import javax.jcr.Property;
import javax.jcr.PropertyIterator;
import javax.jcr.Session;
import javax.jcr.SimpleCredentials;
import javax.jcr.version.Version;
import javax.jcr.version.VersionManager;
import org.apache.jackrabbit.core.TransientRepository;
public class TestRestoreDeleted {
    public static void main(String... args) throws Exception {
        TransientRepository rep = new TransientRepository();
        Session s = rep.login(
                new SimpleCredentials("", new char[0]));
        try {
            // clear the repository first
            if (s.getRootNode().hasNode("test")) {
                s.getRootNode().getNode("test").remove();
                s.save();
            }
            // add test/t1 and check in the change
            Node test = s.getRootNode().addNode("test");
            Node t1 = test.addNode("t1");
            t1.addMixin("mix:versionable");
            s.save();
            VersionManager vm = s.getWorkspace().
                    getVersionManager();
            for(int i=0; i<3; i++) {
                vm.checkout("/test/t1");
                t1.setProperty("data", "Hello" + i);
                s.save();
                vm.checkin("/test/t1");
            }
            // remove the node
            t1.remove();
            s.save();
            // list all versions of all nodes in the repository
            Node vs = s.getRootNode().
                    getNode("jcr:system").
                    getNode("jcr:versionStorage");
            Version v = traverseVersionStorage(vs, 0);
            // restore a version
            vm.restore("/test/t1", v, false);
            // get the node and print the data
            t1 = s.getRootNode().
                    getNode("test").getNode("t1");
            System.out.println("Restored: " +
                    t1.getProperty("data").getString());
        } finally {
            s.logout();
        }
    }

    private static Version traverseVersionStorage(
            Node n, int level) throws Exception {
        Version v = null;
        for (NodeIterator it = n.getNodes(); it.hasNext();) {
            Node n2 = it.nextNode();
            if (n2 instanceof Version
                    && !n2.getName().startsWith("jcr:")) {
                v = (Version) n2;
                System.out.println("version " + n2.getName() +
                        " of node " + n2.getParent().getName() + ":");
                Node n3 = n2.getNode("jcr:frozenNode");
                for (PropertyIterator pt =
                            n3.getProperties(); pt.hasNext();) {
                    Property p = pt.nextProperty();
                    if (!p.getName().startsWith("jcr:")) {
                        System.out.println("  " + p.getName() + "="
                                + (p.isMultiple() ? p.getValues().toString()
                                        : p.getValue().getString()));
                    }
                }
                System.out.println();
            }
            Version v2 = traverseVersionStorage(n2, level + 1);
            v = v == null ? v2 : v;
        }
        return v;
    }

}

关于jackrabbit - 如何在 jackrabbit 2.1 存储库中恢复 "versioned node"?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3292719/

相关文章:

aem - SQL2 - 获取子节点属性

java - 命名内容存储库中的节点

Jackrabbit 锁定了许多空位 ACE

pentaho - mysql 存储库如何在 Pentaho 用户控制台中工作?

jackrabbit - JCR Jackrabbit 版本控制

java - Jackrabbit-oak 构建因 mvn clean install 失败

java - 如何访问远程 jackrabbit 存储库?

tomcat - Pentaho 双服务器-ce 5 : RepositorySynchronizer plugin issue