0

インターネットに接続するアプリケーションを使用する場合、この後にアプリがクラッシュしたり強制終了されたりすると、再度ログインできなくなります。アプリケーション - >アプリ - >停止ボタンから停止して再度ログインする必要があります。

アプリのデバッグをたどると、デバッグ メッセージが doInBackground メソッドの最後に表示されますが、非同期タスク クラスが doInbackground メソッドの後に onPostExecute を呼び出すことがわかっています。

誰でもこの問題で私を助けることができますか?

    private class doAuthentication extends AsyncTask<String, String, String> {

    @Override
    protected String doInBackground(String... params) {



        Requester req = new Requester();
        String hash = req.loginByPIN(params[0]);//,VendingManagerActivity.this);

        return hash;
    }

    @Override
    protected void onPostExecute(String hash) {
        Log.d("Vending","In post Ex-> "+hash);
    //  myProgressDialog.dismiss();


        if (hash.equals("")) {

            final EditText kbdInput = (EditText) findViewById(R.id.kbdInput);

            kbdInput.setText("");

            displayMessage(getString(R.string.err_wrong_credentials));
            return;
        } else if (hash.equals("-")) {

            final EditText kbdInput = (EditText) findViewById(R.id.kbdInput);

            kbdInput.setText("");

            displayMessage(getString(R.string.err_no_permissions));
            return;
        } else {

            String[] resp = hash.split("#");


            Editor edit = mPrefs.edit();

            edit.putString("login_hash",resp[0]);// hash);
            edit.putString("password",resp[1]);//lbp.reset_pass);
            edit.commit();

            Intent mainScreenActivity = new Intent(
                    VendingManagerActivity.this, MainScreenActivity.class);

            startActivity(mainScreenActivity);

            finish();
        }
    }
}

リクエスタ クラス -> メソッド loginByPIN ->

    public String loginByPIN(String pin_code)
{
    ArrayList<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>(3);
    nameValuePairs.add(new BasicNameValuePair("module", "tablet"));
    nameValuePairs.add(new BasicNameValuePair("method", "loginByPin"));
    nameValuePairs.add(new BasicNameValuePair("pin", pin_code));
    String xmlData = getRequest(API_ADDRESS, nameValuePairs);

    String hash = "";
    String response = "";

    try {

        Serializer serializer = new Persister();        

        Reader reader = new StringReader(xmlData);
        LoginByPin lbp = 
            serializer.read(LoginByPin.class, reader, false);

        hash = lbp.hash;

        Requester.HASH = hash;

        Log.d("Vending", "HASH received: " + hash);

        response = hash +"#"+lbp.reset_pass;



    } catch (Exception e) {

        Log.d("Vending",e.getMessage().toString());
        Serializer serializer = new Persister();        

        Reader reader = new StringReader(xmlData);

        try {

            Error err = 
                serializer.read(Error.class, reader, false);

            Integer errorCode = err.code;
            String errorText = err.text;

            Log.e("Vending", "ERROR: " + errorText + "(" + Integer.toString(errorCode) + ")");

            if (err.code == 200)
                return "-";

        } catch (Exception e2) {

            Log.e("Vending", "ERROR: Invalid output returned from API");

        }

    }
    Log.d("Vending","Before returning-> "+hash);
    return response;//hash;
}

ありがとう!

編集:このようにコードを変更しないでください

@Override
    protected String doInBackground(String... params) {



        Requester req = new Requester();
        String hash = req.loginByPIN(params[0]);//,VendingManagerActivity.this);
        Log.d("Vending","Before doInBackground ends-> "+hash);
        return hash;
    }

    @Override
    protected void onPostExecute(String hash) {
        Log.d("Vending","In post Ex-> "+hash);
        myProgressDialog.dismiss();

そしてlogcat出力は

10-29 10:26:06.278: D/Vending(25714): Before returning-> peq8qkjvee7v4nhci8v3dub293
10-29 10:26:06.278: D/Vending(25714): Before doInBackground ends-> peq8qkjvee7v4nhci8v3dub293#qwerty123
4

1 に答える 1

1

doInBackground()の実行中にアプリがクラッシュした場合、はonPostExecute()呼び出されません。

onPostExecute()doInBackground()メソッドが正常に完了した後にのみ呼び出されます。

于 2012-10-29T07:11:38.913 に答える