什么样的Java类型是“[B”?

时间:2011-01-05 17:02:45

标签: java hibernate jdbc cryptography md5

我试图通过Java代码(Hibernate)从MySQL DB获取MD5加密传递。但我不能得到String或任何合理的Java类型。

我唯一得到的是这个无益的信息: java.lang.ClassCastException:[B不能转换为com.mysql.jdbc.Blob (或者我尝试转换为的任何Java类型)。

这是我的方法:

public void testCrypto() {
        session.beginTransaction();
        // creates native SQL query
        // uses native MySQL's MD5 crypto
        final Blob pass = (Blob) session.createSQLQuery("SELECT MD5('somePass')")
            .list().get(0);
        session.getTransaction().commit();
}

这是完整的堆栈跟踪:

java.lang.ClassCastException: [B cannot be cast to com.mysql.jdbc.Blob
    at domain.DatabaseTest.testCrypto(DatabaseTest.java:57)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at junit.framework.TestCase.runTest(TestCase.java:168)
    at junit.framework.TestCase.runBare(TestCase.java:134)
    at junit.framework.TestResult$1.protect(TestResult.java:110)
    at junit.framework.TestResult.runProtected(TestResult.java:128)
    at junit.framework.TestResult.run(TestResult.java:113)
    at junit.framework.TestCase.run(TestCase.java:124)
    at junit.framework.TestSuite.runTest(TestSuite.java:232)
    at junit.framework.TestSuite.run(TestSuite.java:227)
    at org.junit.internal.runners.JUnit38ClassRunner.run(JUnit38ClassRunner.java:83)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:49)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)

4 个答案:

答案 0 :(得分:46)

我的朋友是一个字节数组。在JNI中,[B用于描述字节数组([)(B)。一组int是[I等。

您可以在此处获得有关字段描述符的更多信息:
JNI Types and Data StructuresTable 3-2应该是你要找的东西。)

答案 1 :(得分:8)

这是byte[].class的班级名称。试试这个:

System.out.println(byte[].class.getName());

输出(你猜对了):

  

[B

如果您想访问可读名称,请使用Class.getCanonicalName()

System.out.println(byte[].class.getCanonicalName());

输出:

  

字节[]

答案 2 :(得分:4)

当另一个回答状态时,那是一个字节数组。

如果要从字节数组中获取字符串,请使用String构造函数:

public void testCrypto()
{
        session.beginTransaction();
        // creates native SQL query
        // uses native MySQL's MD5 crypto
        final String pass = new String(session.createSQLQuery("SELECT MD5('somePass')")
            .list().get(0));
        session.getTransaction().commit();
}

答案 3 :(得分:3)

[B是字节数组(byte [])的编码类型名称,通常只应出现在类型签名字符串中,因为它不是有效的类型名称。