Android 禁止第三方应用安装

一、禁止手动安装(下载的apk文件)

framwork/base/packages/PackageInstaller/src/com/android/packageinstaller/InstallStart.java 
@@ -37,7 +37,7 @@ import android.os.UserManager;
import android.util.Log;
import java.util.Arrays;
-
+import android.widget.Toast;
/**
  * Select which activity is the first visible activity of the installation and forward the intent to
  * it.
**/
@@ -50,6 +50,8 @@ public class InstallStart extends Activity {
     private UserManager mUserManager;
     private boolean mAbortInstall = false;
+    private boolean APK_INSTALL_FINISH = false; 
+
     @Override
     protected void onCreate(@Nullable Bundle savedInstanceState) {
         super.onCreate(savedInstanceState);
@@ -140,7 +142,18 @@ public class InstallStart extends Activity {
         }
         if (nextActivity != null) {
-            startActivity(nextActivity);
+            //add ban apk install begin {//@
+            if(!APK_INSTALL_FINISH) {  
+                //startActivity(nextActivity);
+                Toast.makeText(InstallStart.this, "禁止安装", Toast.LENGTH_LONG).show();
+                Intent result = new Intent();
+                 result.putExtra(Intent.EXTRA_INSTALL_RESULT,
+                PackageManager.INSTALL_FAILED_INVALID_URI);
+                setResult(RESULT_FIRST_USER, result);
+            } else{
+                startActivity(nextActivity);
+            }
+            //@}
         }
         finish();
     }

二、禁止adb指令安装

diff --git a/services/core/java/com/android/server/pm/PackageManagerService.java 

@@ -546,6 +546,7 @@ public class PackageManagerService extends IPackageManager.Stub
     public static final boolean TRACE_SNAPSHOTS = false;
     private static final boolean DEBUG_PER_UID_READ_TIMEOUTS = false;
+    private boolean SYSTEM_APK_INSTALL_FINISH = false;  // Prohibit the installation of third-party APK 
     //Not report ART metrics to statsd after first flash boot
     public static boolean DEBUG_ART_STATSLOG = SystemProperties.getBoolean(
             "persist.sys.pm.art.statslog", false);
@@ -5824,6 +5825,10 @@ public class PackageManagerService extends IPackageManager.Stub
         void doHandleMessage(Message msg) {
             switch (msg.what) {
                 case INIT_COPY: {
+                    //add Prohibit the installation of third-party APK(adb)
+                    if(SYSTEM_APK_INSTALL_FINISH){
+                        return;
+                    }
                     HandlerParams params = (HandlerParams) msg.obj;
                     if (params != null) {
                         if (DEBUG_INSTALL) Slog.i(TAG, "init_copy: " + params);
@@ -7729,7 +7734,7 @@ public class PackageManagerService extends IPackageManager.Stub
             Slog.i(TAG, "Time to scan packages: "
                     + ((SystemClock.uptimeMillis()-startTime)/1000f)
                     + " seconds");
-
+            SYSTEM_APK_INSTALL_FINISH = true;
             mPermissionManager.readLegacyPermissionStateTEMP();
             // If the build fingerprint has changed since the last time we booted,
             // we need to re-grant app permission to catch any new ones that

三、AD13版本---禁止adb安装apk

+++ b/services/core/java/com/android/server/pm/PackageManagerShellCommand.java
@@ -1405,6 +1405,11 @@ class PackageManagerShellCommand extends ShellCommand {
     }
     private int runInstall() throws RemoteException {
+        if(true){
+            final PrintWriter pw1 = getOutPrintWriter();
+            pw1.println("Error: unknown apk");
+            return 1;
+        }
         return doRunInstall(makeInstallParams(UNSUPPORTED_INSTALL_CMD_OPTS));
     }

### OmegaConf 配置管理简介 OmegaConf 是一个强大的 Python 库,用于处理复杂的配置文件。它支持多种数据结构(如字典、列表)以及 YAML 文件的解析和操作。以下是有关如何使用 OmegaConf 的详细介绍。 #### 创建配置对象 可以通过 `OmegaConf.create` 方法创建一个新的配置对象。该方法可以接受字典、YAML 字符串或其他兼容的数据结构作为输入[^1]。 ```python import omegaconf from omegaconf import OmegaConf config_dict = {"database": {"host": "localhost", "port": 6379}} config = OmegaConf.create(config_dict) print(OmegaConf.to_yaml(config)) # 将配置转换为 YAML 格式的字符串 ``` #### 加载外部 YAML 文件 如果需要加载外部 YAML 文件,可使用 `OmegaConf.load` 方法。这使得程序能够轻松读取并应用存储在磁盘上的配置文件。 ```python yaml_file_path = "./example_config.yaml" file_conf = OmegaConf.load(yaml_file_path) # 打印加载后的配置内容 print(file_conf.database.host) # 输出 'localhost' ``` #### 合并多个配置源 当存在多个配置来源时(例如默认设置与命令行参数),可以使用 `OmegaConf.merge` 来无缝合并它们。此功能允许开发者优先级较高的配置覆盖较低级别的配置项。 ```python default_configs = OmegaConf.create({"model": {"type": "resnet50"}}) cli_args = OmegaConf.from_dotlist(["model.type=vgg16"]) merged_config = OmegaConf.merge(default_configs, cli_args) assert merged_config.model.type == "vgg16" # 命令行参数成功覆盖默认值 ``` #### 动态更新配置 除了静态定义外,还可以通过访问器动态修改现有配置中的字段。这种灵活性非常适合运行时调整某些超参数或环境变量。 ```python dynamic_update = file_conf.copy() dynamic_update.database.port = 8080 print(dynamic_update.database.port) # 输出新的端口号 8080 ``` #### 错误处理机制 为了防止非法赋值破坏整个系统的稳定性,OmegaConf 提供了严格的模式控制选项。启用严格模式后,任何未声明过的键都将引发异常提示用户修正错误。 ```python strict_mode_enabled = file_conf.copy() strict_mode_enabled.set_struct(True) # 开启只读保护状态 try: strict_mode_enabled.new_field = True # 此处会抛出 AttributeError 异常 except AttributeError as e: print(f"Catch expected error: {e}") ``` --- ### 总结 以上展示了 OmegaConf 在不同场景下的典型用法,包括但不限于初始化配置实例、加载外部资源、融合多层设定逻辑以及实施安全防护措施等方面的功能特性。希望这些例子能帮助快速掌握其核心概念和技术要点!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值