2011-01-05 8 views
17

私は、MySQL DBからJavaコード(Hibernate)を介してMD5暗号化されたパスを取得しようとしています。しかし、私は文字列も合理的なJava型も得られません。「[B」はどのJavaタイプですか?

私は取得しています唯一のことは、この役に立たないメッセージです: とjava.lang.ClassCastException:[Bは(または任意のJavaタイプIはにキャストしてみてください)をcom.mysql.jdbc.Blobにキャストすることはできません。ここで

は私の方法であって、ここで

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) 

答えて

35

私の友人は、バイトの配列であること。 JNIでは、[Bはバイト(B)の配列()を記述するために使用されます。
http://java.sun.com/docs/books/jni/html/types.htmlsection 12.3.3あなたが探しているものでなければなりません):intの配列は、あなたがここにフィールド記述子のビットより多くの情報を得ることができ[Iなど

です。

+0

はありがとう、あなたが最も参考にされています! – Xorty

3

[Bは、バイト配列(byte [])のエンコードされた型名です。通常、型シグネチャ文字列には有効な型名ではないため、この型名は通常エンコードされます。

6

クラス名はbyte[].classです。

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

出力(あなたはそれを推測)::このお試しください

[B

をそして、あなたは読みやすい名前にアクセスしたい場合は、Class.getCanonicalName()を使用します。

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

出力:

他の回答の状態として

バイト[]

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(); 
} 
+0

素晴らしいですが、これは本当に奇妙な動作です!この文字列は、mysql consoleを出力するものとまったく同じです。しかし、pass.getBytes()。lengthは32であり、MD5は128bitsでなければなりません。どこで手がかりを失ったのですか? – Xorty

+1

@Xorty:暗号化強度と文字列の長さの測定には違いがあります。 MD5は、任意の入力を32文字以上32文字未満の文字列に変換します。 –

+0

偉大な、神話が逮捕された;) – Xorty

関連する問題