java.lang.Objectjavax.xml.bind.DatatypeConverter
public final class DatatypeConverter
     
可以使用 javaType 绑定声明来自定义 XML 模式数据类型到 Java 数据类型的绑定。自定义可能涉及编写分别用来解析和打印 XML 模式数据类型的词汇表示形式的 parse 和 print 方法。不过,编写 parse 和 print 方法需要了解词汇表示形式( XML Schema Part2: Datatypes 规范),因此可能很难编写。
此类使编写 parse 和 print 方法变得更容易。它定义了静态 parse 和 print 方法,以便访问 JAXB 提供者的 parse 和 print 方法的实现。这些方法由自定义 parse 和 print 方法调用。例如,可以使用如下 parse 和 print 方法来自定义 xsd:dateTime 到 long 值的绑定:
 
   
// Customized parse method 
public long myParseCal( String dateTimeString ) {
java.util.Calendar cal = DatatypeConverter.parseDateTime(dateTimeString);
long longval = convert_calendar_to_long(cal); //application specific
return longval;
    }
     
// Customized print method
public String myPrintCal( Long longval ) {
java.util.Calendar cal = convert_long_to_calendar(longval) ; //application specific
String dateTimeString = DatatypeConverter.printDateTime(cal);
return dateTimeString;
    }
     
   
   在 DatatypeConverterInterface 中有分别对应于每个 parse 和 print 方法的静态 parse 和 print 方法。 
在该类中定义的静态方法还可以用于指定 javaType 绑定声明中的 parse 和 print 方法。
 JAXB 提供者需要在第一次执行编组或解组操作之前(可能是在调用 JAXBContext.newInstance 期间)的某个时间点调用 setDatatypeConverter API。要配置用于执行打印和解析功能的转换器,这一步是必需的。 
XML 模式数据类型的 print 方法可以输出对于 XML 模式数据类型有效的任何词汇表示形式。如果在转换期间发生错误,则该方法将抛出 IllegalArgumentException,或者抛出 IllegalArgumentException 的子类。
DatatypeConverterInterface, 
    ParseConversionEvent, 
    PrintConversionEvent
   | 方法摘要 | |
