2011-01-05 18 views
17

मैं जावा कोड (हाइबरनेट) के माध्यम से MySQL डीबी से MD5 एन्क्रिप्टेड पास प्राप्त करने का प्रयास कर रहा हूं। लेकिन मैं न तो स्ट्रिंग और न ही कोई उचित जावा प्रकार प्राप्त कर सकता हूं।किस प्रकार का जावा प्रकार "[बी" है?

केवल एक चीज मैं हो रही है इस बेकार संदेश है: java.lang.ClassCastException: [बी (या जो भी जावा प्रकार मैं करने के लिए कास्ट का प्रयास करें) 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

कि

यहाँ मेरी विधि है। जेएनआई में, [बी का प्रयोग बाइट्स (B) के सरणी() का वर्णन करने के लिए किया जाता है। ints की एक सरणी [I है आदि

आप क्षेत्र वर्णनकर्ता यहाँ पर थोड़ा और अधिक जानकारी प्राप्त कर सकते हैं:
http://java.sun.com/docs/books/jni/html/types.html (section 12.3.3 होना चाहिए कि आप क्या ढूंढ रहे हैं)।

+0

, धन्यवाद आप सबसे उपयोगी किया गया है:

आप एक बाइट सरणी से एक स्ट्रिंग प्राप्त करना चाहते हैं, स्ट्रिंग निर्माता का उपयोग करें! – Xorty

3

[B एक बाइट सरणी (बाइट []) के लिए एन्कोडेड प्रकार का नाम है, जो आमतौर पर केवल प्रकार के हस्ताक्षर तारों में दिखाई देना चाहिए, क्योंकि यह वैध प्रकार का नाम नहीं है।

6

यह byte[].class का वर्ग नाम है।

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

आउटपुट (आपने ठीक समझा):

[बी

और तुम पढ़ने योग्य नाम का उपयोग करना चाहते हैं, का उपयोग Class.getCanonicalName():

System.out.println(byte[].class.getCanonicalName()); 
इस प्रयास करें

आउटपुट:

बाइट []

4

अन्य उत्तर राज्य के रूप में, कि एक बाइट सरणी है।

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 कंसोल प्रिंट करता है। लेकिन pass.getBytes() लंबाई लंबाई 32 कहती है, और एमडी 5 128 बिट होना चाहिए। मैं सुराग कहाँ खो गया? – Xorty

+1

@Xorty: एन्क्रिप्शन शक्ति और स्ट्रिंग की लंबाई को मापने के बीच एक अंतर है। एमडी 5 किसी इनपुट को किसी स्ट्रिंग में परिवर्तित करेगा जिसमें 32 हेक्स वर्णों से कम नहीं है। –

+0

ग्रेट, मिथक बस्टेड;) – Xorty

संबंधित मुद्दे