2011-12-02 22 views
7

मैं जैक्सन फ़ाइल का जिक्र करने के लिए जैक्सन का उपयोग कर रहा हूं (जिसे मैंने जैक्सन के साथ क्रमबद्ध किया है)। जेसन एक साधारण हैश मैप है, लेकिन जब मैं कोशिश करता हूं और deserialize मैपर शिकायत कर रहा है।जैक्सन: मानचित्र का deserialization

org.codehaus.jackson.map.JsonMappingException: Can not deserialize instance of java.util.HashMap out of START_ARRAY token 

मेरे धारावाहिक HashMap स्ट्रिंग .....

{ 
"0f861a9a-0a3e-40a7-8ff3-0b83d8070876" : { 
"name" : "BAR.xml", 
"filePath" : "/FOO/repo/BAR.xml" 
}, 
"f3cbb32e-b7b8-4af1-b48b-7ea393de7971" : { 
"name" : "BLAH.xml", 
"filePath" : "/FOO/repo/BLAH.xml" 
}, 
"012009b6-26e9-4bc1-9050-2a4ac9546c7e" : { 
"name" : "Check System.xml", 
"filePath" : "/FOO/repo/Check System.xml" 
} 
} 

मैं इस काम करने के लिए 2 अलग अलग तरीकों की कोशिश की है, और दोनों असफल ...

//doesn't work  
cache = (Map<String,UUIDInfo>) mapper.readValue(bytes.toString(), new TypeReference<HashMap<String,UUIDInfo>>(){}); 

//doesn't work. 
cache = (Map<String,UUIDInfo>) mapper.readValue(bytes.toString(), TypeFactory.mapType(HashMap.class, String.class, UUIDInfo.class)); 

पूर्ण stacktrace