|---|---|
 static String |  
     parseAnySimpleType(String lexicalXSDAnySimpleType) 返回包含简单类型的词汇表示形式的字符串。  |  
    
 static byte[] |  
     parseBase64Binary(String lexicalXSDBase64Binary) 将字符串参数转换为一个字节数组。  |  
    
 static boolean |  
     parseBoolean(String lexicalXSDBoolean) 将字符串参数转换为一个 boolean 值。  |  
    
 static byte |  
     parseByte(String lexicalXSDByte) 将字符串参数转换为一个 byte 值。  |  
    
 static Calendar |  
     parseDate(String lexicalXSDDate) 将字符串参数转换为一个 Calendar 值。  |  
    
 static Calendar |  
     parseDateTime(String lexicalXSDDateTime) 将字符串参数转换为一个 Calendar 值。  |  
    
 static BigDecimal |  
     parseDecimal(String lexicalXSDDecimal) 将字符串参数转换为一个 BigDecimal 值。  |  
    
 static double |  
     parseDouble(String lexicalXSDDouble) 将字符串参数转换为一个 double 值。  |  
    
 static float |  
     parseFloat(String lexicalXSDFloat) 将字符串参数转换为一个 float 值。  |  
    
 static byte[] |  
     parseHexBinary(String lexicalXSDHexBinary) 将字符串参数转换为一个字节数组。  |  
    
 static int |  
     parseInt(String lexicalXSDInt) 将字符串参数转换为一个 int 值。  |  
    
 static BigInteger |  
     parseInteger(String lexicalXSDInteger) 将字符串参数转换为一个 BigInteger 值。  |  
    
 static long |  
     parseLong(String lexicalXSDLong) 将字符串参数转换为一个 long 值。  |  
    
 static QName |  
     parseQName(String lexicalXSDQName, NamespaceContext nsc) 将字符串参数转换为一个 byte 值。  |  
    
 static short |  
     parseShort(String lexicalXSDShort) 将字符串参数转换为一个 short 值。  |  
    
 static String |  
     parseString(String lexicalXSDString) 将词汇 XSD 字符串参数转换为一个 String 值。  |  
    
 static Calendar |  
     parseTime(String lexicalXSDTime) 将字符串参数转换为一个 Calendar 值。  |  
    
 static long |  
     parseUnsignedInt(String lexicalXSDUnsignedInt) 将字符串参数转换为一个 long 值。  |  
    
 static int |  
     parseUnsignedShort(String lexicalXSDUnsignedShort) 将字符串参数转换为一个 int 值。  |  
    
 static String |  
     printAnySimpleType(String val) 将字符串值转换为一个字符串。  |  
    
 static String |  
     printBase64Binary(byte[] val) 将字节数组转换为一个字符串。  |  
    
 static String |  
     printBoolean(boolean val) 将 boolean 值转换为一个字符串。  |  
    
 static String |  
     printByte(byte val) 将 byte 值转换为一个字符串。  |  
    
 static String |  
     printDate(Calendar val) 将 Calendar 值转换为一个字符串。  |  
    
 static String |  
     printDateTime(Calendar val) 将 Calendar 值转换为一个字符串。  |  
    
 static String |  
     printDecimal(BigDecimal val) 将 BigDecimal 值转换为一个字符串。  |  
    
 static String |  
     printDouble(double val) 将 double 值转换为一个字符串。  |  
    
 static String |  
     printFloat(float val) 将 float 值转换为一个字符串。  |  
    
 static String |  
     printHexBinary(byte[] val) 将字节数组转换为一个字符串。  |  
    
 static String |  
     printInt(int val) 将 int 值转换为一个字符串。  |  
    
 static String |  
     printInteger(BigInteger val) 将 BigInteger 值转换为一个字符串。  |  
    
 static String |  
     printLong(long val) 将 long 值转换为一个字符串。  |  
    
 static String |  
     printQName(QName val, NamespaceContext nsc) 将 QName 实例转换为一个字符串。  |  
    
 static String |  
     printShort(short val) 将 short 值转换为一个字符串。  |  
    
 static String |  
     printString(String val) 将字符串参数转换为一个字符串。  |  
    
 static String |  
     printTime(Calendar val) 将 Calendar 值转换为一个字符串。  |  
    
 static String |  
     printUnsignedInt(long val) 将 long 值转换为一个字符串。  |  
    
 static String |  
     printUnsignedShort(int val) 将 int 值转换为一个字符串。  |  
    
 static void |  
     setDatatypeConverter(DatatypeConverterInterface converter) 此方法仅适用于 JAXB 提供者。  |  
    
| 从类 java.lang.Object 继承的方法 | 
|---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |  
    
| 方法详细信息 | 
|---|
public static void setDatatypeConverter(DatatypeConverterInterface converter)
JAXB 提供者需要在允许执行任何 JAXB 客户端编组或解组操作之前的某个时间点调用此方法。要配置用于执行打印和解析功能的转换器,这一步是必需的。
重复调用此 API 是无效的,传入第一次调用中的 DatatypeConverterInterface 实例将始终用于后续调用。
converter - 实现 DatatypeConverterInterface 类的类实例,此参数不能为 null。 
     IllegalArgumentException - 如果参数为 null
     public static String parseString(String lexicalXSDString)
将词汇 XSD 字符串参数转换为一个 String 值。
lexicalXSDString - 包含 xsd:string 的词汇表示形式的字符串。 
     public static BigInteger parseInteger(String lexicalXSDInteger)
将字符串参数转换为一个 BigInteger 值。
lexicalXSDInteger - 包含 xsd:integer 的词汇表示形式的字符串。 
     NumberFormatException - 如果 
      lexicalXSDInteger 不是 
      BigInteger 值的有效字符串表示形式。
     public static int parseInt(String lexicalXSDInt)
将字符串参数转换为一个 int 值。
lexicalXSDInt - 包含 xsd:int 的词汇表示形式的字符串。 
     NumberFormatException - 如果 
      lexicalXSDInt 不是 
      int 值的有效字符串表示形式。
     public static long parseLong(String lexicalXSDLong)
