簡體   English   中英

Android Volley POST服務器錯誤

[英]Android Volley POST ServerError

我正在嘗試通過我的android應用在寵物項目的端點上進行POST調用。

我正在使用volley庫,並且遇到以下錯誤: com.android.volley.ServerErrormessageNULL (我很難找出我在做什么錯)

我確保清單中已提供Internet連接選項: <uses-permission android:name="android.permission.INTERNET" />

我的端點也可以通過curl訪問以進行測試:

curl -X POST -H "Content-Type: application/json" -H "Cache-Control: no-cache" -H "Postman-Token: 122eedf5-8ca5-c1a6-06d9-5cc1986d2b23" -d '{
    "departure_time" : "2016-07-21 07:00:00",
    "arrival_time" : "2016-07-21 08:30:00",
    "location_flow": ["Milpitas+ca", "SanCarlos+Ca"],
    "buffer_time": [0, 30, 0],
    "mode": "driving"
}' "https://sudtrafficalarm.herokuapp.com/v1/wakecheck"

輸出:

{
  "estimated_arrival_time": "2016-07-21 08:05:01",
  "journey_duration": 2101,
  "wake_status": false
}

這是我的主要活動:

package com.sudhishkr.sudtrafficalarmandroid;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;

import com.android.volley.AuthFailureError;
import com.android.volley.Request;
import com.android.volley.RequestQueue;
import com.android.volley.Response;
import com.android.volley.VolleyError;
import com.android.volley.toolbox.JsonObjectRequest;
import com.android.volley.toolbox.StringRequest;
import com.android.volley.toolbox.Volley;

import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import java.util.HashMap;
import java.util.Map;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        final RequestQueue queue = Volley.newRequestQueue(this);
        Button button = (Button) findViewById(R.id.button);

        button.setOnClickListener(new View.OnClickListener() {
            public void onClick(View v) {
                //Toast.makeText(MainActivity.this, SystemTime.date2String(SystemTime.getCurrentTime()), Toast.LENGTH_SHORT).show();
                final String REGISTER_URL = "https://sudtrafficalarm.herokuapp.com/v1/wakecheck";
                JsonObjectRequest jsonRequest = new JsonObjectRequest(Request.Method.POST, REGISTER_URL, getJsonData(),
                        new Response.Listener<JSONObject>() {
                            @Override
                            public void onResponse(JSONObject response) {
                                Toast.makeText(MainActivity.this, response.toString(), Toast.LENGTH_SHORT).show();
                            }
                        },
                        new Response.ErrorListener() {
                            @Override
                            public void onErrorResponse(VolleyError error) {
                                Toast.makeText(MainActivity.this, error.toString(), Toast.LENGTH_SHORT).show();
                            }
                        }
                );
                queue.add(jsonRequest);


            }
        });
    }

    public JSONObject getJsonData() {
        JSONObject params = new JSONObject();
        try {
            params.put("departure_time", "2016-07-21 07:00:00");
            params.put("arrival_time", "2016-07-21 08:30:00");
            params.put("mode", "driving");
            JSONArray address = new JSONArray();
            address.put("Milpitas+ca");
            address.put("SanCarlos+Ca");
            params.put("location_flow", address);
        } catch (JSONException e) {
            e.printStackTrace();
        }
        return params;
    }


}

調試代碼-帶我到這里。 而且我沒有任何消息或信息說明為什么會發生這種情況。

在此處輸入圖片說明

您尚未在Android代碼中添加“ buffer_time”參數。 查看curl請求,POST數據與您從Android代碼提交的數據不同。 您的getJsonData()應該如下所示(我創建了一個演示項目並進行了更改,可以看到預期的響應):

public JSONObject getJsonData() {
    JSONObject params = new JSONObject();
    try {
        params.put("departure_time", "2016-07-21 07:00:00");
        params.put("arrival_time", "2016-07-21 08:30:00");
        params.put("mode", "driving");
        JSONArray address = new JSONArray();
        address.put("Milpitas+ca");
        address.put("SanCarlos+Ca");
        params.put("location_flow", address);

        JSONArray buffer_time = new JSONArray();
        buffer_time.put(0);
        buffer_time.put(30);
        buffer_time.put(0);
        params.put("buffer_time", buffer_time);
    } catch (JSONException e) {
        e.printStackTrace();
    }
    return params;
}

我猜是因為您正在嘗試在后台線程中打印吐司,而該線程可能在主線程中被調用。 可能的原因可能是api的回調方法將在后台線程中被調用,因為網絡操作始終在后台線程中發生。

使用此更新的代碼

button.setOnClickListener(new View.OnClickListener() {
        public void onClick(View v) {
            //Toast.makeText(MainActivity.this, SystemTime.date2String(SystemTime.getCurrentTime()), Toast.LENGTH_SHORT).show();
            final String REGISTER_URL = "https://sudtrafficalarm.herokuapp.com/v1/wakecheck";
            JsonObjectRequest jsonRequest = new JsonObjectRequest(Request.Method.POST, REGISTER_URL, getJsonData(),
                    new Response.Listener<JSONObject>() {
                        @Override
                        public void onResponse(JSONObject response) {
                            runOnUiThread(new Runnable() {
                                @Override
                                public void run() {
                                    Toast.makeText(MainActivity.this, response.toString(), Toast.LENGTH_SHORT).show();        
                                }
                            });

                        }
                    },
                    new Response.ErrorListener() {
                        @Override
                        public void onErrorResponse(VolleyError error) {
                            runOnUiThread(new Runnable() {
                                @Override
                                public void run() {
                                    Toast.makeText(MainActivity.this, error.toString(), Toast.LENGTH_SHORT).show();        
                                }
                            });

                        }
                    }
            );
            queue.add(jsonRequest);


        }
    });

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM