File 尝试读取文件时发生IOException

File 尝试读取文件时发生IOException,file,android-4.4-kitkat,File,Android 4.4 Kitkat,我和我的朋友正在为我们的研究开发android应用程序,它的工作原理和KeePass一样 问题是,这个应用程序可以在我的朋友手机上使用安卓4.0.3,而在我的手机上使用安卓4.4.2 KitKat,它不能。为什么? 我可以创建没有异常的数据库文件,但当我尝试登录时,它会抛出IOException。我们认为这个异常可能是由FileInputStream引发的,但我们不知道为什么 以下是出现异常的代码: public void onClickLogon(View view){ _db = n

我和我的朋友正在为我们的研究开发android应用程序,它的工作原理和KeePass一样

问题是,这个应用程序可以在我的朋友手机上使用安卓4.0.3,而在我的手机上使用安卓4.4.2 KitKat,它不能。为什么?

我可以创建没有异常的数据库文件,但当我尝试登录时,它会抛出IOException。我们认为这个异常可能是由FileInputStream引发的,但我们不知道为什么

以下是出现异常的代码:

public void onClickLogon(View view){
    _db = null;
    FileInputStream fis = null;
    try {
        fis = openFileInput(this.login.getText().toString() + ".db");
        _db = (PasswordDatabase) com.example.tomus.passwordwalletbeta.Security.decrypt(fis, this.login.getText().toString(), this.password.getText().toString());
        fis.close();
        if(_db==null){
            this.info.setText("Wrong informations.");
        }
        else {
            Intent intent = new Intent(MainActivity.this, LoggedActivity.class);
            Bundle bundle = new Bundle();
            bundle.putSerializable("db", _db);
            bundle.putString("login", login.getText().toString());
            bundle.putString("password", password.getText().toString());
            intent.putExtras(bundle);
            this.login.setText("");
            this.password.setText("");
            startActivity(intent);
        }
    } catch (InvalidKeyException | NoSuchPaddingException | NoSuchAlgorithmException e) {
        this.info.setText("Wrong informations.");
    } catch (FileNotFoundException e) {
        this.info.setText("FileNotFound");
    } catch (IOException e) {
        this.info.setText("IOException");
    }
}
@编辑:这是错误日志,现在我可以看到文件找不到了。4.4.2中的创建文件或路径是否有任何更改

Process: com.example.tomus.passwordwalletbeta, PID: 5495
java.lang.IllegalStateException: Could not execute method of the activity
        at android.view.View$1.onClick(View.java:3857)
        at android.view.View.performClick(View.java:4487)
        at android.view.View$PerformClick.run(View.java:18746)
        at android.os.Handler.handleCallback(Handler.java:733)
        at android.os.Handler.dispatchMessage(Handler.java:95)
        at android.os.Looper.loop(Looper.java:149)
        at android.app.ActivityThread.main(ActivityThread.java:5077)
        at java.lang.reflect.Method.invokeNative(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:515)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:609)
        at dalvik.system.NativeStart.main(Native Method)
 Caused by: java.lang.reflect.InvocationTargetException
        at java.lang.reflect.Method.invokeNative(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:515)
        at android.view.View$1.onClick(View.java:3852)
        at android.view.View.performClick(View.java:4487)
        at android.view.View$PerformClick.run(View.java:18746)
        at android.os.Handler.handleCallback(Handler.java:733)
        at android.os.Handler.dispatchMessage(Handler.java:95)
        at android.os.Looper.loop(Looper.java:149)
        at android.app.ActivityThread.main(ActivityThread.java:5077)
        at java.lang.reflect.Method.invokeNative(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:515)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:609)
        at dalvik.system.NativeStart.main(Native Method)
Caused by: java.io.StreamCorruptedException
        at java.io.ObjectInputStream.readStreamHeader(ObjectInputStream.java:2070)
        at java.io.ObjectInputStream.<init>(ObjectInputStream.java:371)
        at com.example.tomus.passwordwalletbeta.Security.decrypt(Security.java:82)
        at com.example.tomus.passwordwalletbeta.MainActivity.onClickLogon(MainActivity.java:74)
        at java.lang.reflect.Method.invokeNative(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:515)
        at android.view.View$1.onClick(View.java:3852)
        at android.view.View.performClick(View.java:4487)
        at android.view.View$PerformClick.run(View.java:18746)
        at android.os.Handler.handleCallback(Handler.java:733)
        at android.os.Handler.dispatchMessage(Handler.java:95)
        at android.os.Looper.loop(Looper.java:149)
        at android.app.ActivityThread.main(ActivityThread.java:5077)
        at java.lang.reflect.Method.invokeNative(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:515)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:609)
        at dalvik.system.NativeStart.main(Native Method)
Process:com.example.tomus.passwordwalletbeta,PID:5495
java.lang.IllegalStateException:无法执行活动的方法
在android.view.view$1.onClick上(view.java:3857)
在android.view.view.performClick上(view.java:4487)
在android.view.view$PerformClick.run(view.java:18746)
位于android.os.Handler.handleCallback(Handler.java:733)
位于android.os.Handler.dispatchMessage(Handler.java:95)
位于android.os.Looper.loop(Looper.java:149)
位于android.app.ActivityThread.main(ActivityThread.java:5077)
位于java.lang.reflect.Method.Invokenactive(本机方法)
位于java.lang.reflect.Method.invoke(Method.java:515)
在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)上
位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:609)
在dalvik.system.NativeStart.main(本机方法)
原因:java.lang.reflect.InvocationTargetException
位于java.lang.reflect.Method.Invokenactive(本机方法)
位于java.lang.reflect.Method.invoke(Method.java:515)
在android.view.view$1.onClick上(view.java:3852)
在android.view.view.performClick上(view.java:4487)
在android.view.view$PerformClick.run(view.java:18746)
位于android.os.Handler.handleCallback(Handler.java:733)
位于android.os.Handler.dispatchMessage(Handler.java:95)
位于android.os.Looper.loop(Looper.java:149)
位于android.app.ActivityThread.main(ActivityThread.java:5077)
位于java.lang.reflect.Method.Invokenactive(本机方法)
位于java.lang.reflect.Method.invoke(Method.java:515)
在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)上
位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:609)
在dalvik.system.NativeStart.main(本机方法)
原因:java.io.StreamCorruptedException
位于java.io.ObjectInputStream.readStreamHeader(ObjectInputStream.java:2070)
位于java.io.ObjectInputStream。(ObjectInputStream.java:371)
位于com.example.tomus.passwordwalletbeta.Security.decrypt(Security.java:82)
位于com.example.tomus.passwordwalletbeta.MainActivity.onClickLogon(MainActivity.java:74)
位于java.lang.reflect.Method.Invokenactive(本机方法)
位于java.lang.reflect.Method.invoke(Method.java:515)
在android.view.view$1.onClick上(view.java:3852)
在android.view.view.performClick上(view.java:4487)
在android.view.view$PerformClick.run(view.java:18746)
位于android.os.Handler.handleCallback(Handler.java:733)
位于android.os.Handler.dispatchMessage(Handler.java:95)
位于android.os.Looper.loop(Looper.java:149)
位于android.app.ActivityThread.main(ActivityThread.java:5077)
位于java.lang.reflect.Method.Invokenactive(本机方法)
位于java.lang.reflect.Method.invoke(Method.java:515)
在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)上
位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:609)
在dalvik.system.NativeStart.main(本机方法)

您可以发布异常日志吗?通常来自android的日志文件非常擅长指向错误。你能发布异常日志吗?通常,来自android的日志文件非常擅长指向错误。