将字符串参数转换为一个 long 值。
lexicalXSDLong - 包含 xsd:long 的词汇表示形式的字符串。 
     NumberFormatException - 如果 
      lexicalXSDLong 不是 
      long 值的有效字符串表示形式。
     public static short parseShort(String lexicalXSDShort)
将字符串参数转换为一个 short 值。
lexicalXSDShort - 包含 xsd:short 的词汇表示形式的字符串。 
     NumberFormatException - 如果 
      lexicalXSDShort 不是 
      short 值的有效字符串表示形式。
     public static BigDecimal parseDecimal(String lexicalXSDDecimal)
将字符串参数转换为一个 BigDecimal 值。
lexicalXSDDecimal - 包含 xsd:decimal 的词汇表示形式的字符串。 
     NumberFormatException - 如果 
      lexicalXSDDecimal 不是 
      BigDecimal 的有效字符串表示形式。
     public static float parseFloat(String lexicalXSDFloat)
将字符串参数转换为一个 float 值。
lexicalXSDFloat - 包含 xsd:float 的词汇表示形式的字符串。 
     NumberFormatException - 如果 
      lexicalXSDFloat 不是 
      float 值的有效字符串表示形式。
     public static double parseDouble(String lexicalXSDDouble)
将字符串参数转换为一个 double 值。
lexicalXSDDouble - 包含 xsd:double 的词汇表示形式的字符串。 
     NumberFormatException - 如果 
      lexicalXSDDouble 不是 
      double 值的有效字符串表示形式。
     public static boolean parseBoolean(String lexicalXSDBoolean)
将字符串参数转换为一个 boolean 值。
lexicalXSDBoolean - 包含 xsd:boolean 的词汇表示形式的字符串。 
     IllegalArgumentException - 如果字符串参数不符合 XML Schema Part 2: Datatypes 中为 xsd:boolean 定义的词汇值空间。
     public static byte parseByte(String lexicalXSDByte)
将字符串参数转换为一个 byte 值。
lexicalXSDByte - 包含 xsd:byte 的词汇表示形式的字符串。 
     IllegalArgumentException - 如果字符串参数不符合 XML Schema Part 2: Datatypes 为 xsd:byte 定义的词汇值空间。
     public static QName parseQName(String lexicalXSDQName, NamespaceContext nsc)
将字符串参数转换为一个 byte 值。
字符串参数 lexicalXSDQname 必须符合 XML Schema Part 2: Datatypes 规范:QName 中指定的词汇值空间。
lexicalXSDQName - 包含 xsd:QName 的词汇表示形式的字符串。
     nsc - 解释 QName 中前缀的名称空间上下文。 
     IllegalArgumentException - 如果字符串参数不符合 XML Schema Part 2 规范,或者 
      lexicalXSDQname 的名称空间前缀未绑定到 NamespaceContext 
      nsc 中的 URI。
     public static Calendar parseDateTime(String lexicalXSDDateTime)
将字符串参数转换为一个 Calendar 值。
lexicalXSDDateTime - 包含 xsd:datetime 的词汇表示形式的字符串。 
     IllegalArgumentException - 如果字符串参数不符合 XML Schema Part 2: Datatypes 为 xsd:dateTime 定义的词汇值空间。
     public static byte[] parseBase64Binary(String lexicalXSDBase64Binary)
将字符串参数转换为一个字节数组。
lexicalXSDBase64Binary - 包含 xsd:base64Binary 的词汇表示形式的字符串。 
     IllegalArgumentException - 如果字符串参数不符合 XML Schema Part 2: Datatypes 为 xsd:base64Binary 定义的词汇值空间。
     public static byte[] parseHexBinary(String lexicalXSDHexBinary)
将字符串参数转换为一个字节数组。
lexicalXSDHexBinary - 包含 xsd:hexBinary 的词汇表示形式的字符串。 
     IllegalArgumentException - 如果字符串参数不符合 XML Schema Part 2: Datatypes 为 xsd:hexBinary 定义的词汇值空间。
     public static long parseUnsignedInt(String lexicalXSDUnsignedInt)
