2017-04-15 32 views
1

私は数ヶ月前にアプリを書いた。私はAndroid Kitkatでノート2を持っていた(それは大丈夫だった)。私の友人はテストしていました(そして今、彼らはそれを使用しています)、そしてすべては大丈夫です。Androidで.xlsxファイルを開く方法は?

Android Nougat(7.0)で新しい携帯電話を購入しました。 今すぐ.xlsxファイルを開くことができません。 ボタンをクリックすると、このメソッドが使用されます。

private void ReadXLSX() { 
    nameFILE= "OOOO.xlsx"; 
    Intent target = new Intent(Intent.ACTION_VIEW); 
    target.setDataAndType(Uri.fromFile(new File((getExternalFilesDir(Environment.DIRECTORY_DOWNLOADS))+"/"+ nameFILE)), "application/vnd.ms-excel"); 
    target.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP); 

    Log.v("OPEN_FILE_PATH", getExternalFilesDir(Environment.DIRECTORY_DOWNLOADS) + "/" + nameFILE); 
    startActivity(target); 

私がdebbuger使用する場合: を私はここに、そのクラッシュ後

try { 
       mResolvedMethod.invoke(mResolvedContext, v); 
      } catch (IllegalAccessException e) { 
       throw new IllegalStateException(
         "Could not execute non-public method for android:onClick", e); 
      } catch (InvocationTargetException e) { 
       throw new IllegalStateException(
         "Could not execute method for android:onClick", e); 
      } 

私のAndroidManifest.xmlがあります

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

---------- --- EDIT ------------- LOGCAT

04-15 23:20:57.073 22020-22020/com.name.name E/AndroidRuntime: FATAL EXCEPTION: main 
                      Process: com.name.name, PID: 22020 
                      java.lang.IllegalStateException: Could not execute method for android:onClick 
                       at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:293) 
                       at android.view.View.performClick(View.java:5642) 
                       at android.view.View$PerformClick.run(View.java:22338) 
                       at android.os.Handler.handleCallback(Handler.java:751) 
                       at android.os.Handler.dispatchMessage(Handler.java:95) 
                       at android.os.Looper.loop(Looper.java:154) 
                       at android.app.ActivityThread.main(ActivityThread.java:6209) 
                       at java.lang.reflect.Method.invoke(Native Method) 
                       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:865) 
                       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755) 
                      Caused by: java.lang.reflect.InvocationTargetException 
                       at java.lang.reflect.Method.invoke(Native Method) 
                       at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:288) 
                       at android.view.View.performClick(View.java:5642)  
                       at android.view.View$PerformClick.run(View.java:22338)  
                       at android.os.Handler.handleCallback(Handler.java:751)  
                       at android.os.Handler.dispatchMessage(Handler.java:95)  
                       at android.os.Looper.loop(Looper.java:154)  
                       at android.app.ActivityThread.main(ActivityThread.java:6209)  
                       at java.lang.reflect.Method.invoke(Native Method)  
                       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:865)  
                       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755)  
                      Caused by: android.os.FileUriExposedException: file:///storage/emulated/0/Android/data/com.name.name/files/Download/OOOO.xlsx exposed beyond app through Intent.getData() 
                       at android.os.StrictMode.onFileUriExposed(StrictMode.java:1799) 
                       at android.net.Uri.checkFileUriExposed(Uri.java:2346) 
                       at android.content.Intent.prepareToLeaveProcess(Intent.java:8933) 
                       at android.content.Intent.prepareToLeaveProcess(Intent.java:8894) 
                       at android.app.Instrumentation.execStartActivity(Instrumentation.java:1690) 
                       at android.app.Activity.startActivityForResult(Activity.java:4290) 
                       at android.support.v4.app.BaseFragmentActivityJB.startActivityForResult(BaseFragmentActivityJB.java:48) 
                       at android.support.v4.app.FragmentActivity.startActivityForResult(FragmentActivity.java:75) 
                       at android.app.Activity.startActivityForResult(Activity.java:4249) 
                       at android.support.v4.app.FragmentActivity.startActivityForResult(FragmentActivity.java:856) 
                       at android.app.Activity.startActivity(Activity.java:4588) 
                       at android.app.Activity.startActivity(Activity.java:4548) 
                       at com.name.name.MainActivity.OnlyReadFile(MainActivity.java:179) 
                       at com.name.name.MainActivity.onStaff(MainActivity.java:52) 
                       at java.lang.reflect.Method.invoke(Native Method)  
                       at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:288)  
                       at android.view.View.performClick(View.java:5642)  
                       at android.view.View$PerformClick.run(View.java:22338)  
                       at android.os.Handler.handleCallback(Handler.java:751)  
                       at android.os.Handler.dispatchMessage(Handler.java:95)  
                       at android.os.Looper.loop(Looper.java:154)  
                       at android.app.ActivityThread.main(ActivityThread.java:6209)  
                       at java.lang.reflect.Method.invoke(Native Method)  
                       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:865)  
                       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755) 
+0

使用LogCatあなたのクラッシュに関連するJavaスタックトレースを調べるために、開始を依頼する必要があります。https://stackoverflow.com/questions/23353173/unfortunately-myapp-has-stopped-どうすれば解決できますか? – CommonsWare

+0

私の投稿後に編集したLogCat – Dann

+0

https://stackoverflow.com/a/38203793/115145 – CommonsWare

答えて

0

あなたはアプリケーションの権限が

ActivityCompat.requestPermissions(MainActivity.this, new String[]{Manifest.permission.READ_EXTERNAL_STORAGE, Manifest.permission.WRITE_EXTERNAL_STORAGE, 1); 
関連する問題