How can I share multiple files via an Intent?

Related searches

Here is my code, but this is for a single file solution.

Can I share multiple files & uploads like I do for single files below?

Button btn = (Button)findViewById(;

    btn.setOnClickListener(new OnClickListener() {

            public void onClick(View v) {
                Intent intent = new Intent(Intent.ACTION_SEND);

                String path = Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_DOWNLOADS) + "/pic.png";
                File file = new File(path);

                MimeTypeMap type = MimeTypeMap.getSingleton();

                intent.putExtra(Intent.EXTRA_STREAM, Uri.fromFile(file));
                intent.putExtra(Intent.EXTRA_TEXT, "1111"); 

Yes but you'll need to use Intent.ACTION_SEND_MULTIPLE instead of Intent.ACTION_SEND.

Intent intent = new Intent();
intent.putExtra(Intent.EXTRA_SUBJECT, "Here are some files.");
intent.setType("image/jpeg"); /* This example is sharing jpeg images. */

ArrayList<Uri> files = new ArrayList<Uri>();

for(String path : filesToSend /* List of the files you want to send */) {
    File file = new File(path);
    Uri uri = Uri.fromFile(file);

intent.putParcelableArrayListExtra(Intent.EXTRA_STREAM, files);

This could definitely be simplified but I left some lines in so you can break down each step that is needed.

UPDATE: Starting in API 24, sharing file URIs will cause a FileUriExposedException. To remedy this, you can either switch your compileSdkVersion to 23 or lower or you can use content URIs with a FileProvider.

UPDATE (to the update): Google recently announced that new apps and app updates would be required to target one of the latest versions of Android for release to the Play Store. That said, targeting API 23 or lower is no longer a valid option if you plan to release the app to the store. You must go the FileProvider route.

How can I share multiple files via an Intent?, Android Sharing Multiple Files through Intent. Example#. The String List passed as a parameter to the share() method contains the paths of all the files you want� android documentation: Sharing Multiple Files through Intent. Example. The String List passed as a parameter to the share() method contains the paths of all the files you want to share.

Here is little improved version improvised by MCeley's solution. This could be used to send the heterogeneous file list (like image, document and video at same time), for instance uploading downloaded documents, images at same time.

public static void shareMultiple(List<File> files, Context context){

    ArrayList<Uri> uris = new ArrayList<>();
    for(File file: files){
    final Intent intent = new Intent(Intent.ACTION_SEND_MULTIPLE);
    intent.putParcelableArrayListExtra(Intent.EXTRA_STREAM, uris);
    context.startActivity(Intent.createChooser(intent, context.getString(R.string.ids_msg_share)));

Android, You can send content by invoking an implicit intent with ACTION_SEND . setType("image/jpg"); final File photoFile = new File(getFilesDir(), "foo.jpg"); normal sharing intents when sharing multiple content elements as discussed in this bug. Share binary data using the ACTION_SEND action. Set the appropriate MIME type and place a URI to the data in the extra EXTRA_STREAM. This is commonly used to share an image but can be used to share any type of binary content:

If you are sharing a file with another applications on devices running KitKat and above, you will need to provide Uri permissions.

This is how I handle multiple file sharing pre and post KitKat:

//All my paths will temporarily be retrieve into this ArrayList
//PathModel is a simple getter/setter
ArrayList<PathModel> pathList;
//All Uri's are retrieved into this ArrayList
ArrayList<Uri> uriArrayList = null;
//This is important since we are sending multiple files
Intent sharingIntent = new Intent(Intent.ACTION_SEND_MULTIPLE);
//Used temporarily to get Uri references
Uri shareFileUri;

if (android.os.Build.VERSION.SDK_INT < Build.VERSION_CODES.KITKAT) {

    //My paths are stored in SQLite, I retrieve them first
    SQLiteHelper helper = new SQLiteHelper(this);
    pathList = helper.getAllAttachments(viewholderID);

    //Create new instance of the ArrayList where the Uri will be stored
    uriArrayList = new ArrayList<>();

    //Get all paths from my PathModel
    for (PathModel data : pathList) {
        //Create a new file for each path
        File mFile = new File(data.getPath());
        //No need to add Uri permissions for pre-KitKat
        shareFileUri = Uri.fromFile(mFile);
        //Add Uri's to the Array that holds the Uri's

} else {

    //My paths are stored in SQLite, I retrieve them first
    SQLiteHelper helper = new SQLiteHelper(this);
    pathList = helper.getAllAttachments(viewholderID);

    //Create new instance of the ArrayList where the Uri will be stored
    uriArrayList = new ArrayList<>();

    //Get all paths from my PathModel
    for (PathModel data : pathList) {
        //Create a new file for each path
        File mFile = new File(data.getPath());
        //Now we need to grant Uri permissions (kitKat>)
        shareFileUri = FileProvider.getUriForFile(getApplication(), getApplication().getPackageName() + ".provider", mFile);
        //Add Uri's to the Array that holds the Uri's

    //Grant read Uri permissions to the intent


//I know that the files which will be sent will be one of the following
//pass the Array that holds the paths to the files
sharingIntent.putParcelableArrayListExtra(Intent.EXTRA_STREAM, uriArrayList);
//Start intent by creating a chooser
startActivity(Intent.createChooser(sharingIntent, "Share using"));

In my case the paths were stored in SQLite, but the paths can come from wherever.

Sharing Content with Intents, In order to display the Android Sharesheet you need to call Intent. Files can be inserted into the MediaStore using scanFile() after which a content:// To share multiple pieces of content, use the ACTION_SEND_MULTIPLE� This is how you can easily use an ActionBar share icon to activate a ShareIntent. The below focuses on the support ShareActionProvider for use with AppCompatActivity. Note: This is an alternative to using a sharing intent as described in the previous section. You either can use a sharing intent or the provider as described below.

 manifest file outside the applicationTag write these permissions
     <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
     <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> */

    File pictures = Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES);
                            //Get a top-level public external storage directory for placing files of a particular type. 
                            // This is where the user will typically place and manage their own files, 
                            // so you should be careful about what you put here to ensure you don't 
                            // erase their files or get in the way of their own organization...
                            // pulled from Standard directory in which to place pictures that are available to the user to the File object

                            String[] listOfPictures = pictures.list();
                            //Returns an array of strings with the file names in the directory represented by this file. The result is null if this file is not a directory.

                            Uri uri=null; 
                            ArrayList<Uri> arrayList = new ArrayList<>();
                            if (listOfPictures!=null) {
                                for (String name : listOfPictures) {
                                    uri = Uri.parse("file://" + pictures.toString() + "/" + name );
                                Intent intent = new Intent();
                                intent.putExtra(Intent.EXTRA_STREAM, arrayList);
                                //A content: URI holding a stream of data associated with the Intent, used with ACTION_SEND to supply the data being sent.
                                intent.setType("image/*"); //any kind of images can support.
                                chooser = Intent.createChooser(intent, "Send Multiple Images");//choosers title

Sending simple data to other apps, When using an intent to send a file's URI from one app to another, you must be careful to get an URI that other apps can read. Doing so on� will take some weeks until I can continue and add target sdk >23 file sharing support using FileProvider. next week I'll add support the other way: HowTo provide the App to others as share target - there are also some traps HowTo deal with the multi instances of the app on Android and I have to figure out HowTo do it from iOS.

Sharing a file, Allow editing - When you share items with this type of link, people can edit files, can add files in a shared folder, and can delete files in a shared folder if they're signed in. Recipients can forward the link, change the list of people sharing the files or folder, and change permissions for recipients. If you're sharing a folder, people with

I have a list of files in my android app and I want to be able to get the selected items and send them via email or any other sharing app. Here is my code. Intent sendIntent = new Intent();

Yes, after getting the ResolveInfo for each Intent via PackageManager.queryIntentActivities(), you can compare their package names via ResolveInfo.activityInfo.packageName and filter out duplicates. – Ken Aug 22 '13 at 21:00

  • unfortunately this seems not working while sharing multiple picture on facebook. I was able to make it working using the solution described in this post:…
  • What about sending different file types image/* and video/*?
  • Should work the same way. You'd just have to change the setType() call to have the proper data type.
  • Set the type something like this to send different file types intent.setType("*/*"); this would help in a situation where you want to send heterogeneous file types (like sending to Google Drive or Dropbox etc.)
  • A trivia for you: file sharing on Android has been designed by the devil himself.
  • Thanks! It's worth noting that in most cases I've tried you can have a heterogeneous file list.. basically the mime type simply limits app responses to those apps capable of handling the type specified, eg. if you specify "text/*" google photos won't respond. But gmail will respond and the list can include images, which will be correctly handled.