0

配列構造の要素を入力するjavascript配列があります:

 var citizens1 = [{"startLat":null,"startLng":null,"socialSecurityNumber":null}];

配列はデータを取得しますが、処理のためにこのデータをサーバーにプッシュする必要があります。配列は500 レコードを保持します。サーバーに 500 のWeb サービス要求を行う代わりに、配列データをJSON文字列に変換し、すべてのデータをサーバーに渡します。サーバーでは、すべてのレコードを一度に処理して、1 つのajax 呼び出しを行います。

データをサーバーに正しく渡しているかどうかわかりません。エラーが発生しています。以下は私のコードです:

Javascript

 citizens1.push({startLat:marker[index].getPosition().lat(),startLng:marker[index].getPosition().lng(),socialSecurityNumber:global_citizens[index].socialSecurityNumber});

 if(citizens1.length == 500){            
     console.log('500 records saved');          
     window.clearTimeout( timerHandle);

     for(var i = 0; i < citizens1.length ; i++){
        var myJsonString = JSON.stringify(citizens1);
        //console.log(myJsonString);

         //console.log(citizens1[i].lat +',' +citizens1[i].lng+','+citizens1[i].socialSecurityNumber); 
        $.ajax({
                type:'POST',
                url:'logMovement.htm',
                contentType: "application/json; charset=utf-8",
                async: false,
                cache: false, 
                data:myJsonString,
                dataType: 'json',
                success:function(data){

                    if (data == false){
                        console.log('error occured in logging data');
                    }

                }

            });          

     }

     citizens1 = [];
 }

コントローラ

 @RequestMapping(value="logMovement.htm", method={RequestMethod.POST},produces = "application/json; charset=utf-8")
     public @ResponseBody Movement logMovement(@RequestBody Movement movement)throws Exception{

         logger.info("About to log movement");

         JSONObject jsonObj = JSONObject.fromObject(movement);
         ObjectMapper mapper = new ObjectMapper();

         List<Movement> move = mapper.readValue(jsonObj.toString(), new TypeReference<Movement>(){});

        logger.info(move);
        return null;

         /*if((!lat.equals(null)) || (!(lat == null)) || (!(lat.length() == 0))){
             double dLat = Double.parseDouble(lat);
             double dLng = Double.parseDouble(lng);
             int iSocialSecurityNumber = Integer.parseInt(socialSecurityNumber);

             this.markerManager.logMovement(dLat, dLng, iSocialSecurityNumber);

         }*/


     }

移動クラス

public class Movement implements Serializable{

    private List<Integer>socialSecurityNumber;
    private List<Double> startLat;
    private List<Double> startLng;
    /**
     * @param socialSecurityNumber
     * @param startLat
     * @param startLng
     */

    public Movement(){}

    public Movement(List<Integer> socialSecurityNumber, List<Double> startLat,
            List<Double> startLng) {
        super();
        this.socialSecurityNumber = socialSecurityNumber;
        this.startLat = startLat;
        this.startLng = startLng;
    }
//getters and setters

サーバーに投稿された Json データのサンプル

最初の行が 'null' になっていますが、これが問題の原因かどうかはわかりません

[{"startLat":null,"startLng":null,"socialSecurityNumber":null},{"startLat":10.537749449700717,"startLng":-61.44420048947677,"socialSecurityNumber":198501012},{"startLat":10.537208514171011," startLng":-61.443589321013235,"socialSecurityNumber":198501012},{"startLat":10.536667622323245,"startLng":-61.44297811322531,"socialSecurityNumber":198501012},{"startLat":10.536131483465244,"startLng":-61.442362603115384,"socialSecurityNumber ":198501012},{"startLat":10.53566878133931,"startLng":-61.44168979108997,"socialSecurityNumber":198501012},{"startLat":10.535227295591238,"startLng":-61.441000943386825,"socialSecurityNumber":198501012},{"startLat":10.170058041417015,"startLng":-61.67893982108137,"socialSecurityNumber":194302025}

エラー

問題を扱ったこのSOの質問を見ていましたRequired JSON parameter is not present in jQuery Datatables

org.springframework.http.converter.HttpMessageNotReadableException: Could not read JSON: Can not deserialize instance of com.crimetrack.business.Movement out of START_ARRAY token

org.springframework.http.converter.HttpMessageNotReadableException: Could not read JSON: Can not deserialize instance of com.crimetrack.business.Movement out of START_ARRAY token
 at [Source: org.apache.catalina.connector.CoyoteInputStream@72f1db9d; line: 1, column: 1]; nested exception is org.codehaus.jackson.map.JsonMappingException: Can not deserialize instance of com.crimetrack.business.Movement out of START_ARRAY token
 at [Source: org.apache.catalina.connector.CoyoteInputStream@72f1db9d; line: 1, column: 1]
    at org.springframework.http.converter.json.MappingJacksonHttpMessageConverter.readInternal(MappingJacksonHttpMessageConverter.java:127)
    at org.springframework.http.converter.AbstractHttpMessageConverter.read(AbstractHttpMessageConverter.java:153)
    at org.springframework.web.servlet.mvc.method.annotation.AbstractMessageConverterMethodArgumentResolver.readWithMessageConverters(AbstractMessageConverterMethodArgumentResolver.java:120)
    at org.springframework.web.servlet.mvc.method.annotation.AbstractMessageConverterMethodArgumentResolver.readWithMessageConverters(AbstractMessageConverterMethodArgumentResolver.java:91)
    at org.springframework.web.servlet.mvc.method.annotation.RequestResponseBodyMethodProcessor.resolveArgument(RequestResponseBodyMethodProcessor.java:71)
    at org.springframework.web.method.support.HandlerMethodArgumentResolverComposite.resolveArgument(HandlerMethodArgumentResolverComposite.java:75)
    at org.springframework.web.method.support.InvocableHandlerMethod.getMethodArgumentValues(InvocableHandlerMethod.java:156)
    at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:117)
    at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:96)
    at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:617)
    at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:578)
    at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:80)
    at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:923)
    at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:852)
    at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:882)
    at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:789)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:647)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:99)
    at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:953)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:408)
    at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1008)
    at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:589)
    at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:310)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
    at java.lang.Thread.run(Unknown Source)
