使用json从php接收数据:mysql到android

时间:2013-03-07 07:07:46

标签: android json web-services

我正在开发一个Android应用程序,它从我的数据库发送和接收简单的fname,Lname。我正在使用php和mysql进行webservice。我正在使用此tutorial 在JSONParser类中,如下所示

public class JSONParser {

static InputStream is = null;
static JSONObject jObj = null;
static String json = "";

// constructor
public JSONParser() {

}

// function get json from url
// by making HTTP POST or GET method
public JSONObject makeHttpRequest(String url, String method,
        List<NameValuePair> params) {

    // Making HTTP request
    try {

        // check for request method
        if(method == "POST"){
            // request method is POST
            // defaultHttpClient
            DefaultHttpClient httpClient = new DefaultHttpClient();
            HttpPost httpPost = new HttpPost(url);
            httpPost.setEntity(new UrlEncodedFormEntity(params));

            HttpResponse httpResponse = httpClient.execute(httpPost);
            HttpEntity httpEntity = httpResponse.getEntity();
            is = httpEntity.getContent();

        }else if(method == "GET"){
            // request method is GET
            DefaultHttpClient httpClient = new DefaultHttpClient();
            String paramString = URLEncodedUtils.format(params, "utf-8");
            url += "?" + paramString;
            HttpGet httpGet = new HttpGet(url);

            HttpResponse httpResponse = httpClient.execute(httpGet);
            HttpEntity httpEntity = httpResponse.getEntity();
            is = httpEntity.getContent();
        }           

    } catch (UnsupportedEncodingException e) {
        e.printStackTrace();
    } catch (ClientProtocolException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    }

    try {
        BufferedReader reader = new BufferedReader(new InputStreamReader(
                is, "iso-8859-1"), 8);
        StringBuilder sb = new StringBuilder();
        String line = null;
        while ((line = reader.readLine()) != null) {
            sb.append(line + "talha");
        }
        Log.i("Buffer Error", "Baby Baby! Yes Mama! ");

        is.close();
        json = sb.toString();
        Log.i("Buffer Error", "Eating suger! NO Mama! "+ json);




    } catch (Exception e) {
        Log.e("Buffer Error", "Error converting result " + e.toString());
    }

    // try parse the string to a JSON object
    try {
        jObj = new JSONObject(json);
    } catch (JSONException e) {
        Log.e("MyJSON", "Error parsing data "+ e.toString());
    }



    // return JSON String
    return jObj;

}
}

当我尝试将字符串解析为json对象时

try {
     jObj = new JSONObject(json);
    } catch (JSONException e) {
        Log.e("MyJSON", "Error parsing data "+ e.toString());
    }

我得到异常JSONArray无法转换为JSONObject。请帮助,因为在每个其他教程中,都描述了类似的过程。

1 个答案:

答案 0 :(得分:0)

是的,如果您直接创建该问题,您将遇到该问题。在json = b.toString();之后添加一行

json = sb.toString();
json = "{json_parse" + "[" + json + "]" + "}";