0

我正在开发使我能够从 php mysql 加载用户的应用程序,当我选择其中一个时,它会打开一个新活动以显示用户名和删除它的按钮。问题是当我运行应用程序时,AllUsersActivity 不会返回用户。它显示一个空白页面,这里是方法 LoadAllUsers 的代码,如果没有任何用户,则有一个“else”移动到另一个 avtivity 以创建用户。但我删除了它,因为我希望它显示用户并在不添加的情况下删除它们。在我删除添加部分后,它返回给我 null,尽管连接工作正常并且它从 logcat 中的数据库中检索数据。任何人都可以帮我吗

/**
     * Background Async Task to Load all users by making HTTP Request
     * */
    class LoadAllUsers extends AsyncTask<String, String, String> {

        /**
         * Before starting background thread Show Progress Dialog
         * */
        @Override
        protected void onPreExecute() {
            super.onPreExecute();
            pDialog = new ProgressDialog(AllUsersActivity.this);
            pDialog.setMessage("Loading users. Please wait...");
            pDialog.setIndeterminate(false);
            pDialog.setCancelable(false);
            pDialog.show();
        }

        /**
         * getting All users from url
         * */
        protected String doInBackground(String... args) {
            // Building Parameters
            List<NameValuePair> params = new ArrayList<NameValuePair>();
            // getting JSON string from URL
            JSONObject json = jParser.makeHttpRequest(url_all_users, "GET", params);

            // Check your log cat for JSON reponse
            Log.d("All users: ", json.toString());

            try {
                // Checking for SUCCESS TAG
                int success = json.getInt(TAG_SUCCESS);

                if (success == 1) {
                    // user found
                    // Getting Array of user
                    user = json.getJSONArray(TAG_USER);

                    // looping through All users
                    for (int i = 0; i < user.length(); i++) {
                        JSONObject c = user.getJSONObject(i);

                        // Storing each json item in variable
                        String U_mail = c.getString(TAG_UMAIL);
                        String Name = c.getString(TAG_NAME);

                        // creating new HashMap
                        HashMap<String, String> map = new HashMap<String, String>();

                        // adding each child node to HashMap key => value
                        map.put(TAG_UMAIL, U_mail);
                        map.put(TAG_NAME, Name);

                        // adding HashList to ArrayList
                        usersList.add(map);
                    }
                } 
            } 

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

            return null;
        }

/**
         * After completing background task Dismiss the progress dialog
         * **/
        protected void onPostExecute(String file_url) {
            // dismiss the dialog after getting all users
            pDialog.dismiss();
            // updating UI from Background Thread
            runOnUiThread(new Runnable() {
                public void run() {
                    /**
                     * Updating parsed JSON data into ListView
                     * */
                    ListAdapter adapter = new SimpleAdapter(
                            AllUsersActivity.this, usersList,
                            R.layout.list_item, new String[] { TAG_UMAIL,
                                    TAG_NAME},
                            new int[] { R.id.um, R.id.name });
                    // updating listview
                    setListAdapter(adapter);
                }
            });

这是日志猫

04-23 09:22:36.814: W/System.err(916): org.json.JSONException: No value for users
04-23 09:22:36.814: W/System.err(916):  at org.json.JSONObject.get(JSONObject.java:354)
04-23 09:22:36.814: W/System.err(916):  at org.json.JSONObject.getJSONArray(JSONObject.java:544)
04-23 09:22:36.824: W/System.err(916):  at com.example.androidhive.AllUsersActivity$LoadAllUsers.doInBackground(AllUsersActivity.java:140)
04-23 09:22:36.824: W/System.err(916):  at com.example.androidhive.AllUsersActivity$LoadAllUsers.doInBackground(AllUsersActivity.java:1)
04-23 09:22:36.824: W/System.err(916):  at android.os.AsyncTask$2.call(AsyncTask.java:287)
04-23 09:22:36.865: W/System.err(916):  at java.util.concurrent.FutureTask.run(FutureTask.java:234)

 04-23 09:22:36.924: W/System.err(916):     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1080)
    04-23 09:22:36.924: W/System.err(916):  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor

.java:573)
4

2 回答 2

1

您没有onPostExecute()覆盖,您应该在那里关闭对话框并更新您的 UI。

我还注意到您return null;doInBackground()方法中使用,如果您想按照方法签名的建议返回一个字符串,那么您将在此处返回一个字符串以传递给该onPostExecute()方法。

正如 Gordak 建议的那样,您可以将方法签名更改为AsyncTask<Void, Void, ArrayList<HashMap<String, String>>>(注意您必须使用大写 V 表示Void),然后您可以简单地返回HashMap并处理它onPostExecute()

编辑

我注意到您更新的问题有几件事,首先,您的异常是因为当您尝试加载用户数组时在 JSON 中找不到该字段。 user = json.getJSONArray(TAG_USER);检查您的提要以确保字段名称或TAG_USER.

其次,您始终将 null 放入您onPostExecute()的文件中,因此文件路径将始终为 null。

最后,onPostExecute()始终在 UI 线程上执行,因此您不需要runOnUIThread()调用。

于 2013-04-23T09:59:59.320 回答
0

我不明白你想做什么。我猜你从 JSON 字符串中获取数据是什么。查看您的代码,此数据包含一些JSONObject. 每个对象都包含一封邮件和一个姓名。

在这种情况下我可能会做什么。而不是扩展 a AsyncTask<String, String, String>,扩展 a AsyncTask<void, void, ArrayList<HashMap<String, String>>>。这样,您的doInBackground方法返回的 aArrayList<HashMap<String, String>>可能比单个字符串更有趣。

在 for 循环结束时,返回 usersList。

如果遇到异常,请处理它并返回 null 或一个空的新 ArrayList> 对象。

然后决定你要在onPostExecute方法中做什么。

希望它可以帮助你。

于 2013-04-23T09:53:14.517 回答