美文网首页Android开发之路Android专题Android
SpUtil多样加密存储,兼容android9.0

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

作者: 奔跑的佩恩 | 来源:发表于2019-03-08 18:38 被阅读137次

前言

在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
            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>

然后在 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出来后,加密这块仍然不消停,加密机制切换,导致获取秘钥数组的方式改变,在加密解密的时候,都会用到以下这行代码:

相关文章

网友评论

    本文标题:SpUtil多样加密存储,兼容android9.0

    本文链接:https://www.haomeiwen.com/subject/eigzuqtx.html