0

I want to save some file in a subfolder of SDCard Documents folder. I've read many posts, finally I don't have any exception, it seems the file store is fine, but i still cannot see the folder, nor the files, when i connect the phone to the comp.

EDIT

this occurs only on the device, on emulator, the file is created

I've granted permission in manifest file

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

I've asked for write permission from the user, and it is granted. This post This post helped me in granting permission

here is my code

    if (!Environment.getExternalStorageState().equalsIgnoreCase(Environment.MEDIA_MOUNTED)) {
        Toast.makeText(_ctx, "There is no external storage", Toast.LENGTH_LONG).show();
    } else {
        File docfolder = Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_DOCUMENTS);
        docfolder.mkdirs();
        if (!docfolder.exists()) {
            Toast.makeText(_ctx, "Documents doesn't exist", Toast.LENGTH_LONG).show();
        }
        File folder = new File(docfolder, foldername);
        folder.mkdirs(); //make if not exist

        boolean isPresent = folder.exists();
        if (isPresent) {
            File file = new File(folder.getAbsolutePath(), filename);

            try {
                OutputStream os = new FileOutputStream(file);
                os.write(xml.getBytes());
                os.close();
            } catch (IOException e) {
                Toast.makeText(_ctx, e.toString(), Toast.LENGTH_LONG).show();

                Log.w("ExternalStorage", "Error writing " + file, e);
            }
            catch (Exception e) {
                Toast.makeText(_ctx, e.toString(), Toast.LENGTH_LONG).show();

                Log.w("ExternalStorage", "Error writing 2 " + file, e);
            }
        } else {
            Toast.makeText(_ctx, "cannot make directory " + foldername, Toast.LENGTH_LONG).show();
            Log.w("ExternalStorage", "cannot make directory " + foldername);
        }

any hint is welcomed!

EDIT

maybe the issue could be that this code saves file into that path?

/storage/emulated/0/Documents/IBHTrack/ibhTrack_GPX_20170706153858.xml

however since i use the Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_DOCUMENTS) method, i don't know how to get the real SDCard path

Community
  • 1
  • 1
pillesoft
  • 466
  • 1
  • 5
  • 20
  • https://stackoverflow.com/questions/32789157/how-to-write-files-to-external-public-storage-in-android-so-that-they-are-visibl – CommonsWare Jul 06 '17 at 12:39
  • Possible duplicate of [How to write files to external public storage in Android so that they are visible from Windows?](https://stackoverflow.com/questions/32789157/how-to-write-files-to-external-public-storage-in-android-so-that-they-are-visibl) – Sanoop Surendran Jul 06 '17 at 12:45
  • thanks, but is seems the mediascanner didn't help me. – pillesoft Jul 06 '17 at 13:18

1 Answers1

0

Firstly check permissions:

 void checkPermission(Activity thisActivity){
        // Here, thisActivity is the current activity
        if (ContextCompat.checkSelfPermission(thisActivity,
                Manifest.permission.WRITE_EXTERNAL_STORAGE)
                != PackageManager.PERMISSION_GRANTED) {
            // Should we show an explanation?
            if (ActivityCompat.shouldShowRequestPermissionRationale(thisActivity,
                    Manifest.permission.WRITE_EXTERNAL_STORAGE)) {
                // Show an explanation to the user *asynchronously* -- don't block
                // this thread waiting for the user's response! After the user
                // sees the explanation, try again to request the permission.
                Toast.makeText(MainActivity.this,"Permission denied, now log will not write in storage.",Toast.LENGTH_SHORT).show();

            } else {
                // No explanation needed, we can request the permission.
                ActivityCompat.requestPermissions(thisActivity,
                        new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},
                        101);

            }
        }else {
                processFileLog(messageForLog);

        }
    }

Then Handle response of permission:

@Override
    public void onRequestPermissionsResult(int requestCode,String permissions[], int[] grantResults) {
        switch (requestCode) {
            case 101: {
                // If request is cancelled, the result arrays are empty.
                if (grantResults.length > 0
                        && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                    processFileLog(messageForLog);
                } else {
                    // permission denied, boo! Disable the
                    // functionality that depends on this permission.
                    Toast.makeText(MainActivity.this,"Permission denied, now log will not write in storage.",Toast.LENGTH_SHORT).show();

                }
                return;
            }

            // other 'case' lines to check for other
            // permissions this app might request
        }
    }

With this method you can log your data into file:

 /**
     * Tag value
     */
    private static final String mTag = "Logs";

    /**
     * File
     */
    private static File mLogFolder = null;

    private static void writeLog() {
        if (isExternalStorageWritable()) {
            mLogFolder = new File(Environment.getExternalStorageDirectory().getAbsolutePath() +
                    "/app-client-logs");
            if (!mLogFolder.exists()) {
                if (!mLogFolder.mkdirs()) {
                    System.out.println("Unable to create the log folder");
                }
            }
        } else {
            System.out.println("SD Card not available for read and write");
        }
    }

    public static void processFileLog(final String message) {
        writeLog();
        File file = new File(mLogFolder, mTag + ".log");
        try {
            BufferedWriter buf = new BufferedWriter(new FileWriter(file, true));
            String currentDateTimeString = DateFormat.getDateTimeInstance().format(System.currentTimeMillis());
            buf.append("\nSafety Net Request "+currentDateTimeString).append(":\n").append(message);
            buf.newLine();
            buf.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
Chetan Pushpad
  • 395
  • 1
  • 9