经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 移动开发 » Android » 查看文章
Android证书安装过程介绍
来源:jb51  时间:2021/12/8 17:00:50  对本文有异议

一.证书在源码中的路径

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里

  1. <Preference android:key="credentials_install"
  2. android:title="@string/credentials_install"
  3. android:summary="@string/credentials_install_summary"
  4. android:persistent="false">
  5. <intent android:action="android.credentials.INSTALL"
  6. android:targetPackage="com.android.certinstaller"
  7. android:targetClass="com.android.certinstaller.CertInstallerMain"/>
  8. </Preference>

packages/apps/CertInstaller

CertInstallerMain打开Document,选择证书文件,选择好后。启动CerInstaller

然后根据证书类型区分createPkcs12PasswordDialog和createNameCredentialDialog,看个简单的createNameCredentialDialog

  1. try {
  2. startActivityForResult(
  3. mCredentials.createSystemInstallIntent(), //Intent intent = new Intent("com.android.credentials.INSTALL");
  4. REQUEST_SYSTEM_INSTALL_CODE);
  5. } catch (ActivityNotFoundException e) {
  6. Log.w(TAG, "systemInstall(): " + e);
  7. toastErrorAndFinish(R.string.cert_not_saved);
  8. }

看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结果回调

  1. if (requestCode == REQUEST_SYSTEM_INSTALL_CODE) {
  2. if (resultCode == RESULT_OK) {
  3. Log.d(TAG, "credential is added: " + mCredentials.getName());
  4. Toast.makeText(this, getString(R.string.cert_is_added,
  5. mCredentials.getName()), Toast.LENGTH_LONG).show();
  6. if (mCredentials.hasCaCerts()) {
  7. // more work to do, don't finish just yet
  8. new InstallCaCertsToKeyChainTask().execute();
  9. return;
  10. }
  11. setResult(RESULT_OK);
  12. } else {
  13. Log.d(TAG, "credential not saved, err: " + resultCode);
  14. toastErrorAndFinish(R.string.cert_not_saved);
  15. }
  16. }

如果是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分析的,高版本可能文件名不同,但是知道大概位置,搜索下,应该没什么难度? ? ? ??

到此这篇关于Android证书安装过程介绍的文章就介绍到这了,更多相关Android证书安装内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号