无法添加窗口 - 令牌android.os.BinderProxy@2a888da无效;你的活动在运行吗?

时间:2018-02-27 13:30:26

标签: android firebase firebase-realtime-database

该应用程序使用来自Firebase的登录和注册。自动登录后,应用程序会自动登录,应用程序正常运行。 但在提供存储权限后,自动登录可以正常工作,但在加载主要活动时会崩溃。

MainActivity.class

package com.example.arnav.chatbot;

import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.content.SharedPreferences;
import android.content.res.AssetManager;
import android.os.Environment;
import android.support.annotation.NonNull;
import android.support.design.widget.FloatingActionButton;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.text.TextUtils;
import android.view.View;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.ListView;
import org.alicebot.ab.AIMLProcessor;
import org.alicebot.ab.Bot;
import org.alicebot.ab.Chat;
import org.alicebot.ab.Graphmaster;
import org.alicebot.ab.MagicBooleans;
import org.alicebot.ab.MagicStrings;
import org.alicebot.ab.PCAIMLProcessorExtension;
import org.alicebot.ab.Timer;
import com.example.arnav.chatbot.Adapter.ChatMessageAdapter;
import com.example.arnav.chatbot.Pojo.ChatMessage;
import com.example.arnav.chatbot.R;
import com.google.firebase.auth.FirebaseAuth;
import com.google.firebase.auth.FirebaseUser;
import com.google.gson.Gson;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.ArrayList;

public class MainActivity extends AppCompatActivity {


private ListView mListView;
private FloatingActionButton mButtonSend;
private EditText mEditTextMessage;
private ImageView mImageView;
public Bot bot;
public static Chat chat;
private ChatMessageAdapter mAdapter;
private Student student;
private FirebaseAuth mAuth;
private FirebaseAuth.AuthStateListener mAuthListener;
private BroadcastReceiver broadcastReceiver;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    mListView = (ListView) findViewById(R.id.listView);
    mButtonSend = (FloatingActionButton) findViewById(R.id.btn_send);
    mEditTextMessage = (EditText) findViewById(R.id.et_message);
    mImageView = (ImageView) findViewById(R.id.iv_image);
    mAdapter = new ChatMessageAdapter(this, new ArrayList<ChatMessage>());

    mListView.setAdapter(mAdapter);

    mButtonSend.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            String message = mEditTextMessage.getText().toString();
            //bot
            String response = chat.multisentenceRespond(mEditTextMessage.getText().toString());
            if (TextUtils.isEmpty(message)) {
                return;
            }
            sendMessage(message);
            mimicOtherMessage(response);
            mEditTextMessage.setText("");
            mListView.setSelection(mAdapter.getCount() - 1);
        }
    });
    //checking SD card availablility
    boolean a = isSDCARDAvailable();
    //receiving the assets from the app directory
    AssetManager assets = getResources().getAssets();
    File jayDir = new File(Environment.getExternalStorageDirectory().toString() + "/srm/bots/SRM");
    boolean b = jayDir.mkdirs();
    if (jayDir.exists()) {
        //Reading the file
        try {
            for (String dir : assets.list("SRM")) {
                File subdir = new File(jayDir.getPath() + "/" + dir);
                boolean subdir_check = subdir.mkdirs();
                for (String file : assets.list("SRM/" + dir)) {
                    File f = new File(jayDir.getPath() + "/" + dir + "/" + file);
                    if (f.exists()) {
                        continue;
                    }
                    InputStream in = null;
                    OutputStream out = null;
                    in = assets.open("SRM/" + dir + "/" + file);
                    out = new FileOutputStream(jayDir.getPath() + "/" + dir + "/" + file);
                    //copy file from assets to the mobile's SD card or any secondary memory
                    copyFile(in, out);
                    in.close();
                    in = null;
                    out.flush();
                    out.close();
                    out = null;
                }
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
    //get the working directory
    MagicStrings.root_path = Environment.getExternalStorageDirectory().toString() + "/srm";
    System.out.println("Working Directory = " + MagicStrings.root_path);
    AIMLProcessor.extension =  new PCAIMLProcessorExtension();
    //Assign the AIML files to bot for processing
    bot = new Bot("SRM", MagicStrings.root_path, "chat");
    chat = new Chat(bot);
    String[] args = null;
    mainFunction(args);

    SharedPreferences sharedPreferences = getSharedPreferences("STUDENT_FILE_KEY", MODE_PRIVATE);
    Gson gson = new Gson();
    String json = sharedPreferences.getString("student", "");
    student = gson.fromJson(json, Student.class);

    mAuth = FirebaseAuth.getInstance();

    broadcastReceiver = new BroadcastReceiver() {
        @Override
        public void onReceive(Context context, Intent intent) {

        }
    };

    registerReceiver(broadcastReceiver, new 
 IntentFilter(MyFirebaseInstanceIDService.TOKEN_BROADCAST));

    mAuthListener = new FirebaseAuth.AuthStateListener(){

        @Override
        public void onAuthStateChanged(@NonNull FirebaseAuth firebaseAuth) {
            FirebaseUser user = firebaseAuth.getCurrentUser();

            if (user != null) {
                // User is signed in
            }
            else
            {
                Intent intent = new Intent(MainActivity.this, SignInActivity.class);
                startActivity(intent);
                finish();
                // User is signed out
            }
            // ...
        }
    };

}

private void sendMessage(String message) {
    ChatMessage chatMessage = new ChatMessage(message, true, false);
    mAdapter.add(chatMessage);

    //mimicOtherMessage(message);
}

private void mimicOtherMessage(String message) {
    ChatMessage chatMessage = new ChatMessage(message, false, false);
    mAdapter.add(chatMessage);
}

private void sendMessage() {
    ChatMessage chatMessage = new ChatMessage(null, true, true);
    mAdapter.add(chatMessage);

    mimicOtherMessage();
}

private void mimicOtherMessage() {
    ChatMessage chatMessage = new ChatMessage(null, false, true);
    mAdapter.add(chatMessage);
}
//check SD card availability
public static boolean isSDCARDAvailable(){
    return Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)? true :false;
}
//copying the file
private void copyFile(InputStream in, OutputStream out) throws IOException {
    byte[] buffer = new byte[1024];
    int read;
    while((read = in.read(buffer)) != -1){
        out.write(buffer, 0, read);
    }
}
//Request and response of user and the bot
public static void mainFunction (String[] args) {
    MagicBooleans.trace_mode = false;
    System.out.println("trace mode = " + MagicBooleans.trace_mode);
    Graphmaster.enableShortCuts = true;
    Timer timer = new Timer();
    String request = "Hello.";
    String response = chat.multisentenceRespond(request);

    System.out.println("Human: "+request);
    System.out.println("Robot: " + response);
}

}

