21

I'm trying to write a file from an Http post reply to a file on the sdcard. Everything works fine until the byte array of data is retrieved.

I've tried setting WRITE_EXTERNAL_STORAGE permission in the manifest and tried many different combinations of tutorials I found on the net.

All I could find was using the openFileOutput("",MODE_WORLD_READABLE) method, of the activity but how my app writes file is by using a thread. Specifically, a thread is invoked from another thread when a file has to be written, so giving an activity object didn't work even though I tried it.

The app has come a long way and I cannot change how the app is currently written.

Please, someone help me?


CODE:

File file = new File(bgdmanip.savLocation);
FileOutputStream filecon = null;
filecon = new FileOutputStream(file);

byte[] myByte;
myByte = Base64Coder.decode(seReply);

bos.write(myByte);
filecon.write(myByte);
myvals = x * 11024;

bgdmanip.savLocation holds the whole files path. seReply is a string reply from HttpPost response. The second set of code is looped with reference to x. The file is created but remains 0 bytes.

jww
  • 97,681
  • 90
  • 411
  • 885
Sumit M Asok
  • 2,950
  • 7
  • 29
  • 38

3 Answers3

29
//------------------------------WRITING DATA TO THE FILE ---------------------------------      

btnWriteSDFile.setOnClickListener(new OnClickListener() 
    {
    public void onClick(View v)
    {       

        try {
            File myFile = new File("/sdcard/mysdfile.txt");
            myFile.createNewFile();
            FileOutputStream fOut = new FileOutputStream(myFile);
            OutputStreamWriter myOutWriter =new OutputStreamWriter(fOut);
            myOutWriter.append(txtData.getText());
            myOutWriter.close();
            fOut.close();
            Toast.makeText(v.getContext(),"Done writing SD 'mysdfile.txt'", Toast.LENGTH_SHORT).show();
            txtData.setText("");
        } 
        catch (Exception e) 
        {
            Toast.makeText(v.getContext(), e.getMessage(),Toast.LENGTH_SHORT).show();
        }
    }


    }); 

//---------------------------READING DATA FROM THE FILE PLACED IN SDCARD-------------------//       
        btnReadSDFile.setOnClickListener(new OnClickListener()
        {

        public void onClick(View v) 
        {

        try {

            File myFile = new File("/sdcard/mysdfile.txt");
            FileInputStream fIn = new FileInputStream(myFile);
            BufferedReader myReader = new BufferedReader(new InputStreamReader(fIn));
            String aDataRow = "";
            String aBuffer = "";
            while ((aDataRow = myReader.readLine()) != null) 
            {
                aBuffer += aDataRow ;
            }
            txtData.setText(aBuffer);
            myReader.close();
            Toast.makeText(v.getContext(),"Done reading SD 'mysdfile.txt'",Toast.LENGTH_SHORT).show();
        } 
        catch (Exception e)
        {
            Toast.makeText(v.getContext(), e.getMessage(),Toast.LENGTH_SHORT).show();
        }
        }
        }); 

ALONG WITH THIS ALSO WRITE THIS PERMISSION IN Android.Manifest

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
Bay
  • 467
  • 7
  • 22
Pir Fahim Shah
  • 10,505
  • 1
  • 82
  • 81
22

The openFileOutput() method writes data to your application's private data area (not the SD card), so that's probably not what you want. You should be able to call Environment.getExternalStorageDirectory() to get the root path to the SD card and use that to create a FileOutputStream. From there, just use the standard java.io routines.

Erich Douglass
  • 51,744
  • 11
  • 75
  • 60
  • Thank Erich. I'm passing the full path as string like this "/sdcard/filename.ext" . also the file was created but the file size remains 0 bytes. also i'm not able to use the push/pull file controls of the DDMS in eclipse. – Sumit M Asok Mar 16 '10 at 14:47
  • You might need to post some of your file writing code to help diagnose the problem. Not everything, but at least the basics of what's going on. Also, are you seeing any messages in LogCat? – Erich Douglass Mar 16 '10 at 15:04
  • Erich, I have updated the code. no messages are created about file ops in LogCat. I changed code lots of time that I got errors in some code but don't recollect which code gave me errors. – Sumit M Asok Mar 17 '10 at 04:07
  • Erich, also i cannot see the push pull buttons in eclipse DDMS. Is this something about why I'm not able to write to file ? I can see the sdcard and files in it but no control buttons mentioned above are visible. – Sumit M Asok Mar 17 '10 at 04:16
3

Here is a sample:

// Log used as debug
File log = new File(Environment.getExternalStorageDirectory(), "Log.txt");
try {
    out = new BufferedWriter(new FileWriter(log.getAbsolutePath(), false));
    out.write(new Date().toString());
    out.write(" : \n");
} catch (Exception e) {
    Log.e(TAG, "Error opening Log.", e);
}
jww
  • 97,681
  • 90
  • 411
  • 885
gtangil
  • 717
  • 7
  • 7