这是我的代码: -
Goals.java类
public class Goals extends AppCompatActivity{
private ArrayList<Goal> result;
private RecyclerView.Adapter adapter;
private RecyclerView recyclerView;
private RecyclerView.LayoutManager layoutManager;
private ArrayList<Goal> dataFromServer;
private Toolbar toolbar;
//This is for back button
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case android.R.id.home:
startActivity(new Intent(this, MainActivity.class));
finish();
return true;
}
return super.onOptionsItemSelected(item);
}
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.goal_list);
recyclerView=(RecyclerView) findViewById(R.id.goal_recycler_view);
toolbar=(Toolbar) findViewById(R.id.toolbar);
recyclerView.setHasFixedSize(true);
layoutManager=new LinearLayoutManager(this);
recyclerView.setLayoutManager(layoutManager);
setSupportActionBar(toolbar);
//FOr back button
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
getSupportActionBar().setDisplayShowHomeEnabled(true);
getSupportActionBar().setDisplayShowTitleEnabled(false);
//fetch goal list from server and also its related action
getData();
//Send Data to GoalAdaptor
showData();
}
private void showData() {
Log.i("Show Date","Enter");
System.out.println("Result Array List"+result.toString());
adapter=new goalAdaptor(this, result);
recyclerView.setAdapter(adapter);
}
private void getData() {
result=new ArrayList<>();
DownloadPlansFromServer server= new DownloadPlansFromServer();
server.execute();
}
class DownloadPlansFromServer extends AsyncTask<Void,Void,Boolean>
{
private ProgressDialog progressDialog;
Boolean planActive=false;
protected void onPreExecute() {
// NOTE: You can call UI Element here.
//UI Element
progressDialog = new ProgressDialog(Goals.this);
progressDialog.setMessage("Downloading Plans Data..");
progressDialog.show();
}
@Override
protected Boolean doInBackground(Void... params) {
try {
Response.Listener listener=new Response.Listener<JSONObject>()
{
@Override
public void onResponse(JSONObject response) {
try {
System.out.println("Inside the response");
// Parsing json object response
// response will be a json object
System.out.println("Output is "+response.toString());
//Toast.makeText(getApplicationContext(),response.toString(),Toast.LENGTH_LONG).show();
planActive=response.getBoolean("success");
if (planActive)
{
JSONArray plansArray=response.getJSONArray("response");
//get Plans Details
for (int p=0;p<plansArray.length();p++)
{
JSONObject plan=plansArray.getJSONObject(p);
//get Goals Details
JSONObject planGoals=plan.getJSONObject("goal");
Goal goal=new Goal();
goal.setGoal_name("Goal Name:- "+planGoals.getString("goal_name"));
Log.i("Goal Name is",planGoals.getString("goal_name"));
JSONObject currentValue=planGoals.getJSONObject("current_value");
JSONObject targetValue=planGoals.getJSONObject("target_value");
//Get the values parameter
ArrayList<String> parameterList=getTheParameter(planGoals.getString("goal_id"));
if (parameterList.isEmpty())
{
System.out.println("Problem WHile Processing the parameter ");
}
else
{
String goalDescription="Reduce the value from";
StringBuilder currentStringBuilder=new StringBuilder();
for (int k=0;k<parameterList.size();k++)
{
currentStringBuilder.append(currentValue.getString(parameterList.get(k))+"/");
}
StringBuilder targetStringBuilder=new StringBuilder();
for (int k=0;k<parameterList.size();k++)
{
targetStringBuilder.append(targetValue.getString(parameterList.get(k))+"/");
}
goal.setGoal_description(goalDescription+currentStringBuilder.toString()+" to "+ targetStringBuilder.toString());
}
//Add the result to the array
result.add(goal);
}
}
}
catch (JSONException k)
{
Log.i("On Response",k.getMessage());
k.printStackTrace();
}
}
};
Response.ErrorListener errorListener=new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
// Handle Error
if (error instanceof TimeoutError || error instanceof NoConnectionError) {
error.printStackTrace();
Toast.makeText(getApplicationContext(), " this Network Error", Toast.LENGTH_SHORT).show();
} else if (error instanceof AuthFailureError) {
//TODO
error.printStackTrace();
Toast.makeText(getApplicationContext(), "User not authorized", Toast.LENGTH_SHORT).show();
} else if (error instanceof ServerError) {
//TODO
error.printStackTrace();
Toast.makeText(getApplicationContext(), "Server error", Toast.LENGTH_SHORT).show();
} else if (error instanceof NetworkError) {
//TODO
error.printStackTrace();
Toast.makeText(getApplicationContext(), "Network Error", Toast.LENGTH_SHORT).show();
} else if (error instanceof ParseError) {
//TODO
error.printStackTrace();
Toast.makeText(getApplicationContext(), "Error consuming request", Toast.LENGTH_SHORT).show();
}
else error.printStackTrace();
}
};
String plan_url=Constants.url+"plan";
JsonObjectHeader customRequest=new JsonObjectHeader(plan_url,null, listener, errorListener);
RequestQueue requestQueue = Volley.newRequestQueue(getApplicationContext());
requestQueue.add(customRequest);
System.out.println("After custom Request");
planActive=true;
}catch (Exception e)
{
e.printStackTrace();
}
return planActive;
}
protected void onPostExecute(Boolean unused) {
// NOTE: You can call UI Element here.
// Close progress dialog
progressDialog.dismiss();
if (unused)
{
Log.i("Get Plan","Yes");
//showData();
}
else
Toast.makeText(getApplicationContext(),"No Plans Found",Toast.LENGTH_LONG).show();
}
}
private ArrayList<String> getTheParameter(String goal_id) {
ArrayList<String> arrayList=new ArrayList<>();
if (goal_id.equals("bp"))
{
arrayList.add("systolic");
arrayList.add("diastolic");
return arrayList;
}
else
{
arrayList.add(null);
return arrayList;
}
}
}
问题是: - 在从服务器获得响应之前,执行了onPostExecute()函数。所以我会得到空结果arraylist。
JsonObjectHeader类是从服务器获取数据的基本排序类。
答案 0 :(得分:1)
当您希望使用任何第三方库进行网络呼叫时,无需使用异步任务。因为volly为网络调用创建了自己的线程。
答案 1 :(得分:0)
如果您使用volley
库,请删除AsyncTask
并以简单方法编写此代码
try {
Response.Listener listener=new Response.Listener<JSONObject>()
{
@Override
public void onResponse(JSONObject response) {
try {
System.out.println("Inside the response");
// Parsing json object response
// response will be a json object
System.out.println("Output is "+response.toString());
//Toast.makeText(getApplicationContext(),response.toString(),Toast.LENGTH_LONG).show();
planActive=response.getBoolean("success");
if (planActive)
{
JSONArray plansArray=response.getJSONArray("response");
//get Plans Details
for (int p=0;p<plansArray.length();p++)
{
JSONObject plan=plansArray.getJSONObject(p);
//get Goals Details
JSONObject planGoals=plan.getJSONObject("goal");
Goal goal=new Goal();
goal.setGoal_name("Goal Name:- "+planGoals.getString("goal_name"));
Log.i("Goal Name is",planGoals.getString("goal_name"));
JSONObject currentValue=planGoals.getJSONObject("current_value");
JSONObject targetValue=planGoals.getJSONObject("target_value");
//Get the values parameter
ArrayList<String> parameterList=getTheParameter(planGoals.getString("goal_id"));
if (parameterList.isEmpty())
{
System.out.println("Problem WHile Processing the parameter ");
}
else
{
String goalDescription="Reduce the value from";
StringBuilder currentStringBuilder=new StringBuilder();
for (int k=0;k<parameterList.size();k++)
{
currentStringBuilder.append(currentValue.getString(parameterList.get(k))+"/");
}
StringBuilder targetStringBuilder=new StringBuilder();
for (int k=0;k<parameterList.size();k++)
{
targetStringBuilder.append(targetValue.getString(parameterList.get(k))+"/");
}
goal.setGoal_description(goalDescription+currentStringBuilder.toString()+" to "+ targetStringBuilder.toString());
}
//Add the result to the array
result.add(goal);
}
}
}
catch (JSONException k)
{
Log.i("On Response",k.getMessage());
k.printStackTrace();
}
}
};
Response.ErrorListener errorListener=new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
// Handle Error
if (error instanceof TimeoutError || error instanceof NoConnectionError) {
error.printStackTrace();
Toast.makeText(getApplicationContext(), " this Network Error", Toast.LENGTH_SHORT).show();
} else if (error instanceof AuthFailureError) {
//TODO
error.printStackTrace();
Toast.makeText(getApplicationContext(), "User not authorized", Toast.LENGTH_SHORT).show();
} else if (error instanceof ServerError) {
//TODO
error.printStackTrace();
Toast.makeText(getApplicationContext(), "Server error", Toast.LENGTH_SHORT).show();
} else if (error instanceof NetworkError) {
//TODO
error.printStackTrace();
Toast.makeText(getApplicationContext(), "Network Error", Toast.LENGTH_SHORT).show();
} else if (error instanceof ParseError) {
//TODO
error.printStackTrace();
Toast.makeText(getApplicationContext(), "Error consuming request", Toast.LENGTH_SHORT).show();
}
else error.printStackTrace();
}
};
String plan_url=Constants.url+"plan";
JsonObjectHeader customRequest=new JsonObjectHeader(plan_url,null, listener, errorListener);
RequestQueue requestQueue = Volley.newRequestQueue(getApplicationContext());
requestQueue.add(customRequest);
因为在volley
中您可以在onResponse
中获得回复,因此请在此内添加onPostExecute
答案 2 :(得分:0)
您的问题是您正在onBackground(Void...)
创建一个额外的帖子。
您的代码看到了:
您需要使用Volley系统中的阻止方法。 This answer解释了它。
RequestFuture<JSONObject> future = RequestFuture.newFuture();
JsonObjectRequest request = new JsonObjectRequest(Method.POST, SIGNUP_URL, reqBody, future, future)
volleyRequestQueue.add(request);
try {
JSONObject response = future.get();
} catch (InterruptedException e) {
} catch (ExecutionException e) {
}
答案 3 :(得分:0)
不是你的帖子执行它是你的
showData();
在
之前执行getData();
已完成。理想情况下,将showData代码移动到postExecute,您将获得预期的结果。
答案 4 :(得分:0)
删除AsyncTask。
在正常函数中移动doInBackgroud中的所有代码。
在onResponse()中调用showSata()。
答案 5 :(得分:0)
我认为你应该阅读文章哪里有一个很好的解释为什么你不应该使用AsyncTask。我的建议是开始使用Retrofit(用于处理Http)+你不必自己解析JSON,你可以在你的Response对象中使用@SerializedName注释
此处&#39; s a tutorial演示了如何从服务器获取数据并填充回收视图
以下是我的登录代码
Call<LoginResponse> call = retrofit.create(ComeAroundAPIInterface.class).signin(data);
call.enqueue(new Callback<LoginResponse>() {
@Override
public void onResponse(Call<LoginResponse> call, Response<LoginResponse> response) {
if (response.isSuccessful()) {
onLoginSuccess();
sharedPreferences = getSharedPreferences(LOGIN_COOKIE, Context.MODE_PRIVATE);
SharedPreferences.Editor editor = sharedPreferences.edit();
editor.putBoolean("LOGIN",true);
editor.commit();
progressDialog.dismiss();
Intent intent = new Intent(LoginActivity.this, MainActivity.class);
intent.putExtra("user", (LoginResponse)response.body());
startActivity(intent);
finish();
} else {
progressDialog.cancel();
onLoginFailed();
Converter<ResponseBody, APIError> converter = retrofit.responseBodyConverter(APIError.class, new Annotation[0]);
APIError error = new APIError();
try {error = converter.convert(response.errorBody());} catch (IOException e) {}
Toast.makeText(getBaseContext(),error.message(),Toast.LENGTH_SHORT).show();
}
}
@Override
public void onFailure(Call<LoginResponse> call, Throwable t) {
onLoginFailed();
Log.e("Login", t.toString());
}
});
这是我的带有@SerializedName注释的Response类
public class LoginResponse implements Parcelable{
@SerializedName("id")
private String id;
@SerializedName("username")
private String username;
@SerializedName("email")
private String email;
@SerializedName("name")
private String name;
@SerializedName("sirname")
private String sirname;
//getters