【问题标题】:parsing org.json.jsonexception value <br type java.lang.String cannot be converted to JSONOobject解析 org.json.jsonexception 值 <br type java.lang.String 无法转换为 JSONOobject
【发布时间】:2014-09-05 04:43:06
【问题描述】:

我已经尝试了所有方法,请任何人帮助我处理此代码。它给出了错误解析 org.json.jsonexception 值 br 类型 java.lang.String 无法转换为 JSONOobject 错误。除了这个错误 logcat 什么都没有显示。我认为问题出在 Post Login() 方法中,但我无法弄清楚问题所在。当我单击发送按钮时,问题就来了。问题可能出在发送按钮和 PostLogin 方法中。我是新的堆栈溢出,所以如果出现问题,请合作。我已经失去了 3 天的时间,但看不出真正的问题是什么。请任何人解决它。是紧急状况。

public class Credit extends Activity implements OnClickListener{

int mYear, mMonth, mDay;
EditText Epickupdate;
Reserve r;
String msg,status;
EditText etname_on_card,etcard_number,etcvv,user_id;
String sflno,stime,sdate,sadd,sdrop_add,sinst;
Button send;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.credit);
    getActionBar().hide();

    StrictMode.ThreadPolicy policy = new    StrictMode.ThreadPolicy.Builder().permitAll().build();
    StrictMode.setThreadPolicy(policy); 

    Epickupdate = (EditText)findViewById(R.id.expiry_date);
    Epickupdate.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View arg0) {
            datepicker();
        }
    });

        user_id=(EditText)findViewById(R.id.user_id);
        etname_on_card=(EditText)findViewById(R.id.name_on_card);
        etcard_number=(EditText)findViewById(R.id.card_number);

        etcvv=(EditText)findViewById(R.id.cvv);

        send=(Button)findViewById(R.id.proceedcheck);
        send.setOnClickListener(this);  
}

public void postLoginData() {
    // Create a new HttpClient and Post Header
    HttpClient httpclient = new DefaultHttpClient();

    HttpPost httppost = new HttpPost("http://atlcity.qa.apps.jasperit.net/index.php");

    SharedPreferences pr= getSharedPreferences("reserve", 0);
    String sflno=pr.getString("flightno", "null");
    String stime=pr.getString("stime", "null");
    String sdate=pr.getString("sdate", "null");
    String  sadd=pr.getString("sadd", "null");
    String sdrop_add=pr.getString("sdrop_add", "null");
    String  sinst=pr.getString("sinst", "null");

    try {
        // Add user name and password

        String sname_on_card = etname_on_card.getText().toString();         
        String scard_number = etcard_number.getText().toString();
        String expiry_dates = Epickupdate.getText().toString();         
        String cvvs = etcvv.getText().toString();           
        String suser_id = user_id.getText().toString();

        List<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>(2);
        nameValuePairs.add(new BasicNameValuePair("action", "makeReservation"));
        nameValuePairs.add(new BasicNameValuePair("app_secret", "jkhljkUILJGJkljhkjUGLG87796587687HGKJhghkjKUYGKJHjhgjUYGKUY7865876hgKUYGK"));
        nameValuePairs.add(new BasicNameValuePair("flight_number", sflno));
        nameValuePairs.add(new BasicNameValuePair("pick_up_time", stime));
        nameValuePairs.add(new BasicNameValuePair("pick_up_date",sdate));
        nameValuePairs.add(new BasicNameValuePair("pick_up_address",sadd));
        nameValuePairs.add(new BasicNameValuePair("drop_off_address", sdrop_add));
        nameValuePairs.add(new BasicNameValuePair("special_instruction", sinst));
        nameValuePairs.add(new BasicNameValuePair("user_id", suser_id));            
        nameValuePairs.add(new BasicNameValuePair("name_on_card",sname_on_card));
        nameValuePairs.add(new BasicNameValuePair("card_number",scard_number));
        nameValuePairs.add(new BasicNameValuePair("expiry_date", expiry_dates));
        nameValuePairs.add(new BasicNameValuePair("cvv", cvvs));

        httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));

        // Execute HTTP Post Request
        HttpResponse response = httpclient.execute(httppost);
        String str = inputStreamToString(response.getEntity().getContent()).toString();
        Log.w("Response", str);
        try {
            JSONObject reader = new JSONObject(str);
            msg = reader.getString("msg");// server le request gareko
            status = reader.getString("status");
            Toast.makeText(getApplicationContext()," "+msg,Toast.LENGTH_LONG).show();
        } catch (Exception e) {
            Toast.makeText(getApplicationContext(), "parsing error "+e, Toast.LENGTH_LONG).show();
            e.printStackTrace();
        }
    } catch (ClientProtocolException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    }
}