org.codehaus.jackson.map.JsonMappingException: Can not deserialize instance of java.util.LinkedHashMap out of START_ARRAY token 
at [Source: [email protected]; line: 1, column: 1] 
    at org.codehaus.jackson.map.JsonMappingException.from(JsonMappingException.java:163) 
    at org.codehaus.jackson.map.deser.StdDeserializationContext.mappingException(StdDeserializationContext.java:198) 
    at org.codehaus.jackson.map.deser.MapDeserializer.deserialize(MapDeserializer.java:151) 
    at org.codehaus.jackson.map.deser.MapDeserializer.deserialize(MapDeserializer.java:25) 
    at org.codehaus.jackson.map.ObjectMapper._readMapAndClose(ObjectMapper.java:2395) 
    at org.codehaus.jackson.map.ObjectMapper.readValue(ObjectMapper.java:1602) 
    at com.hp.oo.studio.shared.UUIDRegistry.UUIDRegistry.<init>(UUIDRegistry.java:63) 
    at com.hp.oo.studio.shared.UUIDRegistry.UUIDRegistry.<clinit>(UUIDRegistry.java:37) 
    at com.hp.oo.studio.shared.StudioShared.loadUUIDRegistry(StudioShared.java:93) 
    at com.hp.oo.studio.shared.StudioShared.start(StudioShared.java:42) 
    at org.eclipse.osgi.framework.internal.core.BundleContextImpl$1.run(BundleContextImpl.java:711) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at org.eclipse.osgi.framework.internal.core.BundleContextImpl.startActivator(BundleContextImpl.java:702) 
    at org.eclipse.osgi.framework.internal.core.BundleContextImpl.start(BundleContextImpl.java:683) 
    at org.eclipse.osgi.framework.internal.core.BundleHost.startWorker(BundleHost.java:381) 
    at org.eclipse.osgi.framework.internal.core.AbstractBundle.start(AbstractBundle.java:299) 
    at org.eclipse.osgi.framework.util.SecureAction.start(SecureAction.java:440) 
    at org.eclipse.osgi.internal.loader.BundleLoader.setLazyTrigger(BundleLoader.java:268) 
    at org.eclipse.core.runtime.internal.adaptor.EclipseLazyStarter.postFindLocalClass(EclipseLazyStarter.java:107) 
    at org.eclipse.osgi.baseadaptor.loader.ClasspathManager.findLocalClass(ClasspathManager.java:462) 
    at org.eclipse.osgi.internal.baseadaptor.DefaultClassLoader.findLocalClass(DefaultClassLoader.java:216) 
    at org.eclipse.osgi.internal.loader.BundleLoader.findLocalClass(BundleLoader.java:400) 
    at org.eclipse.osgi.internal.loader.SingleSourcePackage.loadClass(SingleSourcePackage.java:35) 
    at org.eclipse.osgi.internal.loader.BundleLoader.findClassInternal(BundleLoader.java:473) 
    at org.eclipse.osgi.internal.loader.BundleLoader.findClass(BundleLoader.java:429) 
    at org.eclipse.osgi.internal.loader.BundleLoader.findClass(BundleLoader.java:417) 
    at org.eclipse.osgi.internal.baseadaptor.DefaultClassLoader.loadClass(DefaultClassLoader.java:107) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:356) 
    at com.hp.oo.studio.StudioUI.registerFile(StudioUI.java:133) 
    at com.hp.oo.studio.StudioUI.findFilesInDirectory(StudioUI.java:125) 
    at com.hp.oo.studio.StudioUI.findFilesInDirectory(StudioUI.java:120) 
    at com.hp.oo.studio.StudioUI.start(StudioUI.java:75) 
    at org.eclipse.osgi.framework.internal.core.BundleContextImpl$1.run(BundleContextImpl.java:711) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at org.eclipse.osgi.framework.internal.core.BundleContextImpl.startActivator(BundleContextImpl.java:702) 
    at org.eclipse.osgi.framework.internal.core.BundleContextImpl.start(BundleContextImpl.java:683) 
    at org.eclipse.osgi.framework.internal.core.BundleHost.startWorker(BundleHost.java:381) 
    at org.eclipse.osgi.framework.internal.core.AbstractBundle.start(AbstractBundle.java:299) 
    at org.eclipse.osgi.framework.util.SecureAction.start(SecureAction.java:440) 
    at org.eclipse.osgi.internal.loader.BundleLoader.setLazyTrigger(BundleLoader.java:268) 
    at org.eclipse.core.runtime.internal.adaptor.EclipseLazyStarter.postFindLocalClass(EclipseLazyStarter.java:107) 
    at org.eclipse.osgi.baseadaptor.loader.ClasspathManager.findLocalClass(ClasspathManager.java:462) 
    at org.eclipse.osgi.internal.baseadaptor.DefaultClassLoader.findLocalClass(DefaultClassLoader.java:216) 
    at org.eclipse.osgi.internal.loader.BundleLoader.findLocalClass(BundleLoader.java:400) 
    at org.eclipse.osgi.internal.loader.BundleLoader.findClassInternal(BundleLoader.java:476) 
    at org.eclipse.osgi.internal.loader.BundleLoader.findClass(BundleLoader.java:429) 
    at org.eclipse.osgi.internal.loader.BundleLoader.findClass(BundleLoader.java:417) 
    at org.eclipse.osgi.internal.baseadaptor.DefaultClassLoader.loadClass(DefaultClassLoader.java:107) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:356) 
    at org.eclipse.osgi.internal.loader.BundleLoader.loadClass(BundleLoader.java:345) 
    at org.eclipse.osgi.framework.internal.core.BundleHost.loadClass(BundleHost.java:229) 
    at org.eclipse.osgi.framework.internal.core.AbstractBundle.loadClass(AbstractBundle.java:1207) 
    at org.eclipse.core.internal.registry.osgi.RegistryStrategyOSGI.createExecutableExtension(RegistryStrategyOSGI.java:174) 
    at org.eclipse.core.internal.registry.ExtensionRegistry.createExecutableExtension(ExtensionRegistry.java:905) 
    at org.eclipse.core.internal.registry.ConfigurationElement.createExecutableExtension(ConfigurationElement.java:243) 
    at org.eclipse.core.internal.registry.ConfigurationElementHandle.createExecutableExtension(ConfigurationElementHandle.java:55) 
    at org.eclipse.ui.internal.WorkbenchPlugin$1.run(WorkbenchPlugin.java:268) 
    at org.eclipse.swt.custom.BusyIndicator.showWhile(BusyIndicator.java:70) 
    at org.eclipse.ui.internal.WorkbenchPlugin.createExtension(WorkbenchPlugin.java:264) 
    at org.eclipse.ui.internal.registry.EditorDescriptor.createEditor(EditorDescriptor.java:235) 
    at org.eclipse.ui.internal.EditorManager.createPart(EditorManager.java:875) 
    at org.eclipse.ui.internal.EditorReference.createPartHelper(EditorReference.java:609) 
    at org.eclipse.ui.internal.EditorReference.createPart(EditorReference.java:465) 
    at org.eclipse.ui.internal.WorkbenchPartReference.getPart(WorkbenchPartReference.java:595) 
    at org.eclipse.ui.internal.EditorAreaHelper.setVisibleEditor(EditorAreaHelper.java:271) 
    at org.eclipse.ui.internal.EditorManager.setVisibleEditor(EditorManager.java:1459) 
    at org.eclipse.ui.internal.EditorManager$5.runWithException(EditorManager.java:972) 
    at org.eclipse.ui.internal.StartupThreading$StartupRunnable.run(StartupThreading.java:31) 
    at org.eclipse.swt.widgets.RunnableLock.run(RunnableLock.java:35) 
    at org.eclipse.swt.widgets.Synchronizer.runAsyncMessages(Synchronizer.java:135) 
    at org.eclipse.swt.widgets.Display.runAsyncMessages(Display.java:3563) 
    at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3212) 
    at org.eclipse.ui.application.WorkbenchAdvisor.openWindows(WorkbenchAdvisor.java:803) 
    at org.eclipse.ui.internal.Workbench$33.runWithException(Workbench.java:1595) 
    at org.eclipse.ui.internal.StartupThreading$StartupRunnable.run(StartupThreading.java:31) 
    at org.eclipse.swt.widgets.RunnableLock.run(RunnableLock.java:35) 
    at org.eclipse.swt.widgets.Synchronizer.runAsyncMessages(Synchronizer.java:135) 
     at org.eclipse.swt.widgets.Display.runAsyncMessages(Display.java:3563) 
    at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3212) 
    at org.eclipse.ui.internal.Workbench.runUI(Workbench.java:2604) 
    at org.eclipse.ui.internal.Workbench.access$4(Workbench.java:2494) 
    at org.eclipse.ui.internal.Workbench$7.run(Workbench.java:674) 
    at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:332) 
    at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:667) 
    at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:149) 
    at org.eclipse.ui.internal.ide.application.IDEApplication.start(IDEApplication.java:123) 
    at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:196) 
    at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:110) 
    at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:79) 
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:344) 
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:179) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:601) 
    at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:622) 
    at org.eclipse.equinox.launcher.Main.basicRun(Main.java:577) 
    at org.eclipse.equinox.launcher.Main.run(Main.java:1410) 
    at org.eclipse.equinox.launcher.Main.main(Main.java:1386) 
