读写应用的data/data的files目录的文件

@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		String valueString = "dfjkdjfkdjfjieurieuriewuorewioreir";
		try {
			writeDateFile("name", valueString.getBytes());
		} catch (Exception e) {
			e.printStackTrace();
		}
		
		try {
			String value = readDateFile("name");
			Log.d("test", "___value__" + value);
			Log.d("test", "___value.length()__" + value.length());
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

	// 将文件写入应用的data/data的files目录下
	public void writeDateFile(String fileName, byte[] buffer) throws Exception {
		byte[] buf = fileName.getBytes("iso8859-1");
		fileName = new String(buf, "utf-8");
		// Context.MODE_PRIVATE:为默认操作模式,代表该文件是私有数据,只能被应用本身访问,在该模式下,写入的内容会覆盖原文件的内容,如果想把新写入的内容追加到原文件中。可以使用Context.MODE_APPEND
		// Context.MODE_APPEND:模式会检查文件是否存在,存在就往文件追加内容,否则就创建新文件。
		// Context.MODE_WORLD_READABLE和Context.MODE_WORLD_WRITEABLE用来控制其他应用是否有权限读写该文件。
		// MODE_WORLD_READABLE:表示当前文件可以被其他应用读取;MODE_WORLD_WRITEABLE:表示当前文件可以被其他应用写入。
		// 如果希望文件被其他应用读和写,可以传入:
		// openFileOutput("output.txt", Context.MODE_WORLD_READABLE +
		// Context.MODE_WORLD_WRITEABLE);
		FileOutputStream fos = FilesDemoActivity.this.openFileOutput(fileName,
				Context.MODE_PRIVATE);// 添加在文件后面
		fos.write(buffer);
		fos.close();
	}

	// 读取应用的data/data的files目录下文件数据
	public String readDateFile(String fileName) throws Exception {
		FileInputStream fis = FilesDemoActivity.this.openFileInput(fileName);
		String result = streamRead(fis);// 返回一个字符串
		return result;
	}

	private String streamRead(InputStream is) throws IOException {
		int buffersize = is.available();// 取得输入流的字节长度
		byte buffer[] = new byte[buffersize ];
		is.read(buffer);// 将数据读入数组
		is.close();// 读取完毕后要关闭流。
		String result = EncodingUtils.getString(buffer, "UTF-8");// 设置取得的数据编码,防止乱码
		return result;
	}

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Android 11 上,由于系统安全性的增强,应用程序需要获得 READ_EXTERNAL_STORAGE 和 WRITE_EXTERNAL_STORAGE 权限才能读取和写入外部存储器中的文件。但是,对于 /data 目录及其子目录,只有具有特权的系统应用程序才能访问。 因此,要在 Android 11 上通过代码读写和删除 /data/misc/keystore/user_0 目录下的文件,您需要运行在特权模式下的系统应用程序。这意味着您需要在设备上 root,或者使用系统签名密钥签署您的应用程序。 如果您的应用程序是系统应用程序或已使用系统签名密钥签署,则可以使用以下代码访问 /data/misc/keystore/user_0 目录: ```java String keystorePath = "/data/misc/keystore/user_0"; File keystoreDir = new File(keystorePath); if (!keystoreDir.exists()) { // 目录不存在 return; } if (!keystoreDir.isDirectory()) { // 不是目录 return; } // 获取目录下的所有文件 File[] keystoreFiles = keystoreDir.listFiles(); if (keystoreFiles == null || keystoreFiles.length == 0) { // 目录为空 return; } // 遍历文件列表,读取、写入或删除文件 for (File keystoreFile : keystoreFiles) { if (keystoreFile.isFile()) { // 读取文件 FileInputStream inputStream = new FileInputStream(keystoreFile); // TODO: 处理文件内容 inputStream.close(); // 写入文件 FileOutputStream outputStream = new FileOutputStream(keystoreFile); // TODO: 写入文件内容 outputStream.close(); // 删除文件 keystoreFile.delete(); } } ``` 需要注意的是,对于 /data/misc/keystore/user_0 目录,您需要确保仅读取、写入和删除应用程序创建的文件,以避免破坏系统的安全性和稳定性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值