IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> Android 证书安装流程分析 -> 正文阅读

[移动开发]Android 证书安装流程分析

一.证书在源码中的路径

5.1系统证书(命名是 openssl x509 -subject_hash_old -in filename)
libcore/luni/src/main/files/cacerts

7.1及以后系统证书
/system/ca-certificates/files

二.证书在固件中的路径

/system/etc/security/cacerts

三.手动安装流程

设置-->安全-->从SD卡安装证书:
在AndroidManif.xml里

<Preference android:key="credentials_install"
? ? ? ? android:title="@string/credentials_install"
? ? ? ? android:summary="@string/credentials_install_summary"
? ? ? ? android:persistent="false">
? ? <intent android:action="android.credentials.INSTALL"
? ? ? ? ? ? android:targetPackage="com.android.certinstaller"
? ? ? ? ? ? android:targetClass="com.android.certinstaller.CertInstallerMain"/>
</Preference>

packages/apps/CertInstaller
CertInstallerMain打开Document,选择证书文件,选择好后。启动CerInstaller
然后根据证书类型区分createPkcs12PasswordDialog和createNameCredentialDialog,看个简单的createNameCredentialDialog

try {
? ? startActivityForResult(
? ? ? ? ? ? mCredentials.createSystemInstallIntent(), ? //Intent intent = new Intent("com.android.credentials.INSTALL");
? ? ? ? ? ? REQUEST_SYSTEM_INSTALL_CODE);
} catch (ActivityNotFoundException e) {
? ? Log.w(TAG, "systemInstall(): " + e);
? ? toastErrorAndFinish(R.string.cert_not_saved);
}

看intent,又到了Settings的CredentialStorage

Settings/src/com/android/settings/CredentialStorage.java ? ?installIfAvailable
添加证书:Settings/src/com/android/settings/CredentialStorage.java ? ?installIfAvailable()
删除证书:Settings/src/com/android/settings/TrustedCredentialsSettings.java ? AliasOperation#doInBackground
显示证书:Settings/src/com/android/settings/TrustedCredentialsSettings.java ? AdapterData#AliasLoader#doInBackground ??
证书内容:Settings/src/com/android/settings/TrustedCredentialsSettings.java ?CertHolder ?SslCertificate

安装类型两种: userKey和Ca证书(pk12要处理密码)
CertInstaller\src\com\android\certinstaller\CredentialHelper.java

异常码:
机器未设置密码锁
机器未解锁
锁屏方式不符合要求还是packages/apps/CertInstaller/CertInstallerMain,startActivityForResult结果回调

if (requestCode == REQUEST_SYSTEM_INSTALL_CODE) {
? ? if (resultCode == RESULT_OK) {
? ? ? ? Log.d(TAG, "credential is added: " + mCredentials.getName());
? ? ? ? Toast.makeText(this, getString(R.string.cert_is_added,
? ? ? ? ? ? ? ? mCredentials.getName()), Toast.LENGTH_LONG).show();

? ? ? ? if (mCredentials.hasCaCerts()) {
? ? ? ? ? ? // more work to do, don't finish just yet
? ? ? ? ? ? new InstallCaCertsToKeyChainTask().execute();
? ? ? ? ? ? return;
? ? ? ? }
? ? ? ? setResult(RESULT_OK);
? ? } else {
? ? ? ? Log.d(TAG, "credential not saved, err: " + resultCode);
? ? ? ? toastErrorAndFinish(R.string.cert_not_saved);
? ? }
}


如果是CaCerts,还要进行 new InstallCaCertsToKeyChainTask().execute() --> mCredentials.installCaCertsToKeyChain --> keyChainService.installCaCertificate
keyChainService实现在packages/apps/KeyChain ?mTrustedCertificateStore.installCertificate
external/conscrypt/src/platform/java/org/conscrypt/TrustedCertificateStore ? installCertificate --> writeCertificate


四.c层
system/security/keystore/keystore.cpp

添加证书 ?installIfAvailable -> mKeyStore.put -> mBinder.insert (这里还是java层)
? ? ? ? ? ? ? ? ? ? -> KeyStoreProxy::insert -> KeyStore::put ?(这里getEncryptionKey用到一个AESkey,哪里来的?)

五.为什么要锁屏密码
以设置密码为例
Settings/src/com/android/settings/ChooseLockPassword.java ?mLockPatternUtils.saveLockPassword
frameworks/base/core/java/com/android/internal/widget/LockPatternUtils.java ?getLockSettings().setLockPassword
frameworks/base/services/core/java/com/android/server/LockSettingsService.java ?setLockPassword -> maybeUpdateKeystore ?-> ks.passwordUid
? ? -> 到keystore.cpp的password_uid?
? ??
password_uid 有三种状态,其中STATE_UNINITIALIZED和STATE_LOCKED都会调用setupMasterKeys,经锁屏密码设置AESkey
这里就解答了添加证书时的AESKey是哪来的

这个是基于Android5.1分析的,高版本可能文件名不同,但是知道大概位置,搜索下,应该没什么难度
? ? ? ??


?

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2021-12-07 12:09:34  更:2021-12-07 12:09:42 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 7:38:59-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码