Android文件存储
一, 当应用用到拍摄功能时,拍摄照片比较大,保存在数据库不现实,必须保存在私有存储空间,此空间也用来保存数据库文件,将照片文件保存在databases子目录相邻的某个子目录中,这就涉及到文件的存储问题了,本文将简单介绍android的文件存储。
二,1,外部存储目录external与内部存储目录internal
内部存储目录:打开文件管理器,最外层的data目录即为内部存储目录,内部都是app的包名,存储着应用程序相关的数据,例如 data/data/包名/(shared_prefs、database、files、cache),这里面的文件对未root用户不可见,当用户卸载App时,存储在这里的数据也会被销毁。
2,外部存储目录:和内部存储目录data同级的其他目录基本都为外部存储目录,外部存储目录分为私有目录和公有目录,私有目录存储在android文件夹下,各应用数据存储在对应以包为名的目录下,这里的数据不同应用不可共享。与android目录同级的目录为公有目录,这些目录可以由我们自己创建。
三,应用内部存储空间中的应用私有目录和外部存储空间中的应用私有目录和区别。
3,如何获取对应目录呢?
(1)context.getFilesDir() 内部存储data/data/包名/files目录;
(2)context.getCacheDir() 内部存储data/data/包名/cache目录;
(3)Environment.getExternalStorageDirectory() 外部存储根目录 Environment.getExternalStoragePublicDirectory ();
(4)外部存储公有目录context.getExternalFilesDir() 外部存储私有目录storage/sdcard/Android/data/包名/files。一般存储长时间保存的数据。
context.getExternalCacheDir() 外部存储私有目录storage/sdcard/Android/data/包名/cache。一般存储临时缓存数据。
4,内部存储空间私有存储空间:对于设备中每一个安装的 App,系统都会在内部存储空间的 data/data 目录下以应用包名为名字自动创建与之对应的文件夹。这个文件夹用于 App 中的 WebView 缓存页面信息,SharedPreferences 和 SQLiteDatabase 持久化应用相关数据等,普通用户无法查看,应用卸载后所有文件被一同删除。
5,外部存储空间私有存储空间:由于有些文件本身过大,不能全放在内部存储空间,因为这样会造成应用本身数据冗余,过大,所以提供外部存储空间,普通用户可以查看,应用卸载后文件依旧存在,
-
Context 类提供了基本文件和目录处理方法(存储的文件仅供应用内部使用,此法足以)来处理获取并操作内部存储空间下应用私有目录文件的方法。
(1)File getFilesDir() 获取/data/data/<包名>/files目录。
(2)FileInputStream openFileInput(String name):打开现有文件进行读取
(3)FileOutputStream openFileOutPutStream(String name,int mode): 打开文件进行写入,如果不存在就创建它。
(4)File getDir(String name,int mode) 获取/data/data/<包名>目录的子目录(不存在就创建它)。
(5)String[] fileList() *获取主文件目录下的文件列表,可与其它方法配合使用,如openFileInput(String)>。
(6)File getCacheDir() 获取/data/data/<包名>/cache目录,应及时清理该目录,并节约使用。 -
有另一种情况,如果外部相机将拍摄的照片存在应用内部(这种情况属于属于其他应用读写本应用文件的情况)在这种情况下如果共享文件给其它应用或是接受其他应用文件,可通过ContentProvider把要共享的文件暴露出来,ContentProvider允许暴露内容URI给其它应用,其它应用就可以通过URI下载或向其写入文件,同时读写可控。
-
如果只想从其它应用接收一个文件,自己实现ContentProvider就有点费力不讨好了,此时可以使用一个便利类FileProvider,它是ContentProvider的一个子类,只要简单的做做配置就可以,另外**从 7.0 开始,Android SDK 中的 StrictMode策略禁止开发人员在应用外部公开 file:// URI,如果我们在使用 file://URI 时忽视了这两条规定,将导致用户在 7.0 及更高版本系统的设备中使用到相关功能时,出现 FileUriExposedException 异常,导致应用出现崩溃闪退问题。而这两个过程的替代解决方案便是使用 FileProvider。FileProvider帮助我们将访问受限的 file:// URI 转化为可以授权共享的 content:// URI。
FileProvider的使用:
a. 声明FileProvider为ContentProvider,并给予一定权限(及指定一个位置用来保存文件) 在AndroidManifest.xml中添加一个FileProvider声明。
属性介绍:
android:authorities: 标识内容提供器范围内的数据URI的授权列表,有多个授权时,要用分号来分离每个授权.通常为应用包名+ContentProvier子类名称。
android:exported=”false:意味着除了你自己以及你授权的人外其它人不能访问你提供的FileProvider.
Android: grantUriPermission="true":此属性给其它应用授权,容许向你指定的URI写入文件。
Android:name :FileProvide所对应的包名。
b. 接下来配置FileProvider让它知道该暴露哪些文件,在项目窗口右键单击app.res目录new->Android resource file,文件名输入files,接下来将生成的xml文件内容修改为如下。
22.PNG
此配置文件把私有存储空间的根路径映射为crime_photos,这个名字只供FileProvider内部使用。
c. 接下来在AndroidManifest.xml中添加meta-data标签,让FileProvider能找到files.xml文件,在<provider>…</provider>之间加入如下内容
33PNG.PNG
好了,一切准备就绪,现在成功配置好了应用向外不提供的访问路径,此路径有如下关系<files-path>路径下的文件夹可以通过Context.getFilesDir()来访问了。
此处只是对android文件存储进行了简单的介绍,第一次写的不好勿喷,还望各位多多指点
网友评论