前言
在android系统不断升级的过程中,Sharepreferences存储出现多中问题,其中有些是读写权限造成,有些是因为加密问题引起。下面介绍下SpUtil这个工具类,它是在Sharepreferences基础上进行了封装优化,具备存储不同数据类型,然后有加密功能,使用简单,在介绍的工程中,还会涉及到一些权限方面的讲解。
存储数据类型包括:
boolean、int、float、long、String,List,object,其中 存储 String 具备加密功能,在存储 object的时候,object 需要是可序列化的对象
今天涉及的内容有:
- 读写权限及安装权限差异
- 加密差异
- SpUtil 的基本使用
注:具体代码的话,大家可以在"demo大师"官网上搜索《SpUtil多样加密存储,兼容android9.0》这篇文章
效果图
一. 读写权限及安装权限差异
android 6.0以下
在android6.0 以前,我们在设置读写权限的时候,需要在android mainfast.xml中做权限申请:
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
android 6.0开始
在android6.0以后,读写权限增加了动态申请,于是需要用到android动态权限申请,网上这方面知识很多,大家可以搜搜,这里就不详细讲解了。
android 7.0开始
然后到了android7.0增加了 FileProvider 文件权限限制,需要在 mainfast 的配置文件中加入FileProvider注册(注意:provider 和 activity 标签同级,都是 application 标签的子类):
<application>
<provider
android:name="androidx.core.content.FileProvider"
android:authorities="${applicationId}"
android:exported="false"
android:grantUriPermissions="true">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/update_files" />
</provider>
</application>
然后在 res文件夹下建 xml文件 updat_files.xml(文件名自己定义,但是要与上面provider中的 meta-data 标签对应的 resource引用一致)
updat_files.xml文件代码如下:
<?xml version="1.0" encoding="utf-8"?>
<resources>
<paths>
<external-path path="" name="download"/>
</paths>
</resources>
要是项目涉及到自动下载安装的时候,则自动安装代码要改成类似下面这样:
/**
* 安装软件
*
* @param file
*/
private void installApk(File file) {
if (!file.exists()) {
return;
}
Uri uri = null;
Intent install = new Intent(Intent.ACTION_VIEW);
install.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
// UpdateConfig.FILE_PROVIDER_AUTH 即是在清单文件中配置的authorities
uri = FileProvider.getUriForFile(mContext, AUTHORITY_TAG, file);
// 给目标应用一个临时授权
install.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);
} else {
uri = Uri.fromFile(file);
}
install.setDataAndType(uri, "application/vnd.android.package-archive");
mContext.startActivity(install);
}
其中FileProvider.getUriForFile(mContext, AUTHORITY_TAG, file);中的 AUTHORITY_TAG 即为 provider 注册中的 android:authorities 值。
android 8.0开始
此版本开始后,增加了安装未知权限的限制,于是需要在 mainfast.xml中添加安装未知应用的权限:
<uses-permission android:name="android.permission.REQUEST_INSTALL_PACKAGES"/>
二. 加密差异
android 7.0 开始
android7.0之后的加密会出现问题,解决办法的话,之前我已经讲过,大家可以参考我的文章 android-N在AES加密时出现:no such provider: Crypto 的问题
android 9.0 开始
然而在android9.0出来后,加密这块仍然不消停,加密机制切换,导致获取秘钥数组的方式改变,在加密解密的时候,都会用到以下这行代码: