2012-07-03 5 views
1

여기에 자바에 그리드를 제출하는 동안 문제가 발생하여 구문 분석 오류가 발생합니다. 이 오류를 해결하는 방법. 도와주세요. 아래는 나의 반응이다. Json 데이터 구문 분석 오류

이 그리드 열 설정

columns: [ 
      { 
       xtype: 'gridcolumn', 
       dataIndex: 'afs', 
       text: 'AFS' 
      }, 
      { 
       xtype: 'gridcolumn', 
       dataIndex: 'date', 
       text: 'Date', 
       flex :1 
      }] 

입니다 응답

{"gridData":[{"id":170,"afs":5,"date":"04-22-2011","qty":12,"quantity":11,"shift":"A","sourceLocation":"Office","time":"12:00:00 AM"},{"id":171,"afs":6,"date":"04-22-2011","qty":12,"quantity":11,"shift":"B","sourceLocation":"Office","time":"12:00:00 AM"},{"id":172,"afs":7,"date":"04-22-2011","qty":12,"quantity":11,"shift":"C","sourceLocation":"Office","time":"12:00:00 AM"},{"id":173,"afs":8,"date":"04-22-2011","qty":12,"quantity":11,"shift":"A","sourceLocation":"Office","time":"12:00:00 AM"},{"id":174,"afs":9,"date":"04-22-2011","qty":12,"quantity":11,"shift":"B","sourceLocation":"Office","time":"12:00:00 AM"},{"id":175,"afs":10,"date":"04-22-2011","qty":12,"quantity":11,"shift":"C","sourceLocation":"Office","time":"12:00:00 AM"},{"id":176,"afs":11,"date":"04-22-2011","qty":12,"quantity":11,"shift":"A","sourceLocation":"Office","time":"12:00:00 AM"},{"id":177,"afs":12,"date":"04-22-2011","qty":12,"quantity":11,"shift":"B","sourceLocation":"Office","time":"12:00:00 AM"},{"id":178,"afs":13,"date":"04-22-2011","qty":12,"quantity":11,"shift":"C","sourceLocation":"Office","time":"12:00:00 AM"},{"id":179,"afs":14,"date":"04-22-2011","qty":12,"quantity":11,"shift":"A","sourceLocation":"Office","time":"12:00:00 AM"},{"id":180,"afs":15,"date":"04-22-2011","qty":12,"quantity":11,"shift":"B","sourceLocation":"Office","time":"12:00:00 AM"},{"id":181,"afs":16,"date":"04-22-2011","qty":12,"quantity":11,"shift":"C","sourceLocation":"Office","time":"12:00:00 AM"},{"id":182,"afs":17,"date":"04-22-2011","qty":12,"quantity":11,"shift":"A","sourceLocation":"Office","time":"12:00:00 AM"}],"success":true} 

않습니다이 내 컨트롤러 클래스 날짜

@JsonSerialize(using=JsonDateSerializer.class) 
public Date getDate() { 
    return this.date; 
} 

내 POJO 클래스 설정입니다

[email protected]sponseBody String saveGridData(HttpServletRequest request,@RequestParam("grid") String gridData){ 
    System.out.println("Group Name :"+request.getParameter("groupName")); 
    JSONPObject json = new JSONPObject("encode", gridData); 
    System.out.println(gridData); 
    NewSand[] newSands = getJsonString(gridData, NewSand[].class); 
    for(NewSand newSand: newSands){ 
     System.out.println("Shift --> " + newSand.getShift()); 
    } 
    return "true"; 
} 

private static <T> T getJsonString(String json, Class<T> type) throws JsonParseException{ 

    GsonBuilder gsonBuilder = new GsonBuilder(); 
    gsonBuilder.serializeNulls(); 
    JsonSerializer<Date> ser = new JsonSerializer<Date>() { 
      public JsonElement serialize(Date src, Type typeOfSrc, JsonSerializationContext 
        context) { 
      return src == null ? null : new JsonPrimitive(src.getTime()); 
      } 
     }; 

     JsonDeserializer<Date> deser = new JsonDeserializer<Date>() { 
      public Date deserialize(JsonElement json, Type typeOfT,JsonDeserializationContext context) throws JsonParseException { 
      return json == null ? null : new Date(json.getAsLong()); 
      } 
     }; 
     Gson gson = gsonBuilder.registerTypeAdapter(Date.class, ser).registerTypeAdapter(Date.class, deser).create(); 
    //Gson gson = gsonBuilder.create(); 
    return (T) gson.fromJson(json, type); 
} 
01 23,516,

