JSON Object возвращает нулевой указатель - PullRequest
0 голосов
/ 28 сентября 2011

Я хочу вставить некоторые элементы в базу данных. В основном задании я получаю информацию от пользователя и передаю ее другому классу, чтобы выполнить некоторый анализ. Мой JSONObject продолжает отображаться как NULL.

Извините, если мне не ясен вопрос. Я пытался объяснить это как можно больше.

Ниже приведен код приветствия ваших входных данных

public class MainActivity extends Activity {
/** THE FOLLOWING STRINGS WILL BE DISPLAYED IN LOGCAT */

final String TAG = "########-------MAIN ACTIVITY: LOGIN--------######";
final String URL = "http://46.51.193.32/timereport/ses/sessions";
UserHelper userAdapter;
UserHelper db;
EditText edit_password,edit_username,edit_company;
String regName;
int duration = Toast.LENGTH_LONG;

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    db = new UserHelper(this);
    userAdapter = new UserHelper(this);
     edit_password = (EditText)findViewById(R.id.password);
     edit_username = (EditText)findViewById(R.id.user_name);
     edit_company = (EditText)findViewById(R.id.company_string);
    Button login = (Button)findViewById(R.id.login_button);
    login.setOnClickListener(new OnClickListener() {

        @Override
        public void onClick(View v) {
           JSONObject jsonobj = new JSONObject();
            try{

                JSONObject subJson = new JSONObject();
                subJson.put("username", edit_username.getText().toString());
                subJson.put("password", edit_password.getText().toString());
                subJson.put("company", edit_company.getText().toString());
                jsonobj.put("user", subJson);
            }
            catch(JSONException e) {
                Log.i("","#####-----error at catch jsonexception-----#####");

            }
HandleJSON.SendHttpPost(URL, jsonobj);
                String regNameSplit[] = regName.split("-");
            try{
                userAdapter.openDatabase();
                long id = db.insertIntoDatabase(edit_username.getText().toString(),edit_company.getText().toString(), edit_password.getText().toString(),regNameSplit[0], regNameSplit[2]);
                Toast.makeText(getApplicationContext(), "You have successfully logged in as: " +"\n" +regNameSplit[0], duration).show();
                Log.i(TAG, "Printing value of id which will be inserted only to remove warnings "+id);
                userAdapter.closeDatabase();
            }
            catch(SQLiteException e){
                e.printStackTrace();
            } 
        }
    });
}

}

Это класс, в который я отправляю объект JSON для анализа

public class HandleJSON{

UserHelper userAdapter;
private static final String TAG = "&&----HTTPClient-----**";
public static String SendHttpPost (String URL, JSONObject jsonobj) {
String regName = "";

try{    

        Log.v("Json object request is ",jsonobj.toString());
        DefaultHttpClient httpClientInstance = GetHttpClient.getHttpClientInstance();
        HttpPost httpPostRequest = new HttpPost(URL);
        Log.v(TAG,"The url is "+URL);

        StringEntity se;
        se = new StringEntity(jsonobj.toString());

        httpPostRequest.setEntity(se);
        httpPostRequest.setHeader("Accept", "application/json");
        httpPostRequest.setHeader("Content-type", "application/json");

        long t = System.currentTimeMillis();
        HttpResponse response = (HttpResponse) httpClientInstance.execute(httpPostRequest);
        Log.i(TAG, "HTTPRESPONSE RECIEVED" +(System.currentTimeMillis()-t) + "ms");

            String resultString = convertStreamToString(response.getEntity().getContent());
            Log.v(TAG , "The response is " +resultString);
            JSONObject jsonObj = new JSONObject(resultString);
            JSONObject sessionJson = jsonObj.getJSONObject("session");
            String sessionId = sessionJson.getString("sessionid");
            String name = sessionJson.getString("name");
            Log.v(TAG,"The session ID is "+sessionId);
            Log.v(TAG,"The name is "+name);
            regName = name+"-"+sessionId+"-"+URL;

} catch (Exception e){
    e.printStackTrace();
}
return regName;
}

 private static String convertStreamToString(InputStream is) {

BufferedReader reader = new BufferedReader(new InputStreamReader(is));
StringBuilder sb = new StringBuilder();

String line = null;
try{
    while((line = reader.readLine()) !=null ){
        sb.append(line + "\n");
    }
}
    catch (IOException e){
        e.printStackTrace();
    } finally{
        try {
            is.close();
        } catch (IOException e){
            e.printStackTrace();
        }
    }
    return sb.toString();
 }
 }

Я только что добавил часть кода, который отсутствовал в MainActivity,

String regNameSplit[] = regName.split("-");

продолжает отображаться как ноль

Ответы [ 2 ]

2 голосов
/ 28 сентября 2011
  1. Вместо вашего convertStreamToString() метода попробуйте использовать предоставленную систему EntityUtils.toString(entity).

  2. ВАЖНО: не перехватывать универсальные Exception, это скрывает непроверенные (во время выполнения) исключения. Возможно, вы скрываете JSONException, что происходит в конструкторе JSONObject .

Обновление:

Вы звоните SendHttpPost и не присваиваете результат переменной:

HandleJSON.SendHttpPost(URL, jsonobj);

должно быть:

regName = HandleJSON.SendHttpPost(URL, jsonobj);
1 голос
/ 28 сентября 2011

Я не вижу в этом ничего плохого, не могли бы вы мне сказать, что такое regname?

в вашей основной деятельности просто измените следующее:

regname = HandleJSON.SendHttpPost(URL, jsonobj);

Вы не перезваниваете regname для назначения имени и sessionid, который вы возвращаете на sendhttppost.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...