2.41. JSLT
使用 JSLT 查询或转换 JSON 有效负载。
2.41.1. 内部内容
-
JSLT 组件, URI 语法:
jslt:resourceUri
有关使用和配置详情,请参阅上述链接。
2.41.2. Maven 协调
在 code.quarkus.redhat.com 上创建一个具有此扩展名的新项目
或者在现有项目中添加协调:
<dependency> <groupId>org.apache.camel.quarkus</groupId> <artifactId>camel-quarkus-jslt</artifactId> </dependency>
2.41.3. 在原生模式中允许ContextMapAll 选项
原生模式中不支持 allowContextMapAll
选项,因为它需要反复访问安全敏感的 camel 核心类,如 CamelContext
和 Exchange
。这被视为安全风险,因此默认情况下不提供对该功能的访问。
2.41.4. 其他 Camel Quarkus 配置
2.41.4.1. 从原生模式的类路径加载 JSLT 模板
此组件通常从 classpath 加载模板。要使它在原生模式下工作,您需要使用 quarkus.native.resources.includes
属性将模板文件显式嵌入到原生可执行文件中。
例如,以下路由将从名为 transformation.json
的类路径资源加载 JSLT 模式:
from("direct:start").to("jslt:transformation.json");
要在原生镜像中包含此(可能存储在 .json
文件中的其他模板),您必须将类似如下的内容添加到 application.properties
文件中:
quarkus.native.resources.includes = *.json
2.41.4.2. 在原生模式中使用 JSLT 功能
当在原生模式中使用来自 camel-quarkus 的 JSLT 功能时,需要 注册托管功能的类来反映。当无法注册目标功能时,可能会最终写入一个存根,如下所示。
@RegisterForReflection public class MathFunctionStub { public static double pow(double a, double b) { return java.lang.Math.pow(a, b); } }
目标功能 Math.pow (…)
现在可以通过可以在组件中注册的 MathFunctionStub
类进行访问,如下所示:
@Named JsltComponent jsltWithFunction() throws ClassNotFoundException { JsltComponent component = new JsltComponent(); component.setFunctions(singleton(wrapStaticMethod("power", "org.apache.cq.example.MathFunctionStub", "pow"))); return component; }