首先,在manifest.xml中添加user permission:
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"></uses-permission>
代碼中,
String path = "http://192.168.1.22:8088/4";
URL url = new URL(path);
URLConnection cn = url.openConnection();
cn.connect();
InputStream stream = cn.getInputStream();
if (stream == null)
throw new RuntimeException("stream is null");
File temp = new File("/data/data/com.dilifetech/mediaplayertmp");//com.dilifetech是package name
temp.createNewFile();
String tempPath = temp.getAbsolutePath();
FileOutputStream out = new FileOutputStream(temp);
byte buf[] = new byte[128];
do {
int numread = stream.read(buf);
if (numread <= 0)
break;
out.write(buf, 0, numread);
} while (true);
mp.setDataSource(tempPath);
stream.close();
android系統中的檔案許可權:
Android有一套自己的安全模型, 具體可參見Android開發文檔。當應用程式(.apk)在安裝時就會分配一個userid,當該應用要去訪問其他資源比如檔案的時候,就需要userid匹配。預設情況下 ,任何應用建立的檔案,資料庫, sharedpreferences都應該是私人的(位於/data/data/your_project/files/),其餘程式無法訪問。除非在建立時指明是MODE_WORLD_READABLE 或者 MODE_WORLD_WRITEABLE,只要這樣其餘程式才能正確訪問。
因為有這種Android讀寫檔案的方法在安全上有所保障,進程開啟檔案時Android要求檢查進程的user id。所以不能直接用java的api來開啟,因為java的io函數沒有提這個機制 。無法用java的api直接開啟程式私人的資料 ,預設路徑為/data/data/your_project/files/
FileReader file = new FileReader("Android.txt");
這裡特彆強調私人資料!言外之意是如果某個檔案或者資料不是程式私人的,既訪問它時無須經過Android的許可權檢查,那麼還是可以用java的io api來直接存取的。所謂的非私人資料是只放在sdcard上的檔案或者資料,可以用java的io api來直接開啟sdcard上檔案。
FileReader file = new FileReader("/sdcard/Android.txt");
如果要開啟程式自己私人的檔案和資料,那必須使用Activity提供openFileOutput和openFileInput方法。
建立程式私人的檔案,由於許可權方面的要求,必須使用activity提供的Android讀寫檔案方法
FileOutputStream os = this.openFileOutput("Android.txt", MODE_PRIVATE); OutputStreamWriter outWriter = new OutputStreamWriter (os);
讀取程式私人的檔案,由於許可權方面的要求,必須使用activity提供的方法
FileInputStream os =this.openFileInput("Android.txt"); InputStreamReader inReader = new InputStreamReader(os);