Pass array data from javascript in browser to spring mvc controller using ajax

前端 未结 6 1128
独厮守ぢ
独厮守ぢ 2020-12-07 19:27

I would like to pass an array from javascript in web browser to a Spring MVC controller using AJAX

In javascript, I have

var a = [];
a[0] = 1;
a[1] =         


        
相关标签:
6条回答
  • 2020-12-07 19:43

    You can do this from the JavaScript side:

    $.ajax({
        type : "POST",
        url : "/myurl",
        data : {
            myArray: a //notice that "myArray" matches the value for @RequestParam
                       //on the Java side
        },
        success : function(response) {
           // do something ... 
        },
        error : function(e) {
           alert('Error: ' + e);
        }
    }); 
    

    Then on the Java side (in Spring 3), assuming that this method is mapped by /myurl:

    public String controllerMethod(@RequestParam(value="myArray[]") Integer[] myArray){
        ....
    }
    

    I believe the following will also work:

    public String controllerMethod(@RequestParam(value="myArray[]") List<Integer> myArray){
        ....
    }
    

    Spring is smart enough to figure out how to do the binding.

    For multiple arrays, you might want to just have a command object:

    public class MyData {
        private List<Integer> firstArray;
        private List<Integer> secondArray;
        private List<Integer> thirdArray;
    
        ...
        ...
    }
    

    Then on the JavaScript side:

    $.ajax({
        type : "POST",
        url : "/myurl",
        data : {            
            myData: {
               "firstArray": firstArray,
               "secondArray": secondArray,
               "thirdArray": thirdArray
            }            
        },
        success : function(response) {
           // do something ... 
        },
        error : function(e) {
           alert('Error: ' + e);
        }
    }); 
    

    On the Java side, you can bind using @ModelAttribute:

    public String controllerMethod(@ModelAttribute(value="myData") MyData myData) throws ParseException {
        ....
    }
    

    EDIT

    Changed the @RequestParam annotation to use myArray[] instead of just myArray, since this change appears to have been made in Spring after this answer was first posted.

    0 讨论(0)
  • 2020-12-07 19:48

    Fully tested solution

    $.ajax({
        type : "POST",
        url : "/myurl",
        data : {
            myArray: a //notice that "myArray" matches the value for @RequestParam
                       //on the Java side
        },
        success : function(response) {
           // do something ... 
        },
        error : function(e) {
           alert('Error: ' + e);
        }
    }); 
    
    @RequestMapping(value = "/save/", method = RequestMethod.POST)
        public String controllerMethod(@RequestParam(value="myArray[]") List<Integer> myArray){
            System.out.println("My Array"+myArray.get(0));
            return "";
        }
    
    0 讨论(0)
  • 2020-12-07 19:51

    Vivin Paliath doesn't work unless you use myArray[]

    public String controllerMethod(@RequestParam(value="myArray[]") Integer[] myArray){
        ...
    }
    
    0 讨论(0)
  • 2020-12-07 19:54

    If you are using spring mvc 4 then below will be the best approach

    Jquery code

    var dataArrayToSend = []; dataArrayToSend.push("a"); dataArrayToSend.push("b"); dataArrayToSend.push("c");

    // ajax code

    $.ajax({ contentType: "application/json", type: "POST", data: JSON.stringify(dataArrayToSend), url: "/appUrl", success: function(data) { console.log('done'); }, error: function(jqXHR, textStatus, errorThrown) { console.log('error while post'); }
    });

    Spring controller code

    @RequestMapping(value = "/appUrl", method = RequestMethod.POST) public @ResponseBody void yourMethod(@RequestBody String[] dataArrayToSend) { for (String data : dataArrayToSend) { System.out.println("Your Data =>" + data); } }

    check this helps you or not!

    Cheers!

    0 讨论(0)
  • 2020-12-07 20:05

    It is very simple passing such data to the Spring MVC controller, when you have in mind that data is being parsed from string. So if you want to get an array/list in the controller - pass a stringified version of the array:

    public String method(
            @RequestParam(value = "stringParam") String stringParam,
            @RequestParam(value = "arrayParam") List<String> arrayParam) {
        ...
    }
    

    and the corresponding javascript with jQuery would be like:

    $.post("/urlToControllerMethod",
        {
            "stringParam" : "test",
            "arrayParam" : [1, 2, 3, "test"].toString()
        }
    );
    

    Note: the parameter type

    List<String> arrayParam
    

    could be as well replaced with the array equivalent

    String[] arrayParam
    
    0 讨论(0)
  • 2020-12-07 20:09

    I end up doing this and it works

    In js,

    var a = [];
    a[0] = 1;
    a[1] = 2;
    a[2] = 3;
    
    
    $.ajax({
        type : "POST",
        url : "/myurl",
        data : "a="+a,  //multiple array, just add something like "&b="+b ...
        success : function(response) {
           // do something ... 
        },
        error : function(e) {
           alert('Error: ' + e);
        }
    }); 
    

    java side, get a class to receive data, using lombok

    @Setter @Getter public class MyData { private ArrayList a;
    }

    then in the controller

    @RequestMapping(value = "/repair_info", method = RequestMethod.POST)
    public ModelAndView myControl(MyData myData) {
        // get data with myData object
    }
    
    0 讨论(0)
提交回复
热议问题