2011-01-05 18 views
17

MD5 şifreli geçişi MySQL DB'den Java koduyla (Hazırda Bekletme) almaya çalışıyorum. Ama ne String ne de herhangi bir makul Java türünü alamıyorum.Ne tür bir Java türü "[B"?

alıyorum tek şey bu yararsız mesajdır: java.lang.ClassCastException: [B (ben döküm deneyin ya da her türlü Java tipini) com.mysql.jdbc.Blob için döküm edilemez.

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

tam yığın izidir: arkadaşım bayt bir dizidir

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) 

cevap

35

O

İşte yöntemdir. JNI'da, [B bir bayt ([) baytını (B) tanımlamak için kullanılır. ints dizisi [I vb

Burada saha açıklayıcı üzerinde biraz daha fazla bilgi alabilirsiniz:
http://java.sun.com/docs/books/jni/html/types.html (section 12.3.3 aradığınız şey olmalıdır).

+0

, teşekkür ederim size en yararlı olmuştur: Bir bayt dizisi bir dize almak istiyorsanız

, dize yapıcısı kullanın! – Xorty

3

[B, normalde yalnızca tür imzası dizelerinde görünmesi gereken bir bayt dizisi (bayt []) için kodlanmış tür adıdır; geçerli bir tür adı değil.

6

O byte[].class sınıf ismi.

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

Çıktı (tahmin edeceğiniz): Eğer okunabilir adını erişmek istiyorsanız

[B

Ve kullanmak Class.getCanonicalName():

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

Çıkış:

bayt [], diğer cevaplar devlet olarak

4

, bir bayt dizidir.

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

harika, ama bu gerçekten garip bir davranış! Bu String, mysql konsol baskısı ile tamamen aynıdır. Ancak pass.getBytes(). Boy 32, MD5 128 bit olmalıdır. İpucu nerede kaybettim? – Xorty

+1

@Xorty: Şifreleme gücünü ölçme ile bir String'in uzunluğu arasında fark vardır. MD5, herhangi bir girdiyi 32'den daha az olmayan altı karakteri olmayan bir dizeye dönüştürür. –

+0

Harika, efsane;;) – Xorty

İlgili konular