Android文件访问权限和路径问题

文件权限类型:

Context.MODE_PRIVATE:为默认操作模式,代表该文件是私有数据,只能被应用本身访问,在该模式下,写入的内容会覆盖原文件的内容,如果想把新写入的内容追加到原文件中。可以使用Context.MODE_APPEND
Context.MODE_APPEND:模式会检查文件是否存在,存在就往文件追加内容,否则就创建新文件。
MODE_WORLD_READABLE:表示当前文件可以被其他应用读取;
MODE_WORLD_WRITEABLE:表示当前文件可以被其他应用写入。
Context.MODE_WORLD_READABLE+Context.MODE_WORLD_WRITEABLE用来控制其他应用是否有权限读写该文件。


例子:

[java]  view plain copy
  1. public void save(String filename, String content) throws Exception{  
  2.           
  3.         FileOutputStream out = context.openFileOutput(filename, Context.MODE_PRIVATE);  
  4.         out.write(content.getBytes());  
  5.         out.close();  
  6.     }  

文件路径:

public File getDir(String name, int mode):name目录名称、mode权限,如果传入的目录不存在,系统会创建此目录,路径为"/data/data/程序Package Name/app_name",name就是传入的name。

public File getFileStreamPath(String name):name为文件名称,所取得的文件必须是放在/data/data/程序
Package Name/files的文件。

public File getFilesDir():取得"/data/data/程序Package Name/files"这个目录的File。

public FileInputStream openFileInput(String name):读取文件,name为文件名不能包含路径,文件的路径为"/data/data/程序Package Name/files",如果文件不存在,将会出现FileNotFoundException。

public FileOutputStream openFileOutput(String name, int mode):写文件,name为文件名不能包含路径,mode为权限,文件的路径为"/data/data/程序Package Name/files"。


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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、付费专栏及课程。

余额充值