2天时间,聊今年最热的 Agent、上下文工程、AI 产品创新等话题。2025 年最后一场~ 了解详情
写点什么

创建基于查询参数的包

  • 2011-08-03
  • 本文字数:1751 字

    阅读完需:约 6 分钟

目录

要求

用户级别

入门级

示例文件

在使用内容管理系统时,我们往往需要根据某些参数提取内容。一种极其常见的用例就是依据最后一次同步的日期或者生产系统中内容的最后修改日期,更新生产中的存储或者开发系统。我们可以通过编写一个简单的组件来轻松解决这个问题,首先查询存储库,并使用搜索结果来在服务器上创建包。

查询存储库

Day OOTB 提供了搜索存储库的组件,例如 http://localhost:4502/libs/cq/search/content/querydebug.hml http://localhost:4502/crx/ui/search.jsp

我们可以根据查询参数进行查询,也可在一次查询中指定 XPath/SQL(例如,搜索在 2010 年 4 月 1 日之后更改的所有内容)。

基于参数的搜索

Onhttp://localhost:4502/libs/cq/search/content/querydebug.html, type the params in the text area below:

http://localhost:4502/libs/cq/search/content/querydebug.html 中,在文本区域内输入以下参数:

复制代码
type=cq:Page
path=/content
daterange.property=jcr:content/cq:lastModified
daterange.lowerBound=2010-04-01
orderby=@jcr:content/cq:lastModified
orderby.index=true
orderby.sort=asc

基于 XPath 的查询

http://localhost:5502/crx/ui/search.jsp 中使用 XPath,如下所示:

复制代码
/jcr:root/content//element(*, cq:Page)
[
(@jcr:content/cq:lastModified > xs:dateTime('2010-04-01T00:00:00.000+05:30'))
]
order by jcr:content/@cq:lastModified

我们还可以创建自己的组件来进行搜素,方法是创建一个基于所传入的属性(参数)的 PredicateGroup,随后即可利用一个生成器对象(使用 predicateGroup 和可用 jcr 会话创建)来创建查询,如下所示:

复制代码
QueryBuilder builder = resource.getResourceResolver().adaptTo(QueryBuilder.class);
Session session = resource.getResourceResolver().adaptTo(Session.class);
String queryParam = request.getParameter(“query”);
Properties props = new Properties();
props.load(new ByteArrayInputStream(queryParam.getBytes(“ISO-8859-1″)));
PredicateGroup root = PredicateConverter.createPredicates(props);
// avoid slow //* queries
if (!root.isEmpty())
{
query = builder.createQuery(root, session);
query.setHitsPerPage(0);
}
<p>SearchResult result = query.getResult();</p>

在 SearchResult 对象中,我们可以提取 Hits (result.getHits),并遍历列表来显示结果。我们可以使用相同的列表来创建包,如下一节所述。

通过节点列表创建包

如果拥有节点列表,就可以通过创建过滤器并使用相同的过滤器来进行 Jcr 包定义,从而轻松创建包:

复制代码
DefaultWorkspaceFilter filter = new DefaultWorkspaceFilter();
for (Hit hit: hits)
{
PathFilterSet pathFilterSet = new PathFilterSet(hit.getPath());
filter.add(pathFilterSet);
}
JcrPackage jcrPackage = packMgr.create(“testGroup”,”testPackage”);
JcrPackageDefinition jcrPackageDefinition = jcrPackage.getDefinition();
jcrPackageDefinition.setFilter(filter, false);
PrintWriter pkgout = new PrintWriter(System.out);
packMgr.assemble(jcrPackage, new DefaultProgressListener(pkgout));

在执行由组名称为“testGroup”的一个包及其中的一个包构成的组合时,将创建一个“testPackage”包,并可通过包管理器访问。

我已经创建了一个示例组件,方法是扩展创建组名称为 testGroup 的包的默认搜索组件。如果已经存在具有相同名称的包,则将忽略请求,不会覆盖现有包。您可以在这里获得示例组件。

访问 http://servername:port/apps/packages/createPkgWithQuery/createPkg.html ,安装并使用包。您可以使用类似于下面这样的参数:

复制代码
type=cq:Page
path=/content
daterange.property=jcr:content/cq:lastModified
daterange.lowerBound=2010-04-01
orderby=@jcr:content/cq:lastModified
orderby.index=true
orderby.sort=asc

clip_image004

本文遵守知识共享—署名- 非商业性使用- 相同方式共享3.0 Unported License (Creative Commons Attribution-Noncommercial-Share Alike 3.0 Unported License) 许可条件。

查看原文: Creating packages based on query parameters

2011-08-03 05:151233

评论

发布
暂无评论
发现更多内容

鸿蒙HarmonyOS NEXT开发实战:同城服务APP的卡片服务与数据管理

chengxujianke

YC 孵化项目 Pinch:实时语音翻译视频会议平台;Mistral OCR:能处理多语言多模态复杂文档丨日报

声网

微信基于 StarRocks 的实时因果推断实践

StarRocks

微信 OLAP StarRocks 因果推断 数据库 大数据

低代码与AI融合实践:解构智能化办公平台的企业级技术架构

不在线第一只蜗牛

鸿蒙HarmonyOS NEXT开发实战:美颜相机APP中的图像处理与性能优化

chengxujianke

鸿蒙HarmonyOS NEXT开发实战:在社交分享类APP中实现跨设备无缝分享功能

chengxujianke

通义灵码AI程序员深度测评:这些能力体验感拉满!满血版 DeepSeek 玩法大揭秘

阿里巴巴云原生

阿里云 云原生 通义灵码 AI程序员 AI程序员体验官

YashanDB滚动升级

YashanDB

数据库 yashandb

当中国“智算心跳”与全球共振:九章云极DataCanvas首秀MWC 2025

九章云极DataCanvas

人工智能 智算中心

鸿蒙HarmonyOS NEXT开发实战:健康管理APP的跨设备数据同步解决方案

chengxujianke

鸿蒙HarmonyOS NEXT开发实战:图书阅读类APP的跨设备数据同步解决方案

chengxujianke

YashanDB安装常见问题

YashanDB

数据库 yashandb

通义灵码AI程序员深度测评:这些能力体验感拉满!满血版 DeepSeek 玩法大揭秘

阿里云云效

阿里云 云原生 通义灵码 AI程序员 AI程序员体验官

YashanDB升级前准备

YashanDB

数据库 yashandb

解锁YashanDB高效查询的关键功能 Group by分组

YashanDB

数据库 yashandb

鸿蒙HarmonyOS NEXT开发实战:家装设计APP的跨设备协同与UI自适应解决方案

chengxujianke

鸿蒙HarmonyOS NEXT开发实战:新闻头条APP的列表数据加载优化

chengxujianke

鸿蒙HarmonyOS NEXT开发实战:音乐畅听APP的音频播放与分享功能实现

chengxujianke

YashanDB Windows客户端安装

YashanDB

数据库

YashanDB Linux客户端安装

YashanDB

数据库 yashandb

鸿蒙HarmonyOS NEXT开发实战:金融财务类APP的跨设备数据同步解决方案

chengxujianke

鸿蒙HarmonyOS NEXT开发实战:打造一款高效天气预报APP

chengxujianke

鸿蒙HarmonyOS NEXT开发实战:时尚购物APP的跨设备数据同步解决方案

chengxujianke

鸿蒙HarmonyOS NEXT开发实战:旅游攻略APP的跨设备数据同步解决方案

chengxujianke

2025《政府工作报告》解读:发展新质生产力,为现代化产业体系 “赋能提速”!

数造万象

人工智能 数字经济 政策 热门 #大数据

鸿蒙生态新突破:HarmonyOS NEXT分布式媒体会话实战——打造跨设备无缝续播教育应用

chengxujianke

鸿蒙HarmonyOS NEXT开发实战:如何在会议记录APP中实现高效的多设备同步功能

chengxujianke

MQTT协议下温度数据上报观测云最佳实践

观测云

mqtt

英特尔至强6处理器家族,性能与能效的平衡之道

E科讯

创建基于查询参数的包_Java_Yogesh Bahuguna_InfoQ精选文章