예외 코드는 다음과 같습니다

Jul 03, 2012 2:55:46 PM org.apache.catalina.core.StandardWrapperValve invoke 
SEVERE: Servlet.service() for servlet [appServlet] in context with path [/Login] threw exception [Request processing failed; nested exception is java.lang.NumberFormatException: For input string: "04-22-2011"] with root cause 
java.lang.NumberFormatException: For input string: "04-22-2011" 
at java.lang.NumberFormatException.forInputString(NumberFormatException.java:65) 
at java.lang.Long.parseLong(Long.java:441) 
at java.lang.Long.parseLong(Long.java:483) 
at com.google.gson.JsonPrimitive.getAsLong(JsonPrimitive.java:233) 
at com.mpm.common.controller.DataUploadController$2.deserialize(DataUploadController.java:248) 
at com.mpm.common.controller.DataUploadController$2.deserialize(DataUploadController.java:1) 
at com.google.gson.TreeTypeAdapter.read(TreeTypeAdapter.java:58) 
at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$1.read(ReflectiveTypeAdapterFactory.java:93) 
at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$Adapter.read(ReflectiveTypeAdapterFactory.java:172) 
at com.google.gson.internal.bind.TypeAdapterRuntimeTypeWrapper.read(TypeAdapterRuntimeTypeWrapper.java:40) 
at com.google.gson.internal.bind.ArrayTypeAdapter.read(ArrayTypeAdapter.java:72) 
at com.google.gson.Gson.fromJson(Gson.java:791) 
at com.google.gson.Gson.fromJson(Gson.java:757) 
at com.google.gson.Gson.fromJson(Gson.java:706) 
at com.google.gson.Gson.fromJson(Gson.java:678) 
at com.mpm.common.controller.DataUploadController.getJsonString(DataUploadController.java:253) 
at com.mpm.common.controller.DataUploadController.saveGridData(DataUploadController.java:228) 
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.springframework.web.bind.annotation.support.HandlerMethodInvoker.invokeHandlerMethod(HandlerMethodInvoker.java:176) 
at org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.invokeHandlerMethod(AnnotationMethodHandlerAdapter.java:436) 
at org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.handle(AnnotationMethodHandlerAdapter.java:424) 
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:790) 
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:719) 
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:669) 
at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:585) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:641) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722) 
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:304) 
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:224) 
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175) 
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472) 
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:164) 
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100) 
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:929) 
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) 
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:405) 
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:279) 
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:515) 
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:302) 
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110) 
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603) 
at java.lang.Thread.run(Thread.java:722) 

내가 무엇입니까 날짜 구문 분석 오류가 사전에 나에게 감사를 도와주세요.

답변

2

오류는 매우 명확합니다. NumberFormatException: For input string: "04-22-2011"] 숫자가되어야하지만 실제로는 날짜 형식 인 값을 전달하고 있습니다.

내가 생각하는 곳은 json.getAsLong()이고 '12345654'와 같은 문자열이 있어야하지만 대신 날짜 문자열을 가져옵니다.

편집 : 일을 대신

:

new Date(json.getAsLong()) 

시도 : 맞습니다

new Date(json.getAsString()) 
+0

. 우리는 주어진 문자열을 Java의 Date Object로 변환하려고합니다. 그러나 언급 된 예외를 제공합니다. "04-22-2011"을 Java의 Date 객체로 변환 할 수 있도록 수행해야하는 작업. – Mayur

+0

편집 내 대답 – Tomer

+0

재생 해 주셔서 감사합니다. 이제 우리는이 덕분에 많은 사랑을 나누었습니다. :) – Mayur