将字符串参数转换为一个 long 值。
lexicalXSDUnsignedInt - 包含 xsd:unsignedInt 的词汇表示形式的字符串。 
     NumberFormatException - 如果不能将字符串参数解析为 
      long 值。
     public static int parseUnsignedShort(String lexicalXSDUnsignedShort)
将字符串参数转换为一个 int 值。
lexicalXSDUnsignedShort - 包含 xsd:unsignedShort 的词汇表示形式的字符串。 
     NumberFormatException - 如果不能将字符串参数解析为 
      int 值。
     public static Calendar parseTime(String lexicalXSDTime)
将字符串参数转换为一个 Calendar 值。
lexicalXSDTime - 包含 xsd:time 的词汇表示形式的字符串。 
     IllegalArgumentException - 如果字符串参数不符合 XML Schema Part 2: Datatypes 为 xsd:Time 定义的词汇值空间。
     public static Calendar parseDate(String lexicalXSDDate)
将字符串参数转换为一个 Calendar 值。
lexicalXSDDate - 包含 xsd:Date 的词汇表示形式的字符串。 
     IllegalArgumentException - 如果字符串参数不符合 XML Schema Part 2: Datatypes 为 xsd:Date 定义的词汇值空间。
     public static String parseAnySimpleType(String lexicalXSDAnySimpleType)
返回包含简单类型的词汇表示形式的字符串。
lexicalXSDAnySimpleType - 包含简单类型的词汇表示形式的字符串。 
     public static String printString(String val)
将字符串参数转换为一个字符串。
val - 字符串值。 
     public static String printInteger(BigInteger val)
将 BigInteger 值转换为一个字符串。
val - 一个 BigInteger 值 
     IllegalArgumentException - 如果 
      val 为 null。
     public static String printInt(int val)
将 int 值转换为一个字符串。
val - 一个 int 值 
     public static String printLong(long val)
将 long 值转换为一个字符串。
val - 一个 long 值 
     public static String printShort(short val)
将 short 值转换为一个字符串。
val - 一个 short 值 
     public static String printDecimal(BigDecimal val)
将 BigDecimal 值转换为一个字符串。
val - 一个 BigDecimal 值 
     IllegalArgumentException - 如果 
      val 为 null。
     public static String printFloat(float val)
将 float 值转换为一个字符串。
val - 一个 float 值 
     public static String printDouble(double val)
将 double 值转换为一个字符串。
val - 一个 double 值 
     public static String printBoolean(boolean val)
将 boolean 值转换为一个字符串。
val - 一个 boolean 值 
     public static String printByte(byte val)
将 byte 值转换为一个字符串。
val - 一个 byte 值 
     public static String printQName(QName val, NamespaceContext nsc)
将 QName 实例转换为一个字符串。
val - 一个 QName 值
     nsc - 解释 QName 中前缀的名称空间上下文。 
     IllegalArgumentException - 如果 
      val 为 null、
      nsc 为非 null 或 
      nsc.getPrefix(nsprefixFromVal) 为 null。
     public static String printDateTime(Calendar val)
将 Calendar 值转换为一个字符串。
val - 一个 Calendar 值 
     IllegalArgumentException - 如果 
      val 为 null。
     public static String printBase64Binary(byte[] val)
将字节数组转换为一个字符串。
val - 一个字节数组 
     IllegalArgumentException - 如果 
      val 为 null。
     public static String printHexBinary(byte[] val)
将字节数组转换为一个字符串。
val - 一个字节数组 
     IllegalArgumentException - 如果 
      val 为 null。
     public static String printUnsignedInt(long val)
将 long 值转换为一个字符串。
val - 一个 long 值 
     public static String printUnsignedShort(int val)
将 int 值转换为一个字符串。
val - 一个 int 值 
     public static String printTime(Calendar val)
将 Calendar 值转换为一个字符串。
val - 一个 Calendar 值 
     IllegalArgumentException - 如果 
      val 为 null。
     public static String printDate(Calendar val)
将 Calendar 值转换为一个字符串。
val - 一个 Calendar 值 
     IllegalArgumentException - 如果 
      val 为 null。
     public static String printAnySimpleType(String val)
将字符串值转换为一个字符串。
val - 字符串值