Adobe Marketing Cloud의 일부인 Adobe CQ 저장소 내에 있는 노드 및 속성을 프로그래밍 방식으로 수정할 수 있습니다. CQ 저장소에 액세스하려면 JCR(Java Content Repository) API를 사용합니다. Java JCR API를 사용하여 Adobe CQ 저장소 내에 있는 콘텐츠에 대해 만들기, 바꾸기, 업데이트 및 삭제(CRUD) 작업을 수행할 수 있습니다. Java JCR API에 대한 자세한 내용은 https://jackrabbit.apache.org/jcr/jcr-api.html.
이 개발 문서는 외부 Java 애플리케이션에서 Adobe CQ JCR을 수정합니다. 반대로 JCR API를 사용하여 OSGi 번들 내에서 JCR을 수정할 수 있습니다. 자세한 내용은 Java Content Repository에서 CQ 데이터 유지.
JCR API를 사용하려면 다음을 추가합니다. jackrabbit-standalone-2.4.0.jar
을 Java 애플리케이션의 클래스 경로에 추가합니다. 다음 Java JCR API 웹 페이지에서 이 JAR 파일을 가져올 수 있습니다. https://jackrabbit.apache.org/jcr/jcr-api.html.
JCR 쿼리 API를 사용하여 Adobe CQ JCR을 쿼리하는 방법은 다음을 참조하십시오. JCR API를 사용하여 Adobe Experience Manager 데이터 쿼리.
저장소에 연결하고 연결을 설정하는 방법에는 여러 가지가 있지만 이 개발 문서에서는 org.apache.jackrabbit.commons.JcrUtils
클래스. 메서드의 이름은 입니다. getRepository
. 이 메서드는 Adobe CQ 서버의 URL을 나타내는 문자열 매개 변수를 사용합니다. 예 http://localhost:4503/crx/server
.
다음 getRepository
메서드가 을 반환합니다. Repository
예를 들어, 다음 코드 예제에서 볼 수 있습니다.
//Create a connection to the AEM JCR repository running on local host
Repository repository = JcrUtils.getRepository("http://localhost:4503/crx/server");
다음 Repository
인스턴스는 CRX 저장소를 나타냅니다. 다음을 사용합니다. Repository
인스턴스로 이동하여 저장소를 사용하여 세션을 설정합니다. 세션을 만들려면 Repository
인스턴스 login
방법 및 전달 javax.jcr.SimpleCredentials
개체. 다음 login
메서드가 을 반환합니다. javax.jcr.Session
인스턴스.
다음을 생성함: SimpleCredentials
개체, 개체, 개체, 개체 또는 개체의 생성자를 사용하고
두 번째 매개 변수를 전달할 때 String 개체의 toCharArray
메서드를 사용합니다. 다음 코드는 를 호출하는 방법을 보여 줍니다 login
를 반환하는 메서드 javax.jcr.Sessioninstance
.
//Create a Session instance
javax.jcr.Session session = repository.login( new SimpleCredentials("admin", "admin".toCharArray()));
사용 Session
생성할 인스턴스 javax.jcr.Node
인스턴스. A Node
인스턴스를 사용하여 노드 작업을 수행할 수 있습니다. 예를 들어 새 노드를 만들 수 있습니다. 루트 노드를 나타내는 노드를 만들려면 Session
인스턴스 getRootNode
메서드, 다음 코드 행에 표시.
//Create a Node
Node root = session.getRootNode();
을(를) 만든 후 Node
예를 들어 다른 노드를 만들고 해당 노드에 값을 추가하는 등의 작업을 수행할 수 있습니다. 예를 들어 다음 코드는 두 개의 노드를 만들고 두 번째 노드에 값을 추가합니다.
// Store content
Node day = adobe.addNode("day");
day.setProperty("message", "Adobe CQ is part of the Adobe Digital Marketing Suite!");
노드 및 해당 값을 검색하려면 Node
인스턴스 getNode
정규화된 경로를 나타내는 문자열 값을 노드에 전달합니다. 이전 코드 예제에서 만든 노드 구조를 생각해 보십시오. 일 노드를 검색하려면 다음 코드와 같이 adobe/day를 지정합니다.
// Retrieve content
Node node = root.getNode("adobe/day");
System.out.println(node.getPath());
System.out.println(node.getProperty("message").getString());
다음 Java 코드 예제는 Adobe CQ에 연결하고 Session
및 가 추가되었습니다. 노드에 데이터 값이 할당되면 노드 및 해당 경로의 값이 콘솔에 기록됩니다. 세션이 완료되면 로그아웃해야 합니다.
/*
* This Java Quick Start uses the jackrabbit-standalone-2.4.0.jar
* file. See the previous section for the location of this JAR file
*/
import javax.jcr.Repository;
import javax.jcr.Session;
import javax.jcr.SimpleCredentials;
import javax.jcr.Node;
import org.apache.jackrabbit.commons.JcrUtils;
import org.apache.jackrabbit.core.TransientRepository;
public class GetRepository {
public static void main(String[] args) throws Exception {
try {
//Create a connection to the CQ repository running on local host
Repository repository = JcrUtils.getRepository("http://localhost:4503/crx/server");
//Create a Session
javax.jcr.Session session = repository.login( new SimpleCredentials("admin", "admin".toCharArray()));
//Create a node that represents the root node
Node root = session.getRootNode();
// Store content
Node adobe = root.addNode("adobe");
Node day = adobe.addNode("day");
day.setProperty("message", "Adobe CQ is part of the Adobe Digital Marketing Suite!");
// Retrieve content
Node node = root.getNode("adobe/day");
System.out.println(node.getPath());
System.out.println(node.getProperty("message").getString());
// Save the session changes and log out
session.save();
session.logout();
}
catch(Exception e){
e.printStackTrace();
}
}
}
전체 코드 예제를 실행하고 노드를 만든 후에서 새 노드를 볼 수 있습니다. CRXDE Lite다음 그림과 같이 을 참조하십시오.