2.44. JSLT
使用 JSLT 查询或转换 JSON 有效负载。
2.44.1. 内部是什么
-
JSLT 组件, URI 语法:
jslt:resourceUri
有关使用和配置详情,请参阅上述链接。
2.44.2. Maven 协调
在 code.quarkus.redhat.com 上使用此扩展创建一个新项目
或者将协调添加到现有项目中:
<dependency> <groupId>org.apache.camel.quarkus</groupId> <artifactId>camel-quarkus-jslt</artifactId> </dependency>
2.44.3. 原生模式中的 allowContextMapAll 选项
原生模式下不支持 allowContextMapAll
选项,因为它需要对安全敏感 camel 内核类(如 CamelContext
和 Exchange
)进行反映访问。这被视为安全风险,因此默认不提供对该功能的访问。
2.44.4. 其他 Camel Quarkus 配置
2.44.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.44.4.2. 在原生模式中使用 JSLT 功能
当在原生模式下使用 camel-quarkus 中的 JSLT 功能时,需要 注册托管函数的类来反映。当无法注册目标功能时,可能会最终编写 stub,如下所示。
@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; }