+0

पूर्ण अपवाद स्टैक ट्रेस कृपया –

+0

आपके लिए स्टैक ट्रेस जोड़ा गया। – user1078261

उत्तर

0

अपना नक्शा लपेटें एक और वस्तु और फिर मार्शल। उदाहरण के लिए :

class MyObject{ 

    private Map<String,UUIDInfo> map; 

} 

और बस कार्य करें: mappper.readValue(myInstance, MyObject.class)

+0

मुझे लगता है कि कोशिश की और यह रूप में अच्छी तरह से काम नहीं करता .... { "कैश": { "0f861a9a-0a3e-40a7-8ff3-0b83d8070876": { "नाम": "BAR.xml" , "filePath": "/FOO/repo/BAR.xml" }, "f3cbb32e-b7b8-4af1-b48b-7ea393de7971": { "नाम": "BLAH.xml", "filePath": " /FOO/repo/BLAH.xml " }, " 012009b6-26e9-4bc1-9050-2a4ac9546c7e ": { " नाम ":" सिस्टम.एक्सएमएल जांचें ", " फ़ाइलपाथ ":"/FOO/repo/Check System.xml " } } } org.codehaus.jackson.map.JsonMappingException: com.hp.oo.studio.shared.UUIDRegistry.UUIDMap का उदाहरण deserialize नहीं कर सकता START_ARRAY टोकन – user1078261

+0

समाधान गलत है क्योंकि मानचित्र की घोषणा मानचित्र होना चाहिए <स्ट्रिंग, UUIDInfo> , अवांछित मानचित्र नहीं। यदि जेनेरिक प्रकार जोड़ा जाता है तो यह वास्तव में काम कर सकता है। – StaxMan

+0

अच्छी तरह से मेरा यूयूआईडीएएम रैपर नक्शा <स्ट्रिंग, UUIDInfo> कैश के रूप में मानचित्र घोषित करता है; – user1078261

1

मुझे लगता है कि इस मुद्दे को Jackson polymorphic deserialization विकी पृष्ठ पर 5.5 के तहत सूचीबद्ध एक है। असल में यह जावा टाइप एरर आपको धारावाहिक करते समय काट रहा है; और जब deserializing प्रकार स्पष्ट रूप से उपलब्ध कराया जाता है; और वह विसंगति दर्द होता है।