清单文件

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.arnav.chatbot">

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" 
 />

<application
    android:allowBackup="true"
    android:icon="@mipmap/ic_launcher"
    android:label="@string/app_name"
    android:supportsRtl="true"
    android:theme="@style/AppTheme">
    <service
        android:name="com.example.arnav.chatbot.MyFirebaseInstanceIDService"
        android:exported="false">
        <intent-filter>
            <action android:name="com.google.firebase.INSTANCE_ID_EVENT"/>
        </intent-filter>
    </service>
    <activity android:name=".MainActivity">
        <!--<intent-filter>-->
            <!--<action android:name="android.intent.action.MAIN" />-->

            <!--<category android:name="android.intent.category.LAUNCHER" 
/>-->
        <!--</intent-filter>-->
    </activity>
    <activity android:name=".SignInActivity"
        android:screenOrientation="portrait">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
    <activity android:name=".SignUpActivity"
        android:screenOrientation="portrait" />
</application>

</manifest>

登录活动

 package com.example.arnav.chatbot;

import android.app.ProgressDialog;
import android.content.Context;
import android.content.DialogInterface;
import android.content.Intent;
import android.content.SharedPreferences;
import android.support.annotation.NonNull;
import android.support.design.widget.TextInputLayout;
import android.support.v7.app.AlertDialog;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.text.TextUtils;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;

import com.google.android.gms.tasks.OnCompleteListener;
import com.google.android.gms.tasks.Task;
import com.google.firebase.auth.AuthResult;
import com.google.firebase.auth.FirebaseAuth;
import com.google.firebase.auth.FirebaseUser;
import com.google.firebase.database.DataSnapshot;
import com.google.firebase.database.DatabaseError;
import com.google.firebase.database.DatabaseReference;
import com.google.firebase.database.FirebaseDatabase;
import com.google.firebase.database.ValueEventListener;
import com.google.gson.Gson;

