android开发SpUtil多样加密存储,兼容android9.0

释放双眼,带上耳机,听听看~!

前言

在android系统不断升级的过程中,Sharepreferences存储出现多中问题,其中有些是读写权限造成,有些是因为加密问题引起。下面介绍下SpUtil这个工具类,它是在Sharepreferences基础上进行了封装优化,具备存储不同数据类型,然后有加密功能,使用简单,在介绍的工程中,还会涉及到一些权限方面的讲解。
存储数据类型包括:
boolean、int、float、long、String,List,object,其中 存储 String 具备加密功能,在存储 object的时候,object 需要是可序列化的对象

今天涉及的内容有:

  1. 读写权限及安装权限差异
  2. 加密差异
  3. SpUtil 的基本使用
    注:具体代码的话,大家可以在”demo大师”官网上搜索《SpUtil多样加密存储,兼容android9.0》这篇文章
效果图
image.png
一. 读写权限及安装权限差异
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出来后,加密这块仍然不消停,加密机制切换,导致获取秘钥数组的方式改变,在加密解密的时候,都会用到以下这行代码:

人已赞赏
Android文章

Android开发vim编辑器的使用介绍

2020-1-31 11:57:04

Android文章

Android开发实现两种进度条的效果

2020-1-31 13:30:28

个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
有新消息 消息中心
搜索