+0

मैंने बाद में अपने pojos में @JsonTypeInfo जोड़ा है और जो लोग जेसन को लिखे गए हैं, लेकिन यह अभी भी काम नहीं करता है।:( org.codehaus.jackson.map.JsonMappingException: अप्रत्याशित टोकन (START_ARRAY), अपेक्षित START_OBJECT: JSON ऑब्जेक्ट को As.PROPERTY प्रकार की जानकारी रखने के लिए आवश्यक है (वर्ग com.hp.oo.studio.shared.UUIDRegistry.UUIDMap के लिए) – user1078261

+3

यहां रहस्य यह है कि वर्तमान में JSON के पास कोई START_ARRAY टोकन ("[") नहीं है, इसलिए मुझे यह विश्वास करना मुश्किल लगता है कि जेएसओएन का उपयोग deserialization के लिए किया जा रहा है। बीटीडब्ल्यू, जो जैक्सन संस्करण यह है? – StaxMan

1

मूल प्रश्न में JSON जैक्सन 1.9.2 का उपयोग करके मेरे लिए बस ठीक है।

import java.io.File; 
import java.util.HashMap; 
import java.util.Map; 

import org.codehaus.jackson.annotate.JsonAutoDetect.Visibility; 
import org.codehaus.jackson.annotate.JsonMethod; 
import org.codehaus.jackson.map.ObjectMapper; 
import org.codehaus.jackson.type.TypeReference; 

public class JacksonFoo 
{ 
    public static void main(String[] args) throws Exception 
    { 
    ObjectMapper mapper = new ObjectMapper().setVisibility(JsonMethod.FIELD, Visibility.ANY); 
    Map<String, UUIDInfo> cache = 
     mapper.readValue(new File("input.json"), new TypeReference<HashMap<String, UUIDInfo>>() {}); 
    System.out.println(cache); 
    // output: 
    // {0f861a9a-0a3e-40a7-8ff3-0b83d8070876=UUIDInfo: name=BAR.xml, filePath=/FOO/repo/BAR.xml, 
    // f3cbb32e-b7b8-4af1-b48b-7ea393de7971=UUIDInfo: name=BLAH.xml, filePath=/FOO/repo/BLAH.xml, 
    // 012009b6-26e9-4bc1-9050-2a4ac9546c7e=UUIDInfo: name=Check System.xml, filePath=/FOO/repo/Check System.xml} 
    } 
} 

class UUIDInfo 
{ 
    String name; 
    String filePath; 

    @Override 
    public String toString() 
    { 
    return String.format("UUIDInfo: name=%s, filePath=%s", name, filePath); 
    } 
} 
2

इसे इस तरह कार्य करें:

ArrayList<LinkedHashMap<?, ?>> companymap = mapper.readValue(jsonCompany, ArrayList.class); 
+0

मैं सुझाव देता हूं कि डालने से बचें कार्यान्वयन कक्षाएं: सूची > companymap = mapper.readValue (jsoncompany, list.class); –

+0

ए मैसन: अगर मैं इससे बचता हूं तो समस्या हल नहीं होगी। कोई अन्य जवाब इसके साथ काम नहीं कर रहा है .. और मैंने इसका परीक्षण किया है ठीक काम कर रहा है। – Avinash

7
public class ArrayMapDeserializer extends JsonDeserializer<Map<String, UUIDInfo>> { 

    @Override 
    public Map<String, UUIDInfo> deserialize(JsonParser jp, DeserializationContext context) 
      throws IOException { 
     ObjectMapper mapper = (ObjectMapper) jp.getCodec(); 
     if (jp.getCurrentToken().equals(JsonToken.START_OBJECT)) { 
      return mapper.readValue(jp, new TypeReference<HashMap<String, UUIDInfo>>() { 
      }); 
     } else { 
      //consume this stream 
      mapper.readTree(jp); 
      return new HashMap<String, UUIDInfo>(); 
     } 
    } 
} 

वर्ग में घोषित

@JsonDeserialize(using = ArrayMapDeserializer.class) 
private HashMap<String, UUIDInfo> aliases = new HashMap<String, UUIDInfo>(); 

मैं जैक्सन 2.4.2 का उपयोग कर रहा हूँ।

आशा है कि यह आपकी मदद कर सके।

+0

महान समाधान! बहुत बहुत धन्यवाद! –

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