import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class SignInActivity extends AppCompatActivity implements 
View.OnClickListener {

private Button signInButton;
private Button signUpButton;
TextView forgotPasswordTextView;
TextInputLayout emailTextInputLayout,passwordTextInputLayout;
String email;
String password;
private DatabaseReference mDatabase;
private FirebaseAuth mAuth;
private FirebaseAuth.AuthStateListener mAuthListener;
ProgressDialog progressDialog;
private Student student;

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

    emailTextInputLayout=(TextInputLayout)findViewById(R.id.emailTextInputLayout);
    passwordTextInputLayout=(TextInputLayout)findViewById(R.id.passwordTextInputLayout);

    forgotPasswordTextView=(TextView)findViewById(R.id.forgotPasswordTextView);

    signUpButton=(Button)findViewById(R.id.signUpButton);
    signInButton = (Button) findViewById(R.id.signInButton);

    Toast.makeText(this, SharedPrefManager.getInstance(this).getToken(), Toast.LENGTH_SHORT).show();

    progressDialog = new ProgressDialog(this);
    progressDialog.setCanceledOnTouchOutside(false);
    progressDialog.setTitle("Please Wait");
    progressDialog.setMessage("Signing In...");

    signInButton.setOnClickListener(this);
    signUpButton.setOnClickListener(this);
    forgotPasswordTextView.setOnClickListener(this);

    mAuth = FirebaseAuth.getInstance();
    mDatabase = FirebaseDatabase.getInstance().getReference().child("student");

    mAuthListener = new FirebaseAuth.AuthStateListener() {
        @Override
        public void onAuthStateChanged(@NonNull FirebaseAuth firebaseAuth) {
            FirebaseUser user = firebaseAuth.getCurrentUser();
            if (user != null)
            {
                Toast.makeText(SignInActivity.this, user.getEmail(), Toast.LENGTH_SHORT).show();


                if (user.isEmailVerified())
                {
                    Toast.makeText(SignInActivity.this,"arnav",Toast.LENGTH_SHORT).show();

                    mDatabase.addListenerForSingleValueEvent(new ValueEventListener() {
                        @Override
                        public void onDataChange(DataSnapshot dataSnapshot) {
                            for(DataSnapshot ds : dataSnapshot.getChildren())
                            {
                                if (ds.child("email").getValue().equals(mAuth.getCurrentUser().getEmail()))
                                {

                                    student = ds.getValue(Student.class);

                                    String refreshedToken = SharedPrefManager.getInstance(SignInActivity.this).getToken();


Toast.makeText(SignInActivity.this,refreshedToken,Toast.LENGTH_SHORT).show();

                                    student.setToken(refreshedToken);



  mDatabase.child(mAuth.getCurrentUser().getUid()).child
("token").setValue(refreshedToken);

                                    SharedPreferences sharedPreferences = 
getSharedPreferences("STUDENT_FILE_KEY", MODE_PRIVATE);
                                    SharedPreferences.Editor editor = 
sharedPreferences.edit();
                                    Gson gson = new Gson();
                                    String json = gson.toJson(student);
                                    editor.putString("student", json);
                                    editor.apply();

                                    Toast.makeText(SignInActivity.this, 
"Sign in " + student.getName(), Toast.LENGTH_SHORT).show();
                                    progressDialog.dismiss();
                                    Intent intent = new 
Intent(SignInActivity.this, MainActivity.class);
                                    startActivity(intent);
                                    finish();
                                }
                            }
                        }

                        @Override
                        public void onCancelled(DatabaseError databaseError) {

                        }
                    });

                }
                else
                {
                    Toast.makeText(SignInActivity.this, "Kindly Verify your 
Email Id first", Toast.LENGTH_SHORT).show();
                }
            }
        }
    };
}

@Override
public void onClick(View v) {
    switch (v.getId())
    {
        case R.id.signInButton:

            progressDialog.show();

            email = emailTextInputLayout.getEditText().getText().toString();
            password = 
passwordTextInputLayout.getEditText().getText().toString();

            emailTextInputLayout.setErrorEnabled(false);
            passwordTextInputLayout.setErrorEnabled(false);

            if(TextUtils.isEmpty(email))

emailTextInputLayout.setError(getString(R.string.field_cannot_be_empty));
            else if (!isValidEmail(email))

emailTextInputLayout.setError(getString(R.string.invalid_email_id));
            else if(TextUtils.isEmpty(password))

passwordTextInputLayout.setError(getString(R.string.field_cannot_be_empty));
            else
            {
                mAuth.signInWithEmailAndPassword(email, 
password).addOnCompleteListener(new OnCompleteListener<AuthResult>()
                {
                    @Override
                    public void onComplete(@NonNull Task<AuthResult> task)
                    {
                        if(task.isSuccessful())
                        {
                            checkUserExists();
                        }
                        else
                        {
                            Toast.makeText(SignInActivity.this, "Wrong 
email/password", Toast.LENGTH_LONG).show();
                            progressDialog.dismiss();
                        }
                    }
                });
            }
            break;

        case R.id.signUpButton:
            Intent intent1=new 
Intent(SignInActivity.this,SignUpActivity.class);
            startActivity(intent1);
            break;
        case R.id.forgotPasswordTextView:
            LayoutInflater inflater = (LayoutInflater) getSystemService( 
Context.LAYOUT_INFLATER_SERVICE );
            View alertLayout = 
inflater.inflate(R.layout.layout_custom_dialog,null);
            final TextInputLayout emailTextInputLayout = (TextInputLayout) 
alertLayout.findViewById(R.id.emailTextInputLayout);
            final AlertDialog.Builder alert = new 
AlertDialog.Builder(SignInActivity.this);
            alert.setTitle("Forgot Password");
            // this is set the view from XML inside AlertDialog
            alert.setView(alertLayout);
            // disallow cancel of AlertDialog on click of back button and 
outside touch
            alert.setCancelable(true);
            alert.setNegativeButton("Cancel", new 
DialogInterface.OnClickListener() {

                @Override
                public void onClick(DialogInterface dialog, int which) {

                }
            });
            alert.setPositiveButton("Send Email", new DialogInterface.OnClickListener() {

                @Override
                public void onClick(DialogInterface dialog, int which)
                {

                    String email = 
 emailTextInputLayout.getEditText().getText().toString();
                    mAuth.sendPasswordResetEmail(email);
                    Toast.makeText(SignInActivity.this, "Password Reset Mail 
has been sent.", Toast.LENGTH_SHORT).show();
                }
            });
            AlertDialog dialog = alert.create();
            dialog.show();

            break;
    }
}


private boolean isValidEmail(String email) {
    String EMAIL_PATTERN = "^[_A-Za-z0-9-\\+]+(\\.[_A-Za-z0-9-]+)*@"
            + "[A-Za-z0-9-]+(\\.[A-Za-z0-9]+)*(\\.[A-Za-z]{2,})$";

    Pattern pattern = Pattern.compile(EMAIL_PATTERN);
    Matcher matcher = pattern.matcher(email);
    return matcher.matches();

}

private void checkUserExists()
{
    progressDialog.show();
    final String user_id = mAuth.getCurrentUser().getUid();
    mDatabase.addValueEventListener(new ValueEventListener() {
        @Override
        public void onDataChange(DataSnapshot dataSnapshot) {

            if(dataSnapshot.hasChild(user_id))
            {
                FirebaseUser user = 
  FirebaseAuth.getInstance().getCurrentUser();
                if (user.isEmailVerified()) {
                    Intent intent = new Intent(SignInActivity.this, 
  MainActivity.class);
                    startActivity(intent);
                    finish();
                }
                else {
                    Toast.makeText(SignInActivity.this, "Kindly Verify your 
  Email Id", Toast.LENGTH_LONG).show();
                     progressDialog.dismiss();
                }

            }
            else
            {
                progressDialog.dismiss();
                Toast.makeText(SignInActivity.this, "You need to sign up 
 first...", Toast.LENGTH_LONG).show();
            }

        }
        @Override
        public void onCancelled(DatabaseError databaseError) {

        }
    });
}
@Override
public void onStart() {
    super.onStart();
    mAuth.addAuthStateListener(mAuthListener);
}

@Override
public void onStop() {
    super.onStop();
    if (mAuthListener != null) {
        mAuth.removeAuthStateListener(mAuthListener);
    }
}

}

提供权限后,当我打开应用程序时,自动登录可以正常工作,但主要活动崩溃时出现错误令牌异常 - 无法添加窗口。你的活动在运行吗?

这是我的logcat:

02-27 20:16:33.725 10794-10794/com.example.arnav.chatbot E/AndroidRuntime: FATAL EXCEPTION: main
   Process: com.example.arnav.chatbot, PID: 10794
   android.view.WindowManager$BadTokenException: Unable to add window -- token android.os.BinderProxy@7efb1b is not valid; is your activity running?
       at android.view.ViewRootImpl.setView(ViewRootImpl.java:697)
       at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:342)
       at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:93)
       at android.widget.Toast$TN.handleShow(Toast.java:459)
       at android.widget.Toast$TN$2.handleMessage(Toast.java:342)
       at android.os.Handler.dispatchMessage(Handler.java:102)
       at android.os.Looper.loop(Looper.java:154)
       at android.app.ActivityThread.main(ActivityThread.java:6165)
       at java.lang.reflect.Method.invoke(Native Method)
       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:888)
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:778)
       at de.robv.android.xposed.XposedBridge.main(XposedBridge.java:107)

1 个答案:

答案 0 :(得分:0)

尝试使用

select column1, sum(column2 ) from
 (
   select c1 as column1, c2 as column2 from table1
   union all
   select c1 as column1, c2 as column2  from table2
 ) as total
group by column1

而不是

progressDialog = new ProgressDialog(SignInActivity.this);`

转到设置 - &gt;选择应用 ---&gt;再次选择Apps中的设置图标---&gt;选择绘制其他应用程序

选择您的应用程序并启用其他应用程序permition的绘制

如果不起作用意味着你的对话框试图在活动关闭后显示或不在ui线程上显示