34.3. 内置类型 Converters
概述
本节论述了 master 类型转换器支持的转换。这些转换内置到 Apache Camel 内核中。
通常,类型转换器会通过方便功能调用,如 Message.getBody (Class<T> type)
或 Message.getHeader (String name, Class<T> type)
。也可以直接调用 master 类型转换器。例如,如果您有一个交换对象,交换
了,可以将给定值转换为 String
,如 例 34.4 “将值转换为字符串” 所示。
例 34.4. 将值转换为字符串
org.apache.camel.TypeConverter tc = exchange.getContext().getTypeConverter(); String str_value = tc.convertTo(String.class, value);
基本类型转换器
Apache Camel 提供内置类型转换器,可以从以下基本类型执行转换:
-
java.io.File
-
字符串
-
byte[]
andjava.nio.ByteBuffer
-
java.io.InputStream
andjava.io.OutputStream
-
java.io.Reader
和java.io.Writer
-
java.io.BufferedReader
andjava.io.BufferedWriter
-
java.io.StringReader
但是,并非所有这些类型的类型都相互连接。内置的转换器主要关注从文件和字符串类型提供 转换
。文件类型
可转换为上述类型的任何类型,但 Reader
、Writer
和 StringReader
除外。String
类型可转换为文件、
、byte
[]ByteBuffer
、InputStream
或 StringReader
。从 String
转换到 文件
可以解释字符串作为文件名。String
trio、byte[]
和 ByteBuffer
完全相互连接。
您可以通过在当前交换中设置 Exchange.CHARSET_NAME
Exchange 属性,明确指定要用于从 字节[]
转换为 字符串
的字符编码。
例如,若要使用 UTF-8 字符编码执行转换,请调用
exchange.setProperty ("Exchange.CHARSET_NAME", "UTF-8")
。受支持的字符集在 java.nio.charset.Charset
类中描述。
集合类型转换器
Apache Camel 提供内置类型转换器,可以从以下集合类型执行转换:
-
object[]
-
java.util.Set
-
java.util.List
支持在上述集合类型间转换的所有转换。
映射类型转换器
Apache Camel 提供内置类型转换器,可以从以下映射类型执行转换:
-
java.util.Map
-
java.util.HashMap
-
java.util.Hashtable
-
java.util.Properties
前面的 map 类型也可以转换为 java.util.Set
类型的集合,其中集合元素是 MapEntry<K,V>
类型。
DOM 类型转换器
您可以对以下文档对象模型(DOM)类型执行类型转换:
-
org.w3c.dom.Document
PLAYBOOK-ocpvertible frombyte[]
,String
String ,java.io.File
, andjava.io.InputStream
. -
org.w3c.dom.Node
-
javax.xml.transform.dom.DOMSource
PLAYBOOK-ocpvertible fromString
. -
javax.xml.transform.Source
将来自byte[]
和String
String.
支持前面的 DOM 类型之间的所有转换。
SAX 类型转换器
您还可以对 javax.xml.transform.sax.SAXSource
类型执行转换,该类型支持 SAX 事件驱动的 XML 解析器(请参阅 SAX 网站 了解详细信息)。您可以从以下类型转换为 SAXSource
:
-
字符串
-
InputStream
-
源
-
StreamSource
-
DOMSource
enum 类型转换器
Camel 为执行 String
提供了一种类型 转换程序
来枚举类型转换,其中字符串值将被转换为来自指定枚举类的匹配枚举常数(匹配 区分大小写)。在转换消息正文时很少需要这种类型转换器,但 Apache Camel 在内部使用这种类型来选择特定的选项。
例如,在设置日志记录级别选项时,值 INFO
将转换为枚举常量:
<to uri="log:foo?level=INFO"/>
因为 enum
类型转换器不区分大小写,因此以下任意一种替代项都可以正常工作:
<to uri="log:foo?level=info"/> <to uri="log:foo?level=INfo"/> <to uri="log:foo?level=InFo"/>
自定义类型转换器
Apache Camel 还允许您实施自己的自定义类型转换器。有关如何实现自定义类型转换器的详情,请参考 第 36 章 类型 Converters。