• Home
Name Date Size #Lines LOC

..--

bundle_tool/12-May-2024-12,2108,986

common/12-May-2024-1,428902

distributed_bundle_framework/12-May-2024-4,7003,589

figures/12-May-2024-

interfaces/12-May-2024-54,91643,978

sa_profile/12-May-2024-5031

services/12-May-2024-110,62281,096

test/12-May-2024-68,20549,426

.gitattributesD12-May-20241

BUILD.gnD12-May-20241.6 KiB4843

LICENSED12-May-202410.1 KiB177150

OAT.xmlD12-May-20244 KiB7016

README_zh.mdD12-May-20248.5 KiB195170

appexecfwk.gniD12-May-20245.1 KiB141121

bundle.jsonD12-May-20244.8 KiB127126

hisysevent.yamlD12-May-20245.8 KiB13398

README_zh.md

1# **包管理子系统**
2
3## 简介
4
5包管理子系统负责应用安装包的管理,提供安装包的信息查询、安装、更新、卸载和包信息存储等能力。具体功能如下:
6
7包管理子系统架构如下图所示:
8
9![](figures/appexecfwk.png)
10
11
12## 部件内子模块职责
13
14| 子模块名称       | 职责                                                         |
15| ---------------- | ------------------------------------------------------------ |
16| 包管理接口模块   | 1.对外提供的安装更新卸载及通知接口;<br>2.对外提供的包/组件信息/权限信息查询接口;<br>3.对外提供的应用权限查询接口;<br>4.对外提供的清除数据的接口; |
17| 扫描模块         | 1.预置应用的扫描;<br>2.已安装三方应用的扫描;<br>3.包配置文件的解析; |
18| 安全管理模块     | 1.安装过程中的签名校验;<br>2.安装过程中应用所申请权限的授予;<br>3.应用运行中权限的校验; |
19| DBMS模块         | 1.获取指定设备ability信息;                                  |
20| 安装管理模块     | 1.安装、更新、卸载逻辑处理及结果通知;                       |
21| 包信息管理模块   | 1.包信息、组件信息的存储及同步;                             |
22| 设备状态监听模块 | 1.监听设备的上下线;                                         |
23| Installd模块     | 特权进程:<br>1)用于创建、删除等目录操作;<br>2)用于创建、删除等文件操作;<br>3)用于设备目录的沙箱uid/gid等操作 |
24| DFX              | 1.包管理维测工具                                               |
25
26
27## 目录
28
29```
30foundation/bundlemanager/bundle_framework
31├── bundle_tool                        # bm工具存放目录
32├── distributed_bundle_framework       # 分布式包管理服务框架代码
33├── common
34│   └── log							   # 日志组件目录
35├── interfaces
36│   ├── inner_api                      # 内部接口存放目录
37│   └── kits                           # 应用接口
38│       ├── js                         # JS接口
39│       └── native                     # C/C++接口  
40├── services                           # 包管理服务框架代码
41└── test						       # 测试目录
42```
43
44### bm工具命令
45bm是用来方便开发者调试的一个工具。bm工具被hdc工具封装,进入hdc shell命令后,就可以使用bm工具。
46| 命令    | 描述       |
47| ------- | ---------- |
48|  help | 帮助命令,显示bm支持的命令信息 |
49| install | 安装命令,用来安装应用|
50| uninstall | 卸载命令,用来卸载应用|
51| dump | 查询命令,用来查询应用的相关信息|
52| clean | 清理命令,用来清理应用的缓存和数据 |
53| enable | 使能命令,用来使能应用 |
54| disable | 禁用命令,用来禁用应用 |
55| get | 获取udid命令,用来获取设备的udid |
56| quickfix | 快速修复相关命令,用来执行补丁相关操作,如补丁安装、补丁查询 |
57#### 帮助命令
58| 命令    | 描述       |
59| ------- | ---------- |
60| bm help | 显示bm工具的能够支持的命令信息 |
61
62* 示例
63```Bash
64# 显示帮助信息
65bm help
66```
67#### 安装命令
68命令可以组合,下面列出部分命令。
69| 命令                                | 描述                       |
70| ----------------------------------- | -------------------------- |
71| bm install -h | 显示install支持的命令信息 |
72| bm install -p <file-path>    | 安装应用,支持指定路径和多个hap、hsp同时安装 |
73| bm install -p <file-path> -u <user-id>   |给指定用户安装一个应用 |
74| bm install -r -p <file-path> | 覆盖安装一个应用 |
75| bm install -r -p <file-path> -u <user-id> | 给指定用户覆盖安装一个应用 |
76| bm install -r -p <file-path> -u <user-id> -w <waitting-time> | 安装时指定bm工具等待时间,最小的等待时长为5s,最大的等待时长为600s, 默认缺省为5s |
77
78* 示例
79```Bash
80# 安装一个hap
81bm install -p /data/app/ohosapp.hap
82# 覆盖安装一个hap
83bm install -p /data/app/ohosapp.hap -r
84```
85#### 卸载命令
86命令可以组合,下面列出部分命令。-u未指定情况下,默认为所有用户。
87| 命令                          | 描述                     |
88| ----------------------------- | ------------------------ |
89| bm uninstall -h | 显示uninstall支持的命令信息 |
90| bm uninstall -n <bundle-name> | 通过指定包名卸载应用 |
91| bm uninstall -n <bundle-name> -u <user-id>| 通过指定包名和用户卸载应用 |
92| bm uninstall -n <bundle-name> -m <moudle-name> | 通过指定包名卸载应用的一个模块 |
93
94* 示例
95```Bash
96# 卸载一个应用
97bm uninstall -n com.ohos.app
98# 卸载应用的一个模块
99bm uninstall -n com.ohos.app -m com.ohos.app.MainAbility
100```
101#### 查询命令
102命令可以组合,下面列出部分命令。-u未指定情况下,默认为所有用户。
103| 命令       | 描述                       |
104| ---------- | -------------------------- |
105| bm dump -h | 显示dump支持的命令信息 |
106| bm dump -a | 查询系统已经安装的所有应用 |
107| bm dump -n <bundle-name> | 查询指定包名的详细信息 |
108| bm dump -n <bundle-name> -s | 查询指定包名下的快捷方式信息 |
109| bm dump -n <bundle-name> -d <device-id> | 跨设备查询包信息 |
110| bm dump -n <bundle-name> -u <user-id> | 查询指定用户下指定包名的详细信息 |
111
112* 示例
113```Bash
114# 显示所有已安装的包名
115bm dump -a
116# 显示该应用的详细信息
117bm dump -n com.ohos.app
118```
119#### 清理命令
120-u未指定情况下,默认为当前活跃用户。
121| 命令       | 描述                       |
122| ---------- | -------------------------- |
123| bm clean -h | 显示clean支持的命令信息 |
124| bm clean -n <bundle-name> -c | 清除指定包名的缓存数据 |
125| bm clean -n <bundle-name> -d | 清除指定包名的数据目录 |
126| bm clean -n <bundle-name> -c -u <user-id> | 清除指定用户下包名的缓存数据 |
127| bm clean -n <bundle-name> -d -u <user-id> | 清除指定用户下包名的数据目录 |
128
129* 示例
130```Bash
131# 清理该应用下的缓存数据
132bm clean -n com.ohos.app -c
133# 清理该应用下的用户数据
134bm clean -n com.ohos.app -d
135```
136#### 使能命令
137-u未指定情况下,默认为当前活跃用户。
138| 命令       | 描述                       |
139| ---------- | -------------------------- |
140| bm enable -h | 显示enable支持的命令信息 |
141| bm enable -n <bundle-name> | 使能指定包名的应用 |
142| bm enable -n <bundle-name> -a <ability-name> | 使能指定包名下的元能力模块 |
143| bm enable -n <bundle-name> -u <user-id>| 使能指定用户和包名的应用 |
144
145* 示例
146```Bash
147# 使能该应用
148bm enable -n com.ohos.app
149```
150#### 禁用命令
151-u未指定情况下,默认为当前活跃用户。
152| 命令       | 描述                       |
153| ---------- | -------------------------- |
154| bm disable -h | 显示disable支持的命令信息 |
155| bm disable -n <bundle-name> | 禁用指定包名的应用 |
156| bm disable -n <bundle-name> -a <ability-name> | 禁用指定包名下的元能力模块 |
157| bm disable -n <bundle-name> -u <user-id>| 禁用指定用户和包名下的应用 |
158
159* 示例
160```Bash
161# 禁用该应用
162bm disable -n com.ohos.app
163```
164#### 获取udid命令
165| 命令       | 描述                       |
166| ---------- | -------------------------- |
167| bm get -h | 显示get支持的命令信息 |
168| bm get -u | 获取设备的udid |
169
170* 示例
171```Bash
172# 获取设备的udid
173bm get -u
174```
175
176#### 快速修复命令
177| 命令       | 描述                       |
178| ---------- | -------------------------- |
179| bm quickfix -h | 显示quickfix支持的命令信息 |
180| bm quickfix -a -f <file-path> | 执行补丁安装命令 |
181| bm quickfix -q -b <bundle-name> | 根据包名查询补丁包信息 |
182
183* 示例
184```Bash
185# 根据包名查询补丁包信息
186bm quickfix -q -b <bundle-name>
187```
188## 相关仓
189
190[包管理子系统](https://gitee.com/openharmony/docs/blob/master/zh-cn/readme/%E5%8C%85%E7%AE%A1%E7%90%86%E5%AD%90%E7%B3%BB%E7%BB%9F.md)
191
192[bundlemanager_bundle_framework](https://gitee.com/openharmony/bundlemanager_bundle_framework)
193
194[developtools_packing_tool](https://gitee.com/openharmony/developtools_packing_tool)
195