【问题标题】:Android AsyncTask can not retrieve in JSON string from php-mysqlAndroid AsyncTask 无法从 php-mysql 检索 JSON 字符串
【发布时间】:2016-11-19 08:42:18
【问题描述】:

我可以显示存储在“值”中的数组中的数据,但是当我尝试从数据库中获取数据时,我得到了

"E/Surface: getSlotFromBufferLocked: 未知缓冲区"

错误。我有 php 脚本和 mysql 数据库,其中有一个“问题”列。我不确定在连接建立或 json 解析或其他任何地方是否有问题。

我的 VersionsFragment.java

public class VersionsFragment extends ListFragment {
public VersionsFragment() {
}


@Override
public void onActivityCreated(Bundle savedInstanceState) {
    super.onActivityCreated(savedInstanceState);
    //String[] versionName = getResources().getStringArray(R.array.version_names); //this works fine
    new MyTask().execute();
}

class MyTask extends AsyncTask<String, Integer, String[]> {

    @Override
    protected String[] doInBackground(String... params) {
        String[] versionName = new String[0];
        ArrayList<String> scripts = new ArrayList<String>();
        try {
            URL url = new URL("http://192.168.1.105/android/phpcall.php");
            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
            String strJson = "";
            String line;
            BufferedReader br = new BufferedReader(new InputStreamReader(conn.getInputStream()));
            while ((line = br.readLine()) != null) {
                strJson += line;
            }
            //Log.d(VersionsFragment.class.getSimpleName(), line);
            JSONArray jArray = new JSONArray(strJson);

            for (int i = 0; i < jArray.length(); i++) {

                JSONObject jObject = jArray.getJSONObject(i);

                String name = jObject.getString("question");

                scripts.add(name);
            }
            versionName = scripts.toArray(new String[scripts.size()]);

        } catch (MalformedURLException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        } catch (JSONException e) {
            e.printStackTrace();
        }
        return versionName;
    }

    protected void onPostExecute(String[] result){
        //for(int i=0;i<result.length;i++)
            //Log.d(VersionsFragment.class.getSimpleName(), result[i]);
        ArrayAdapter<String> adapter = new ArrayAdapter<String>(getActivity(), android.R.layout.simple_list_item_1, result);
        setListAdapter(adapter);
    }
}

@Override
public void onListItemClick(ListView l, View v, int position, long id) {
    OnVersionNameSelectionChangeListener listener = (OnVersionNameSelectionChangeListener) getActivity();
     listener.OnSelectionChanged(position);
   }
}

【问题讨论】:

    标签: php android mysql json android-asynctask


    【解决方案1】:

    将上面的代码编辑如下:

    JSONObject jsonObj = new JSONObject(strJson);
    
    // Getting JSON Array node
    JSONArray jArray = jsonObj.getJSONArray(YOUR_JSON_ARRAY_NAME);
    

    【讨论】:

    • 在 doinbackground 中替换 JSONArray jArray = new JSONArray(strJson);上面的行。
    • 我应该用 strJson 替换 YOUR_JSON_ARRAY_NAME 吗?
    • 你能打印json响应吗?
    • 是的,写 Log.d(VersionsFragment.class.getSimpleName(), "JSON string" + strJson);上面的 JSONObject jsonObj = new JSONObject(strJson);给出以下行:JSON string[{"id":"1","name":"what is java","address":"programming language"},{"id":"2","name": "什么是oop","address":"面向对象编程"},{"id":"3","name":"为什么使用java?","address":"主要用于android"}]跨度>
    • 我已经更改了 php 脚本,现在它检索这个字符串。 JSON 字符串[{"id":"1","question":"什么是 java","answer":"编程语言"},{"id":"2","question":"什么是 oop" ,"answer":"面向对象编程"},{"id":"3","question":"为什么使用 java?","answer":"主要用于 android"}]
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-12-12
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多