[英]FileNotFoundException while picking images from gallery
I am picking images form Gallery but the following code snippet create the FileNotFoundException. 我正在从Gallery中选择图像,但是以下代码段创建了FileNotFoundException。 Code is fine but I don't know why it raises the exception. 代码很好,但我不知道为什么会引发异常。 Thanks in advance 提前致谢
Here is the Logcat Message: 这是Logcat消息:
Unable to decode stream: java.io.FileNotFoundException: /storage/emulated/0/Pictures/Screenshots/Screenshot_2015-09-15-17-27-49.png: open failed: EACCES (Permission denied) 无法解码流:java.io.FileNotFoundException:/storage/emulated/0/Pictures/Screenshots/Screenshot_2015-09-15-17-27-49.png:打开失败:EACCES(权限被拒绝)
Below is my code 下面是我的代码
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if(requestCode==0010 && resultCode== RESULT_OK && data!=null)
{
Uri selectedImage = data.getData();
String[] filePathColumn = { MediaStore.Images.Media.DATA };
Cursor cursor = getContentResolver().query(selectedImage, filePathColumn, null, null, null);
cursor.moveToFirst();
int columnIndex = cursor.getColumnIndex(filePathColumn[0]);
String imgDecodableString = cursor.getString(columnIndex);
cursor.close();
Testing = (ImageView) findViewById(R.id.testing);
// Set the Image in ImageView after decoding the String
Testing.setImageBitmap(BitmapFactory.decodeFile(imgDecodableString));
} else {
Utility.message(EditProfileActivity.this, "You've not picked image");
}
}
Better use the following class which will return the file path.doesn't matter from where ever you chosen.your code will fail some times for example if your choosing from google drive you might not get the path with the above code.check out.. 最好使用以下类来返回文件路径。无论您选择哪个位置都没有关系。您的代码有时会失败,例如,如果您从google驱动器中选择,则可能无法获得上述代码的路径。 。
import android.annotation.TargetApi;
import android.content.ContentUris;
import android.content.Context;
import android.database.Cursor;
import android.net.Uri;
import android.os.Build;
import android.os.Environment;
import android.provider.DocumentsContract;
import android.provider.MediaStore;
public class FetchPath {
/**
* Get a file path from a Uri. This will get the the path for Storage Access
* Framework Documents, as well as the _data field for the MediaStore and
* other file-based ContentProviders.
*
* @param context The context.
* @param uri The Uri to query.
* @author paulburke
*/
@TargetApi(Build.VERSION_CODES.KITKAT)
public static String getPath(final Context context, final Uri uri) {
final boolean isKitKat = Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT;
// DocumentProvider
if (isKitKat && DocumentsContract.isDocumentUri(context, uri)) {
// ExternalStorageProvider
if (isExternalStorageDocument(uri)) {
final String docId = DocumentsContract.getDocumentId(uri);
final String[] split = docId.split(":");
final String type = split[0];
if ("primary".equalsIgnoreCase(type)) {
return Environment.getExternalStorageDirectory() + "/" + split[1];
}
// TODO handle non-primary volumes
}
// DownloadsProvider
else if (isDownloadsDocument(uri)) {
final String id = DocumentsContract.getDocumentId(uri);
final Uri contentUri = ContentUris.withAppendedId(
Uri.parse("content://downloads/public_downloads"), Long.valueOf(id));
return getDataColumn(context, contentUri, null, null);
}
// MediaProvider
else if (isMediaDocument(uri)) {
final String docId = DocumentsContract.getDocumentId(uri);
final String[] split = docId.split(":");
final String type = split[0];
Uri contentUri = null;
if ("image".equals(type)) {
contentUri = MediaStore.Images.Media.EXTERNAL_CONTENT_URI;
} else if ("video".equals(type)) {
contentUri = MediaStore.Video.Media.EXTERNAL_CONTENT_URI;
} else if ("audio".equals(type)) {
contentUri = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI;
}
final String selection = "_id=?";
final String[] selectionArgs = new String[]{
split[1]
};
return getDataColumn(context, contentUri, selection, selectionArgs);
}
}
// MediaStore (and general)
else if ("content".equalsIgnoreCase(uri.getScheme())) {
// Return the remote address
if (isGooglePhotosUri(uri))
return uri.getLastPathSegment();
return getDataColumn(context, uri, null, null);
}
// File
else if ("file".equalsIgnoreCase(uri.getScheme())) {
return uri.getPath();
}
return null;
}
/**
* Get the value of the data column for this Uri. This is useful for
* MediaStore Uris, and other file-based ContentProviders.
*
* @param context The context.
* @param uri The Uri to query.
* @param selection (Optional) Filter used in the query.
* @param selectionArgs (Optional) Selection arguments used in the query.
* @return The value of the _data column, which is typically a file path.
*/
public static String getDataColumn(Context context, Uri uri, String selection,
String[] selectionArgs) {
Cursor cursor = null;
final String column = "_data";
final String[] projection = {
column
};
try {
cursor = context.getContentResolver().query(uri, projection, selection, selectionArgs,
null);
if (cursor != null && cursor.moveToFirst()) {
final int index = cursor.getColumnIndexOrThrow(column);
return cursor.getString(index);
}
} finally {
if (cursor != null)
cursor.close();
}
return null;
}
/**
* @param uri The Uri to check.
* @return Whether the Uri authority is ExternalStorageProvider.
*/
public static boolean isExternalStorageDocument(Uri uri) {
return "com.android.externalstorage.documents".equals(uri.getAuthority());
}
/**
* @param uri The Uri to check.
* @return Whether the Uri authority is DownloadsProvider.
*/
public static boolean isDownloadsDocument(Uri uri) {
return "com.android.providers.downloads.documents".equals(uri.getAuthority());
}
/**
* @param uri The Uri to check.
* @return Whether the Uri authority is MediaProvider.
*/
public static boolean isMediaDocument(Uri uri) {
return "com.android.providers.media.documents".equals(uri.getAuthority());
}
/**
* @param uri The Uri to check.
* @return Whether the Uri authority is Google Photos.
*/
public static boolean isGooglePhotosUri(Uri uri) {
return "com.google.android.apps.photos.content".equals(uri.getAuthority());
}
}
Usage 用法
Uri photoUri = data.getData();
if (photoUri != null) {
String filePath = FetchPath.getPath(this, photoUri);
}
Gallery Intent 画廊意图
Intent photoPickerIntent = new Intent(Intent.ACTION_PICK);
photoPickerIntent.setType("image/*");
startActivityForResult(photoPickerIntent, requestCode);
在清单中放一行
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
您可能未将所需的权限添加到清单中,而是添加了读取外部存储的用户权限
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
I had the same issue as this one. 我有与此相同的问题。 My code was working all night then upon waking up in the morning nothing seems to be working anymore. 我的代码整夜都在工作,然后在早晨醒来之后似乎再也没有工作了。 I had everything setup even: 我什至设置了所有东西:
Intent 意图
Intent photoPickerIntent = new Intent(Intent.ACTION_PICK); photoPickerIntent.setType("image/*"); // Ensure that there's a gallery to handle the intent if (photoPickerIntent.resolveActivity(getPackageManager()) != null) { // Launch the gallery startActivityForResult(photoPickerIntent, REQUEST_IMAGE_GALLERY); }
onActivityResult: onActivityResult:
Uri imageUri = data.getData(); InputStream imageStream = getContentResolver().openInputStream(imageUri); mResultsBitmap = BitmapFactory.decodeStream(imageStream);
Manifest file: 清单文件:
uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"
So I thought I had it all figured out last night then this morning nothing was working.. My solution: I went to my Samsung Settings->Device Maintenance -> Memory and then ->Storage. 因此,我以为昨晚才知道所有内容,然后今天早上什么也没用。.解决方案:我去了三星设置->设备维护->内存,然后->存储。 I started cleaning up memory and the system works again. 我开始清理内存,系统再次运行。
It seems that it had to do with low memory since I only had 16GB of total memory and just a few GB left remaining 似乎这与内存不足有关,因为我只有16GB的总内存,只剩下了几GB
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.