Caused by: org.codehaus.jackson.map.JsonMappingException: Can not deserialize instance of com.crimetrack.business.Movement out of START_ARRAY token
 at [Source: org.apache.catalina.connector.CoyoteInputStream@72f1db9d; line: 1, column: 1]
    at org.codehaus.jackson.map.JsonMappingException.from(JsonMappingException.java:159)
    at org.codehaus.jackson.map.deser.StdDeserializationContext.mappingException(StdDeserializationContext.java:131)
    at org.codehaus.jackson.map.deser.BeanDeserializer.deserializeUsingCreator(BeanDeserializer.java:397)
    at org.codehaus.jackson.map.deser.BeanDeserializer.deserialize(BeanDeserializer.java:296)
    at org.codehaus.jackson.map.ObjectMapper._readMapAndClose(ObjectMapper.java:1282)
    at org.codehaus.jackson.map.ObjectMapper.readValue(ObjectMapper.java:941)
    at org.springframework.http.converter.json.MappingJacksonHttpMessageConverter.readInternal(MappingJacksonHttpMessageConverter.java:124)
    ... 33 more
4

3 に答える 3

2

JSON が無効です。コロンの左側の値は文字列である必要があります。

[
    {
        "lat": null,
        "lng": null,
        "socialSecurityNumber": null
    }
]

また、間違った注釈を使用しているように見え@RequestBodyます.JSONの内容を解析するために@RequestParam使用されています.

?var=1&newvar=2

また、あなたのJavaScriptではchange data:{'myData':myJsonString }data:myJsonString,

移入するダムオブジェクトを作成する必要があります。ページの下部にあるこのチュートリアルをチェックして、ダムの Person オブジェクトに移入します

于 2013-10-14T14:51:32.627 に答える
0

このようにコントローラーに応答を書き込むことができます

これが「役立つことを願っています

    //get "hie" string from the service class, String is in JSON format
    String hie = svc.getHierarchysvc();

    response.setContentType("application/json");

    PrintWriter out = response.getWriter();
    out.write(hie);
于 2013-10-15T03:45:24.103 に答える
0

ムーブメントクラスとコントローラーにいくつかの調整を加えたところ、解決策が得られました。以下は、このエラーの解決に興味がある人のためのコードです。

動き.java

デフォルトのコンストラクタを持つことは非常に重要です。これが存在しない場合、json はapplication/json に関連するエラーをスローします。charset=utf-8サポートされていません http 415 サポートされていないメディア。

public class Movement implements Serializable{

    private int socialSecurityNumber;
    private double startLat;
    private double startLng;
    /**
     * @param socialSecurityNumber
     * @param startLat
     * @param startLng
     */

    public Movement(){}
    /**
     * @param socialSecurityNumber
     * @param startLat
     * @param startLng
     */
    public Movement(int socialSecurityNumber, double startLat, double startLng) {
        super();
        this.socialSecurityNumber = socialSecurityNumber;
        this.startLat = startLat;
        this.startLng = startLng;
    }
//getters and setters

コントローラ

これはデータの配列であるため、 List@RequestBodyを使用するように定義することが重要です。リストを保持するには、 JSONArrayを宣言することも重要です。それが完了すると、そのタイプに基づいてデータを「取得」できます。下はコードです。

@RequestMapping(value="logMovement.htm", method = {RequestMethod.POST},consumes = "application/json")
     public @ResponseBody Movement logMovement(@RequestBody List<Movement> movement)throws Exception{

         logger.info("About to log movement");

         JSONArray nameArray =(JSONArray) JSONSerializer.toJSON(movement);

         System.out.println(nameArray.size());

          for(Object js : nameArray){
              JSONObject json = (JSONObject)js;
              //System.out.println(json.get("socialSecurityNumber"));
              if((!json.get("startLat").equals(null))){     

                     this.markerManager.logMovement(json.getDouble("startLat"),json.getDouble("startLng"), json.getInt("socialSecurityNumber"));

                }
          }


        return null;    

     }   
于 2013-10-15T14:59:09.673 に答える