web-dev-qa-db-ja.com

jsonを受信し、spring mvcコントローラーでオブジェクトのリストとしてデシリアライズします

私のコードは次のとおりです:

コントローラー

@RequestMapping(value="/setTest", method=RequestMethod.POST, consumes="application/json")
public @ResponseBody ModelMap setTest(@RequestBody List<TestS> refunds, ModelMap map) {
    for(TestS r : refunds) {
        System.out.println(r.getName());
    }
    // other codes
}

TestS pojo

public class TestS implements Serializable {
    private String name;
    private String age;
    //getter setter
}

Jsonリクエスト

var z = '[{"name":"1","age":"2"},{"name":"1","age":"3"}]';
$.ajax({
    url: "/setTest",
    data: z,
    type: "POST",
    dataType:"json",
    contentType:'application/json'               
});

このエラーが発生しています

Java.lang.ClassCastException:Java.util.LinkedHashMapをcom.gogoair.cidb.entities.TestSにキャストできません

私はspring 3.1.2jackson 2.0.4を使用しています

編集:コントローラーメソッドでTestSオブジェクトのリストを受け取り、処理したい。間違ったJSONを送信しているのか、メソッドの署名が間違っているのかを見つけることができません。

32
HKumar

ここに私のために働くコードがあります。重要なのは、ラッパークラスが必要なことです。

public class Person {

    private String name;
    private Integer age;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    @Override
    public String toString() {
        return "Person [name=" + name + ", age=" + age + "]";
    }

PersonWrapperクラス

public class PersonWrapper {

    private List<Person> persons;

    /**
     * @return the persons
     */
    public List<Person> getPersons() {
        return persons;
    }

    /**
     * @param persons the persons to set
     */
    public void setPersons(List<Person> persons) {
        this.persons = persons;
    }
}

私のコントローラーメソッド

@RequestMapping(value="person", method=RequestMethod.POST,consumes="application/json",produces="application/json")
    @ResponseBody
    public List<String> savePerson(@RequestBody PersonWrapper wrapper) {
        List<String> response = new ArrayList<String>();
        for (Person person: wrapper.getPersons()){
        personService.save(person);
         response.add("Saved person: " + person.toString());
    }
        return response;
    }

送信されたリクエストはPOSTのjsonです

{"persons":[{"name":"shail1","age":"2"},{"name":"shail2","age":"3"}]}

そして応答は

["Saved person: Person [name=shail1, age=2]","Saved person: Person [name=shail2, age=3]"]
43
Shailendra

これはあなたがやっている方法では不可能です。ジャクソンのアンマーシャリングは、コンパイルされたJava code after type erasure)で機能します。

public @ResponseBody ModelMap setTest(@RequestBody List<TestS> refunds, ModelMap map) 

本当にただ

public @ResponseBody ModelMap setTest(@RequestBody List refunds, ModelMap map) 

(リスト引数にジェネリックはありません)。

Listの非整列化がLinkedHashMapである場合、Jacksonが作成するデフォルトのタイプ。

@Saintで述べたように、次のようにリストに独自のタイプを作成することでこれを回避できます。

class TestSList extends ArrayList<TestS> { }

コントローラーの署名を次のように変更します

public @ResponseBody ModelMap setTest(@RequestBody TestSList refunds, ModelMap map) {
12
Dirk Lachowski
@RequestMapping(
         value="person", 
         method=RequestMethod.POST,
         consumes="application/json",
         produces="application/json")
@ResponseBody
public List<String> savePerson(@RequestBody Person[] personArray) {
    List<String> response = new ArrayList<String>();
    for (Person person: personArray) {
        personService.save(person);
        response.add("Saved person: " + person.toString());
    }
    return response;
}

上記のように配列を使用できます。

8
Deepak

ソリューションは非常にうまく機能しますが、

public List<String> savePerson(@RequestBody Person[] personArray)  

この署名では、郵便配達人からPerson配列を渡すことができます。

[
{
  "empId": "10001",
  "tier": "Single",
  "someting": 6,
  "anything": 0,
  "frequency": "Quaterly"
}, {
  "empId": "10001",
  "tier": "Single",
  "someting": 6,
  "anything": 0,
  "frequency": "Quaterly"
}
]

consumesタグを追加することを忘れないでください:

@RequestMapping(value = "/getEmployeeList", method = RequestMethod.POST, consumes="application/json", produces = "application/json")
public List<Employee> getEmployeeDataList(@RequestBody Employee[] employeearray) { ... }
0
AmitG

私の下のコードはうまくいきました、最初に適切なヘッダーを持つjson文字列を送信します

$.ajax({
        type: "POST",
        url : 'save',
        data : JSON.stringify(valObject),
        contentType:"application/json; charset=utf-8",
        dataType:"json",
        success : function(resp){
            console.log(resp);
        },
        error : function(resp){
            console.log(resp);
        }
    });

そして、春の側で-

@RequestMapping(value = "/save", 
                method = RequestMethod.POST,
                consumes="application/json")
public @ResponseBody String  save(@RequestBody ArrayList<KeyValue> keyValList) {
    //Saving call goes here
    return "";
}

ここで、KeyValueはJSON構造に対応する単純なpojoであり、必要に応じてプロデュースを追加することもできます。単に文字列を返しています。

私のjsonオブジェクトはこのようなものです-

[{"storedKey":"vc","storedValue":"1","clientId":"1","locationId":"1"},
 {"storedKey":"vr","storedValue":"","clientId":"1","locationId":"1"}]
0
Pratik Goenka