발리 GSON 예외 예상 BEGIN_OBJECT가 시작되었지만 LINE 1 COLULT 11 LINE_ARRAY

StackOverflow https://stackoverflow.com//questions/20004059

  •  20-12-2019
  •  | 
  •  

문제

나는 JSON을 사용했습니다. Google Valley를 사용하고 있습니다 Android 앱에서
클라이언트 측 :

public void onResponse(JSONObject response) {
                        Log.i("asaf","jsone="+response.toString());
                        WorkerSeekerContiner wsc=new WorkerSeekerContiner();
                        Gson gsonConvertFrom = new Gson();

                        wsc=gsonConvertFrom.fromJson(response.toString(), WorkerSeekerContiner.class);
                        Log.i("asaf","list size="+wsc.getList().size());
.

서버 측 :

 Gson gsonConvertTo = new Gson();
         String jsonString = gsonConvertTo.toJson(send);
         JSONObject myJsonObj;
         try {
         myJsonObj = new JSONObject(jsonString);
         out.print( myJsonObj.toString()); 
.

JSONObject 응답의 toString : (올바른 데이터를 보류)

    {
"list":[
[251,"t1","t1","Nov 7, 2018",31.483521,34.596634,9000,"Nov 10, 
 2013","yardwork","a"]
,[252,"t1","t1","Nov 7, 
 2018",31.483521,34.696634,9000,"Nov 10, 2013","yardwork","a"]
]
}
.

그러나 gsonconvertfrom.fromjson을 시도 할 때 예외가 발생합니다 :

wsc= gsonconvertfrom.fromjson (response.tostring (), Workerseekercontiner.class);

       11-15 16:50:52.792: E/AndroidRuntime(17804): com.google.gson.JsonSyntaxException: java.lang.IllegalStateException:
 Expected BEGIN_OBJECT but was BEGIN_ARRAY at line 1 column 11
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$Adapter.read(ReflectiveTypeAdapterFactory.java:180)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at com.google.gson.internal.bind.TypeAdapterRuntimeTypeWrapper.read(TypeAdapterRuntimeTypeWrapper.java:40)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at com.google.gson.internal.bind.CollectionTypeAdapterFactory$Adapter.read(CollectionTypeAdapterFactory.java:81)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at com.google.gson.internal.bind.CollectionTypeAdapterFactory$Adapter.read(CollectionTypeAdapterFactory.java:60)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$1.read(ReflectiveTypeAdapterFactory.java:93)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$Adapter.read(ReflectiveTypeAdapterFactory.java:176)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at com.google.gson.Gson.fromJson(Gson.java:755)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at com.google.gson.Gson.fromJson(Gson.java:721)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at com.google.gson.Gson.fromJson(Gson.java:670)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at com.google.gson.Gson.fromJson(Gson.java:642)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at asaf.findwork.linkup$1.onResponse(linkup.java:131)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at asaf.findwork.linkup$1.onResponse(linkup.java:1)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at com.android.volley.toolbox.JsonRequest.deliverResponse(JsonRequest.java:65)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at com.android.volley.ExecutorDelivery$ResponseDeliveryRunnable.run(ExecutorDelivery.java:99)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at android.os.Handler.handleCallback(Handler.java:615)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at android.os.Handler.dispatchMessage(Handler.java:92)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at android.os.Looper.loop(Looper.java:153)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at android.app.ActivityThread.main(ActivityThread.java:5037)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at java.lang.reflect.Method.invokeNative(Native Method)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at java.lang.reflect.Method.invoke(Method.java:511)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:821)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:584)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at dalvik.system.NativeStart.main(Native Method)
    11-15 16:50:52.792: E/AndroidRuntime(17804): Caused by: java.lang.IllegalStateException: Expected BEGIN_OBJECT but was BEGIN_ARRAY at line 1 column 11
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at com.google.gson.stream.JsonReader.expect(JsonReader.java:339)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at com.google.gson.stream.JsonReader.beginObject(JsonReader.java:322)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$Adapter.read(ReflectiveTypeAdapterFactory.java:168)
    11-15 16:50:52.792: E/AndroidRuntime(17804):    ... 22 more
.

및 마지막 내 객체 만 객체 목록을 누르고 있습니다.

public class WorkerSeekerContiner {
    List<WorkerSeeker> list;
.

WorkerSeeker 클래스 :

@Entity
public class WorkerSeeker implements Serializable {
    private static final long serialVersionUID = 1L;
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Long id;
    @Temporal(javax.persistence.TemporalType.DATE)
    private Calendar startdate;
    @Temporal(javax.persistence.TemporalType.DATE)
    private Calendar enddate;
    private Double offerprice;
    private Double  latitude;
    private Double longitude;
    private String address;
    private String userName;
    private String type;
    private String description;
.

하나님 댐 : ((


이 문제는 createNatialQuery WICH를 사용하여 (목록) Q3.getResultList ()를 사용하여 사용했습니다.나에게 객체 목록을 주었고 Workerseeker 목록이 아닙니다. errrrrrrrrrrrrrrrrrrrrrrr.


이 문제를 해결하는 사람이있는 경우 수정 사항은 정말로 쉽습니다


CreateNativeQuery (SQLQUY, URCLASS.CLASS );arrayof urclass가 아닌 arrayof retit of return

도움이 되었습니까?

해결책

createNativeQuery는 query.getResultList ()에있는 객체 목록을 반환합니다.Opperseeker 목록이 아닙니다

라이센스 : CC-BY-SA ~와 함께 속성
제휴하지 않습니다 StackOverflow
scroll top