private StringBuilder inputStreamToString(InputStream is) {
    String line = "";
    StringBuilder total = new StringBuilder();
    // Wrap a BufferedReader around the InputStream
    BufferedReader rd = new BufferedReader(new InputStreamReader(is));
    // Read response until the end
    try {
        while ((line = rd.readLine()) != null) {
            total.append(line);
        }
    } catch (IOException e) {
        e.printStackTrace();
    }
    // Return full string
    return total;
}

@Override
public void onClick(View v) {

String sname_on_card = etname_on_card.getText().toString();         
String scard_number = etcard_number.getText().toString();
String expiry_dates = Epickupdate.getText().toString();         
String cvvs = etcvv.getText().toString();           
String suser_id = user_id.getText().toString();

    try {
        if (v.getId() == R.id.proceedcheck) {       
            if (sname_on_card.matches("")) {
                Toast.makeText(this, "please fill up all the field", Toast.LENGTH_SHORT).show();
                return;
            }else if(scard_number.matches("")){
                 Toast.makeText(this, "please fill up all the field", Toast.LENGTH_SHORT).show();
                return;
            }else if(expiry_dates.matches("")){
                 Toast.makeText(this, "please fill up all the field", Toast.LENGTH_SHORT).show();
                return;
            }else if(cvvs.matches("")){
                 Toast.makeText(this, "please fill up all the field", Toast.LENGTH_SHORT).show();
                return;
            }else if(suser_id.matches("")){
                 Toast.makeText(this, "please fill up all the field", Toast.LENGTH_SHORT).show();
                return;
            }else{
                try {
                    postLoginData();
                } catch (Exception e) {
                    Toast.makeText(getBaseContext(), "postlogin error " +e,Toast.LENGTH_LONG);
                    e.printStackTrace();
                }

            }}

    } catch (Exception e) {
         Toast.makeText(this,"error in onclick"+e, Toast.LENGTH_SHORT).show();
        e.printStackTrace();
    }

}

}

Logcat:

09-05 00:48:11.147: W/Response(1635): <br /><b>Fatal error</b>:  Call to a member function fetch_object() on a non-object in <b>/home/appsjasp/public_html/atlcity.qa/index.php</b> on line <b>124</b><br />
09-05 00:48:11.177: W/System.err(1635): org.json.JSONException: Value <br of type java.lang.String cannot be converted to JSONObject
09-05 00:48:11.187: W/System.err(1635):     at org.json.JSON.typeMismatch(JSON.java:111)
09-05 00:48:11.187: W/System.err(1635):     at org.json.JSONObject.<init>(JSONObject.java:159)
09-05 00:48:11.197: W/System.err(1635):     at org.json.JSONObject.<init>(JSONObject.java:172)
09-05 00:48:11.197: W/System.err(1635):     at example.atlcitylimo.Credit.postLoginData(Credit.java:172)
09-05 00:48:11.197: W/System.err(1635):     at example.atlcitylimo.Credit.onClick(Credit.java:247)
09-05 00:48:11.197: W/System.err(1635):     at android.view.View.performClick(View.java:4438)
09-05 00:48:11.207: W/System.err(1635):     at android.view.View$PerformClick.run(View.java:18422)
09-05 00:48:11.207: W/System.err(1635):     at android.os.Handler.handleCallback(Handler.java:733)
09-05 00:48:11.207: W/System.err(1635):     at android.os.Handler.dispatchMessage(Handler.java:95)
09-05 00:48:11.207: W/System.err(1635):     at android.os.Looper.loop(Looper.java:136)
09-05 00:48:11.207: W/System.err(1635):     at android.app.ActivityThread.main(ActivityThread.java:5017)
09-05 00:48:11.207: W/System.err(1635):     at java.lang.reflect.Method.invokeNative(Native Method)
09-05 00:48:11.207: W/System.err(1635):     at java.lang.reflect.Method.invoke(Method.java:515)
09-05 00:48:11.217: W/System.err(1635):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
09-05 00:48:11.227: W/System.err(1635):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
09-05 00:48:11.227: W/System.err(1635):     at dalvik.system.NativeStart.main(Native Method)

【问题讨论】:

  • 发布你的日志。根据这个错误 java.lang.String cannot be converted to JSONOobject error 它说你正在将 String 转换为 JSONObject
  • 你能发布json响应吗?
  • logcat 是空白的.. 上面的错误也会在 toast 中弹出。 logcat 里面什么都没有
  • 请发布您从服务器获得的响应。
  • 请发布您从服务器获得的响应。正如@Aniruddha 所说

标签: java android json eclipse android-activity


【解决方案1】:

由于来自服务器的响应不是 JSONObject 其触发异常 org.json.JSONException

回应

<br /><b>Fatal error</b>:  Call to a member function fetch_object() on a non-object in <b>/home/appsjasp/public_html/atlcity.qa/index.php</b> on line <b>124</b><br />

响应是 XML 而不是 JSON,因此它会在创建 JSONObject 的对象并传递 XML 字符串时触发 org.json.JSONException

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2013-04-09
    • 1970-01-01
    • 2016-10-03
    • 1970-01-01
    • 1970-01-01
    • 2014-03-20
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多