我正在使用AsyncTask进行网络通话。如果成功,它应该返回一个JSON数组,到目前为止它在我测试的设备上运行良好(Google nexus 5)。 但在摩托罗拉设备上,它不起作用。从某种意义上说,它甚至没有向服务器发送请求。
以下是代码:
private class SimpleTask extends AsyncTask<String, Void, String> {
ProgressDialog dialog;
@Override
protected void onPreExecute()
{
dialog = new ProgressDialog(MainActivity.this,ProgressDialog.STYLE_SPINNER);
dialog.setMessage("Loading Engine");
dialog.show();
}
protected String doInBackground(String... urls) {
String result = "";
try {
//HttpGet httpGet = new HttpGet(urls[0]);
HttpPost httpPost = new HttpPost(urls[0]);
HttpClient client = new DefaultHttpClient();
List<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>(1);
nameValuePairs.add(new BasicNameValuePair("number",details));
httpPost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
HttpResponse response = client.execute(httpPost);
int statusCode = response.getStatusLine().getStatusCode();
if (statusCode == 200) {
InputStream inputStream = response.getEntity().getContent();
BufferedReader reader = new BufferedReader
(new InputStreamReader(inputStream));
String line;
while ((line = reader.readLine()) != null) {
result += line;
}
}
} catch (ClientProtocolException e) {
} catch (IOException e) {
}
//Log.w("PREMIERE::::",result);
return result;
}
protected void onPostExecute(String jsonString) {
//dialog.dismiss();
try {
if ((this.dialog != null) && this.dialog.isShowing()) {
this.dialog.dismiss();
}
} catch (final IllegalArgumentException e) {
// Handle or log or ignore
} catch (final Exception e) {
// Handle or log or ignore
} finally {
this.dialog = null;
}
showData(jsonString);
}
}
private void showData(String jsonString)
{
// try
// {
Log.w("VALS:",""+jsonString);
Gson gson = new Gson();
JsonParser parser = new JsonParser();
JsonArray jArray = parser.parse(jsonString).getAsJsonArray();
SharedPreferences pref = getSharedPreferences("ActivitySession", Context.MODE_PRIVATE);
for(JsonElement obj : jArray )
{
MainPojo cse = gson.fromJson( obj , MainPojo.class);
uid.add(cse);
}
if(!uid.isEmpty())
{
new SimpleTask2().execute(URL2);
}
else
{
Snackbar.make(this.findViewById(android.R.id.content), "Invalid Credentials", Snackbar.LENGTH_LONG).show();
}
/*
}
catch (Exception e){
Snackbar.make(this.findViewById(android.R.id.content), "Check data connection", Snackbar.LENGTH_LONG).show();
e.printStackTrace();
}*/
}
我有目的地,没有捕获异常,并通过Crashlytics追踪该错误。该行发生了这个错误。
JsonArray jArray = parser.parse(jsonString).getAsJsonArray();
说:
致命异常:java.lang.IllegalStateException:这不是JSON 阵列。
我认为当响应为空时也会发生这种情况,并且因为我无法在服务器中跟踪请求,我相信这是因为没有请求被发送。(如果错误则纠正我)。
所以,我的问题是:我错过了什么或者我定义AsyncTask的方式有什么问题吗?
编辑1
PS:我在这个AsyncTask中使用了一个HTTPS URL
答案 0 :(得分:1)
在Crashalitics中,您可以记录调试消息并从捕获的异常中堆栈跟踪。所以答案就是正确收集这些信息,然后问题就会清楚
// catch everythin n log everything
} catch (ClientProtocolException e) {
Crashlytics.logException(e);
} catch (IOException e) {
Crashlytics.logException(e);
}
还会在可能的崩溃之前放置日志消息
Crashlytics.log("Here is the async task that keeps giving me headache");