android 写文件权限

首先,在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/

 
 
  1. FileReader file = new FileReader("Android.txt"); 

这里特别强调私有数据!言外之意是如果某个文件或者数据不是程序私有的,既访问它时无须经过Android的权限检查,那么还是可以用java的io api来直接访问的。所谓的非私有数据是只放在sdcard上的文件或者数据,可以用java的io api来直接打开sdcard上文件。

 
 
  1. FileReader file = new FileReader("/sdcard/Android.txt"); 

如果要打开程序自己私有的文件和数据,那必须使用Activity提供openFileOutput和openFileInput方法。

创建程序私有的文件,由于权限方面的要求,必须使用activity提供的Android读写文件方法

 
 
  1. FileOutputStream os = this.openFileOutput("Android.txt", MODE_PRIVATE);  
  2. OutputStreamWriter outWriter = new OutputStreamWriter (os); 

读取程序私有的文件,由于权限方面的要求,必须使用activity提供的方法

 
 
  1. FileInputStream os =this.openFileInput("Android.txt");  
  2. InputStreamReader inReader = new InputStreamReader(os);
permission
位置0: - :代表文件 ; d: 代表目录
位置1-3 :当前用户 r可读 w可写 x 可执行
位置4-6 : 当前用户所在的组
位置7-9 : 其他的用户的权限
Android中,文件权限是指应用程序获得在设备上创建、修改或删除文件的能力。可以通过在AndroidManifest.xml文件中声明权限来获取文件权限,例如: <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> 使用此权限,应用程序可以在外部存储设备(如SD卡)上创建、修改或删除文件。但自Android 4.4(API级别19)开始,入外部存储的应用程序必须请求额外的权限,即WRITE_EXTERNAL_STORAGE不再授予应用的默认权限。 在应用程序中,可以通过以下方式检查和请求文件权限: 1. 检查权限: 可以使用ContextCompat.checkSelfPermission()方法来检查应用是否具有文件权限,代码示例如下: if (ContextCompat.checkSelfPermission(this, Manifest.permission.WRITE_EXTERNAL_STORAGE) == PackageManager.PERMISSION_GRANTED) { // 已经具有文件权限,可以执行文件操作 } else { // 没有文件权限需要申请权限 } 2. 请求权限: 可以使用ActivityCompat.requestPermissions()方法来请求文件权限,代码示例如下: ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE}, requestCode); 在请求权限时,可以传递一个请求码用于标识此次请求,同时需要在Activity的onRequestPermissionsResult()方法中处理权限请求结果。 需要注意的是,为了提高应用程序的安全性,应该遵循权限最小化原则,即只请求应用程序所需的最少权限。同时,在进行文件操作时,还需要注意文件路径的获取和权限检查,以确保在访问文件时不会发生权限异常或造成数据丢失等问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值