0

私は LoopJ AndroidAsyncHttp Library を使い始めたばかりで、データのアップロードに優れています。

しかし、現在、get リクエストを使用して応答を取得しようとしていますが、onSuccess メソッドも onFailure メソッドも呼び出されていない理由を理解できないようです。ここで質問を調べましたが、onSuccess メソッドの新しい実装に対処するものを見つけることができないようです。誰か助けてくれませんか?

ButtonClick で呼び出されるメソッド:

public void displayUploaded(View view){

    RequestParams params=new RequestParams();


    try{


        AsyncHttpClient client = new AsyncHttpClient();

        client.get("http://192.168.1.4/clientservertest/returnUploadedImages.php",
                    new JsonHttpResponseHandler() {

                    @Override
                    public void onSuccess(JSONObject jsonObject) {
                    // Display a "Toast" message

                    Toast.makeText(getApplicationContext(), "Success!", Toast.LENGTH_LONG).show();


                    Log.d("android", jsonObject.toString());
                    }

                    @Override
                    public void onFailure(int statusCode, Throwable throwable, JSONObject error) {
                    // Display a "Toast" message

                    Toast.makeText(getApplicationContext(), "Error: " + statusCode + " " + throwable.getMessage(), Toast.LENGTH_LONG).show();

                    // Log error message
                    // to help solve any problems
                     Log.e("android", statusCode + " " + throwable.getMessage());
                     }
                     });




    }
    catch(Exception e){
        Toast toast2=Toast.makeText(getApplicationContext(),"Failed first TRY",Toast.LENGTH_LONG);
        toast2.show();
        e.printStackTrace();
    }


}

これは私のphpコードです(chromeでPostman Clientを使用しても問題なく動作します。出力をEDIT2に投稿しました):

<?php 

        #Connect to Database 
        $con = mysqli_connect("localhost","root","", "mytestdatabase"); 

        #Check connection 
        if (mysqli_connect_errno()) { 
            echo 'Database connection error: ' . mysqli_connect_error(); 
            exit(); 
        } 


        #Query the database to get the user details. 
        $userdetails = mysqli_query($con, "SELECT * FROM images"); 

        #If no data was returned, check for any SQL errors 
        if (!$userdetails) { 
            echo 'Could not run query: ' . mysqli_error($con); 
            exit; 
        } 

        #Return the results
        $rows = array();
        while($r = mysqli_fetch_assoc($userdetails)) {
            $rows[] = $r;
        } 


        print(json_encode($rows));  

?>

他の ResponseHandlers を使用して同じことも試しましたが、どちらも機能しません。本当に答えを期待しています!

編集:同じアクティビティで有効で完全に機能するコードを追加します。これは投稿リクエストです:

File selectedPicture=new File(picturePath);

        RequestParams params=new RequestParams();

        try{

           params.put("UploadedPic",selectedPicture);
           AsyncHttpClient client = new AsyncHttpClient();
           client.post("http://192.168.1.4/clientservertest/imageupload.php", params,new AsyncHttpResponseHandler());

        }

EDIT2: PHP ページから POSTMAN クライアントに返される応答:

[{"id":"7","path":"uploads/speed.png"},{"id":"8","path":"uploads/Untitled.png"},{"id": "9","パス":"uploads/Untitled.png"},{"id":"10","パス":"uploadsspeed_2.png"},{"id":"11","パス": "uploads/speed_3.png"}]

4

1 に答える 1

2

サーバーが JSON 配列を返しているように見えるので、JsonHttpResponseHandler で onSuccess(JSONArray array) メソッドをオーバーライドしてみてください。

client.get("http://192.168.1.4/clientservertest/returnUploadedImages.php",
    new JsonHttpResponseHandler() {
        @Override
        public void onSuccess(JSONArray jsonArray) {
            Toast.makeText(getApplicationContext(), "Success!", Toast.LENGTH_LONG).show();
            Log.d("android", jsonArray.toString());
        }
        //etc...
    });
于 2014-05-03T14:15:34.033 に答える