0

プロジェクトのログイン システムを作成しようとしています。フォームに入力した後に登録ボタンがクリックされたときのようなプロセスを作成したい.URLを含むデータをAPIに送信し、次のjson文字列を返します。

{
  "result": "OK",
  "message": [
      "Congratulations! You will shortly receive email ."
  ],
  "values": {
      "id": 178964,
      "fname": "", 
      "gender": "female"
  }
}

結果の文字列は、OK または No のみを返します。 ここで、結果が「OK」を返したときにloginErrorMsgに「メッセージ」を表示したいと考えています。結果が Ok を返す場合、LoginActivity を開始する必要があります。しかし、json/gson の解析でどこかを失いました。

これは、Register 用に作成したファイルです。

    public class RegisterActivity  extends Activity{
        private static String URL = "http://api.eample.com/";
        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.register);

            final EditText inputFname = (EditText) findViewById(R.id.registerFname);
            final EditText inputLname = (EditText) findViewById(R.id.registerLname);
            final EditText inputEmail = (EditText) findViewById(R.id.registerEmail);
            Button btnRegister = (Button) findViewById(R.id.btnRegister);
            Button btnLinkToLogin = (Button) findViewById(R.id.btnLinkToLogin);
            final TextView loginErrorMsg = (TextView) findViewById(R.id.register_error);

            // Register Button Click event
            btnRegister.setOnClickListener(new View.OnClickListener() {  
                Login login2;
                RadioGroup radioSexGroup = (RadioGroup) findViewById(R.id.sex);
                public void onClick(View view) {
                    String fname = inputFname.getText().toString();
                    String lname = inputLname.getText().toString();
                    String email = inputEmail.getText().toString();

                    // get selected radio button from radioGroup
                    int selectedId = radioSexGroup.getCheckedRadioButtonId();
                    RadioButton radioSexButton = (RadioButton) findViewById(selectedId);
                    String gender = radioSexButton.getText().toString();
                    System.out.println(fname);
                    //Toast.makeText(RegisterActivity.this, radioSexButton.getText(), Toast.LENGTH_SHORT).show();

                    String registerURL = URL +"&user_email="+ email +"&first_name="+ fname +"&last_name="+ lname +"&gender="+ gender;
                    System.out.println(registerURL);

                    if( email.length() == 0) {
                        loginErrorMsg.setText(R.string.empty);
                        //Toast.makeText(view.getContext(), R.string.empty, Toast.LENGTH_SHORT).show();
                        return;
                    }else{

                        try {
                            //Create an HTTP client
                            HttpClient client = new DefaultHttpClient();
                            HttpPost post = new HttpPost(registerURL);

                            //Perform the request and check the status code
                            HttpResponse response = client.execute(post);
                            StatusLine statusLine = response.getStatusLine();
                            if(statusLine.getStatusCode() == 200) {
                                HttpEntity entity = response.getEntity();
                                InputStream content = entity.getContent();

                                try {
                                    //Read the server response and attempt to parse it as JSON
                                    Reader reader = new InputStreamReader(content);

                                    Gson gson = new Gson();
                                    this.login2 = gson.fromJson(reader, Login.class);

                                    //handlePostsList(posts);
                                } catch (Exception ex) {
                                    //Log.e(TAG, "Failed to parse JSON due to: " + ex);
                                    failedLoading();
                                }
                            } else {
                                //Log.e(TAG, "Server responded with status code: " + statusLine.getStatusCode());
                                failedLoading();
                            }
                        } catch(Exception ex) {
                            //Log.e(TAG, "Failed to send HTTP POST request due to: " + ex);
                            failedLoading();
                        }
//To set register message
                    if(login2.getResult().equals("OK")){
                        loginErrorMsg.setText(login2.getMessage().toString());
                    }
                    }


                }
            });

        }

誰かが登録プロセスを解決するのを手伝ってくれますか? それを解析して「メッセージ」文字列データを取得する方法を知りたいだけです。

編集:ログインオブジェクトを次のように変更し、値クラスを作成します。

LogCat:

09-29 13:05:13.145: E/AndroidRuntime(9428): FATAL EXCEPTION: main
09-29 13:05:13.145: E/AndroidRuntime(9428): java.lang.NullPointerException
09-29 13:05:13.145: E/AndroidRuntime(9428):     at com.kabelash.sk.RegisterActivity$1.onClick(RegisterActivity.java:105)
09-29 13:05:13.145: E/AndroidRuntime(9428):     at android.view.View.performClick(View.java:4211)
09-29 13:05:13.145: E/AndroidRuntime(9428):     at android.view.View$PerformClick.run(View.java:17267)
09-29 13:05:13.145: E/AndroidRuntime(9428):     at android.os.Handler.handleCallback(Handler.java:615)
09-29 13:05:13.145: E/AndroidRuntime(9428):     at android.os.Handler.dispatchMessage(Handler.java:92)
09-29 13:05:13.145: E/AndroidRuntime(9428):     at android.os.Looper.loop(Looper.java:137)
09-29 13:05:13.145: E/AndroidRuntime(9428):     at android.app.ActivityThread.main(ActivityThread.java:4898)
09-29 13:05:13.145: E/AndroidRuntime(9428):     at java.lang.reflect.Method.invokeNative(Native Method)
09-29 13:05:13.145: E/AndroidRuntime(9428):     at java.lang.reflect.Method.invoke(Method.java:511)
09-29 13:05:13.145: E/AndroidRuntime(9428):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1006)
09-29 13:05:13.145: E/AndroidRuntime(9428):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:773)
09-29 13:05:13.145: E/AndroidRuntime(9428):     at dalvik.system.NativeStart.main(Native Method)
09-29 13:10:21.380: I/Process(9428): Sending signal. PID: 9428 SIG: 9
4

2 に答える 2

0

強制終了メッセージが表示されると、LogCat に診断出力が表示されます。たとえば、まだ NullPointerException である可能性があります。その場合は、logcat に記載されている行番号を見て、コード内のどの行にあるかを確認する必要があります。また、Eclipse デバッガーを使用してコードをステップ実行し、問題が発生している場所を確認することもできます。ギル

于 2013-09-29T13:46:44.053 に答える