2016-08-13 50 views
0

我是新的android和php的移动开发,所以请容易对我,如果我的问题是不相关的。谢谢。unsual-get请求结果没有更新后发布请求凌空

需求是开发一个功能来同步 - 通过点击按钮,从android设备的sqlite数据库上传数据到godaddy平台上的mysql服务器。

  • 我公司开发的2个独立的web服务:1的上传功能,1个用于下载功能托管GoDaddy的服务器
  • 我用凌空的请求的API
  • 我开发了一个synchelper类上传和下载功能,Android版。

问题 - 上传和下载功能,做工精细,当他们被单独的按钮,一前一后上点击调用。但是,当我将上传和下载功能集成到一个按钮时,上传功能可以正常工作,但下载功能不会下载包含刚刚上传的数据的mysql数据库的最新映像。

谁能一些线索呢?

这里是我的代码:

在syncHelper.java

String read_animal_url = "http://www.careagriculture.com/get_all_animals3.php"; 
    String insert_animals_url = "http://www.careagriculture.com/insert_animals25.php"; 
    public void DeviceDataUpload() { 

    StringRequest postRequest = new StringRequest(Method.POST, insert_animals_url, new Response.Listener<String>() { 

       @Override 
       public void onResponse(String response) { 
        try { 
         if (!(response == null)) { 

          JSONObject c = new JSONObject(response); 
          System.out.print(insert_animals_url + " response " + response.toString()); 
          int success = c.getInt("success"); 
          if (success == 1) { 
           localDBHelper.deleteAllAnimalFromDevice(); 

          } 
         } 
        }catch (JSONException e) { 
         e.printStackTrace(); 
        } 
       } 
      }, new Response.ErrorListener() { 
     @Override 
     public void onErrorResponse(VolleyError error) { 
     } 
    }){ 
     @Override 
     public Map<String, String> getParams(){ 
      Map<String, String> params = localDBHelper.getAllAnimalMap(); 
      return params; 
     } 

     @Override 
     public Priority getPriority() { 
      return Priority.HIGH; 
     } 
    }; 
    AppController.getInstance().addToReqQueue(postRequest); 
} 


    public void ServerDataDownload(){ 

    JsonObjectRequest readAnimalReq = new JsonObjectRequest(Method.GET, read_animal_url, new Response.Listener<JSONObject>() { 

       @Override 
       public void onResponse(JSONObject response) { 
        try { 
         System.out.print(read_animal_url+" response "+response.toString()); 
         int success = response.getInt("success"); 

         if (success == 1) { 
          JSONArray ja = response.getJSONArray("animal"); 

          localDBHelper.deleteAllAnimalFromServer(); 

          for (int i = 0; i < ja.length(); i++) { 

           map.put("ANIMAL_ID", c.getString(TAG_ANIMAL_ID)); 
           map.put("SUPERVISOR", c.getString(TAG_SUPERVISOR)); 
           map.put("ANIMAL_TYPE", c.getString(TAG_ANIMAL_TYPE)); 
           map.put("RECORD_TYPE", "S"); 
           if (!c.isNull(TAG_GENDER)) 
            map.put("GENDER", c.getString(TAG_GENDER)); 
           if (!c.isNull(TAG_DATE_OF_BIRTH)) 
            map.put("DATE_OF_BIRTH", c.getString(TAG_DATE_OF_BIRTH)); 
           if (!c.isNull(TAG_DATE_PURCHASED)) 
            map.put("DATE_PURCHASED", c.getString(TAG_DATE_PURCHASED)); 
           if (!c.isNull(TAG_PURCHASE_PRICE)) 
            map.put("PURCHASE_PRICE", c.getString(TAG_PURCHASE_PRICE)); 
           if (!c.isNull(TAG_DATE_DISTRIBUTED)) 
            map.put("DATE_DISTRIBUTED", c.getString(TAG_DATE_DISTRIBUTED)); 
           if (!c.isNull(TAG_DATE_SOLD)) 
            map.put("DATE_SOLD", c.getString(TAG_DATE_SOLD)); 
           if (!c.isNull(TAG_SALE_PRICE)) 
            map.put("SALE_PRICE", c.getString(TAG_SALE_PRICE)); 

           Item_List.add(map); 
           localDBHelper.insertAnimalFromServer(map); 

          } 
         } 

        } catch (JSONException e) { 
         e.printStackTrace(); 
        } 

       } 
      }, new Response.ErrorListener() { 

     @Override 
     public void onErrorResponse(VolleyError error) { 
     } 
    }){ 
     @Override 
     public Priority getPriority() { 
      return Priority.LOW; 
     } 
    }; 
    AppController.getInstance().addToReqQueue(readAnimalReq); 
} 

在MainActivity,我呼吁:

syncButton.setOnClickListener(new View.OnClickListener() { 
     @Override 
     public void onClick(View v) { 
      if (localDBHelper.getAllAnimalCount()>0) { 
       SyncHelper syncHelper = new SyncHelper(MainActivity.this); 
       syncHelper.DeviceDataUpload(); 
       Toast.makeText(getApplicationContext(),"Upload Completed", Toast.LENGTH_LONG).show(); 
      } 
      syncHelper.ServerDataDownload(); 
      Toast.makeText(getApplicationContext(),"Sync Completed", Toast.LENGTH_LONG).show(); 
     } 
    }); 

回答

1

new Response.Listener<JSONObject>()上传的声音时,喜欢它是异步的,所以会立即返回回到您的点击处理程序事件。

如果您想在之后触发下载上传已完成,您需要从上传的侦听器中的onResponse()方法调用它。

+1

谢谢谢谢谢谢你!这是令人难以置信的,它的工作。并且非常感谢你解释这种行为! – vyxf