Java 即使文件夹存在,file.listFiles()也返回null
我在onCreate中有这个活动类我正在检查文件是否存在它是否存在,我编写了请求外部读取权限的代码,我甚至在清单中添加了权限,但onCreate中的代码使应用程序崩溃,说files.length为null,我向用户授予权限后,应用程序崩溃,因为执行了获取文件列表的代码Java 即使文件夹存在,file.listFiles()也返回null,java,android,file,io,Java,Android,File,Io,我在onCreate中有这个活动类我正在检查文件是否存在它是否存在,我编写了请求外部读取权限的代码,我甚至在清单中添加了权限,但onCreate中的代码使应用程序崩溃,说files.length为null,我向用户授予权限后,应用程序崩溃,因为执行了获取文件列表的代码 package com.example.instantshare.UI.Activities; import android.Manifest; import android.content.Context; import an
package com.example.instantshare.UI.Activities;
import android.Manifest;
import android.content.Context;
import android.content.pm.PackageManager;
import android.graphics.Typeface;
import android.os.Bundle;
import android.os.Environment;
import android.util.Log;
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;
import androidx.core.content.ContextCompat;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;
import com.example.instantshare.R;
import com.example.instantshare.UI.Helpers.FileExplorerHelper;
import com.example.instantshare.UI.Models.FileItem;
import com.example.instantshare.UI.UIComponents.FileListRecyclerViewAdapter;
import com.faraji.environment3.Device;
import com.faraji.environment3.Environment3;
import java.io.File;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashSet;
import java.util.Iterator;
public class FilePickerActivity extends AppCompatActivity {
private static final String TAG = "FilePickerActivity";
private final int REQUEST_CODE = 1;
private static final ArrayList<FileItem> list = new ArrayList<>();
private static Context context;
// View variables
static RecyclerView fileListRecyclerView;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_file_picker);
init();
final String rawExternalStorage = System.getenv("EXTERNAL_STORAGE");
File file = new File("/sdcard/Android");
Log.d(TAG, "onCreate: " + file.isDirectory() + " " + file.exists());
File[] files = file.listFiles();
Log.d(TAG, "onCreate: " + files.length);
}
private void init(){
fileListRecyclerView = findViewById(R.id.file_list_recycler_view);
context = FilePickerActivity.this;
if(ContextCompat.checkSelfPermission(this, Manifest.permission.READ_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED || ActivityCompat.checkSelfPermission(this,Manifest.permission.WRITE_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED){
ActivityCompat.requestPermissions(this,new String[]{Manifest.permission.READ_EXTERNAL_STORAGE,Manifest.permission.WRITE_EXTERNAL_STORAGE},REQUEST_CODE);
}
else{
readFileInit();
}
}
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
switch (requestCode){
case REQUEST_CODE:
{
if(grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED){
readFileInit();
}
else{
finish();
}
}
}
}
private void readFileInit(){
FileItem internalStorage = new FileItem("Internal Storage","","internal_storage","internal_storage", Environment.getExternalStorageDirectory().getAbsolutePath(),"",true,false,false);
list.add(internalStorage);
try {
File storage = Environment3.getSecondaryExternalStorage().getFile();
FileItem externalStorage = new FileItem(storage.getName(),"","external_storage","external_storage", storage.getAbsolutePath(),"",true,false,false);
Log.d(TAG, "readFileInit: " + externalStorage.getPath());
list.add(externalStorage);
}
catch (Exception e){
e.printStackTrace();
}
FileListRecyclerViewAdapter fileListRecyclerViewAdapter = new FileListRecyclerViewAdapter(this,list);
fileListRecyclerView.setLayoutManager(new LinearLayoutManager(this));
fileListRecyclerView.setAdapter(fileListRecyclerViewAdapter);
}
public static void clickedItem(FileItem fileItem){
if (fileItem.getStorage() ){
File directory = new File(fileItem.getPath());
File[] files = directory.listFiles();
Log.d(TAG, "clickedItem: " + files.length);
for(int i = 0; i < files.length; i++){
FileItem list_item = new FileItem();
File file = files[i];
list_item.setName(file.getName());
list_item.setDirectory(file.isDirectory());
list_item.setFile(file.isFile());
list_item.setStorage(false);
list_item.setLastModified(new Date(file.lastModified()).toString());
list_item.setPath(file.getAbsolutePath());
list_item.setExtension(file.getName().split(".")[1]);
list_item.setType(getFileType());
list.add(list_item);
}
FileListRecyclerViewAdapter fileListRecyclerViewAdapter = new FileListRecyclerViewAdapter(context,list);
fileListRecyclerView.setAdapter(fileListRecyclerViewAdapter);
}
else if(fileItem.getDirectory()){
File directory = new File(fileItem.getPath());
File[] files = directory.listFiles();
for(int i = 0; i < files.length; i++){
FileItem list_item = new FileItem();
File file = files[i];
list_item.setName(file.getName());
list_item.setDirectory(file.isDirectory());
list_item.setFile(file.isFile());
list_item.setStorage(false);
list_item.setLastModified(new Date(file.lastModified()).toString());
list_item.setPath(file.getAbsolutePath());
list_item.setExtension(file.getName().split(".")[1]);
list_item.setType(getFileType());
list.add(list_item);
}
FileListRecyclerViewAdapter fileListRecyclerViewAdapter = new FileListRecyclerViewAdapter(context,list);
fileListRecyclerView.setAdapter(fileListRecyclerViewAdapter);
}
else{
return;
}
}
private static String getFileType(){
return "";
}
}
为了访问这些文件,必须在清单文件中授予权限
将其添加到MainActivity.java中(不在同一类中,因为它在安装应用程序时不会第一次工作,因为它不是异步的)
试试这个:
String path = Environment.getExternalStorageDirectory().getAbsolutePath()+"/Android";
Log.d("Files", "Path: " + path);
File directory = new File(path);
File[] files = directory.listFiles();
if (files != null)
{
Log.d("Files", "Size: "+ files.length);
for (int i = 0; i < files.length; i++)
{
Log.d("Files", "FileName:" + files[i].getName());
}
}
如果您对此有任何问题,请告诉我。
requestPermissions()
不是阻塞调用。当onCreate()
开始执行文件I/O时,您还没有权限。即使它在第二次运行时拥有权限,它也会崩溃“It crash”--请编辑您的问题,并提供导致崩溃的异常的完整堆栈跟踪。检查堆栈跟踪应该更详细。在你的问题中,重要的部分被切掉了。使用String path=Environment.getExternalStorageDirectory().toString()+“/Android”;文件=新文件(路径)
而不是您的文件File=新文件(“/sdcard/Android”);不,没有帮助面对同样的崩溃吗?@RohanKeskar18现在检查一下,它对meWell工作正常……它没有崩溃,但也没有显示任何文件
2020-02-24 20:39:33.936 10270-10270/com.example.instantshare D/AndroidRuntime: Shutting down VM
2020-02-24 20:39:33.944 10270-10270/com.example.instantshare E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.instantshare, PID: 10270
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.instantshare/com.example.instantshare.UI.Activities.FilePickerActivity}: java.lang.NullPointerException: Attempt to get length of null array
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3344)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3488)
at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:83)
at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)
at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2049)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loop(Looper.java:216)
at android.app.ActivityThread.main(ActivityThread.java:7506)
at java.lang.reflect.Method.invoke(Native Method)
at com.an
2020-02-24 20:39:34.060 10270-10270/com.example.instantshare I/Process: Sending signal. PID: 10270 SIG: 9
checkPermissionReadStorage(this);
String path = Environment.getExternalStorageDirectory().getAbsolutePath()+"/Android";
Log.d("Files", "Path: " + path);
File directory = new File(path);
File[] files = directory.listFiles();
if (files != null)
{
Log.d("Files", "Size: "+ files.length);
for (int i = 0; i < files.length; i++)
{
Log.d("Files", "FileName:" + files[i].getName());
}
}
public static void checkPermissionReadStorage(Activity activity) {
if (ContextCompat.checkSelfPermission(activity,
Manifest.permission.READ_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) {
if (!ActivityCompat.shouldShowRequestPermissionRationale(activity,
Manifest.permission.READ_EXTERNAL_STORAGE)) {
ActivityCompat.requestPermissions(activity,
new String[]{Manifest.permission.READ_EXTERNAL_STORAGE},
1);
}
}
}