1e41f4b71Sopenharmony_ci# NativeBundle开发指导
2e41f4b71Sopenharmony_ci
3e41f4b71Sopenharmony_ci## 场景介绍
4e41f4b71Sopenharmony_ci
5e41f4b71Sopenharmony_ci开发者可以通过本指导了解在OpenHarmony应用中,如何使用Native Bundle接口获取应用自身相关信息。
6e41f4b71Sopenharmony_ci
7e41f4b71Sopenharmony_ci## 接口说明
8e41f4b71Sopenharmony_ci
9e41f4b71Sopenharmony_ci| 接口名                                                       | 描述                                     |
10e41f4b71Sopenharmony_ci| :----------------------------------------------------------- | :--------------------------------------- |
11e41f4b71Sopenharmony_ci| [OH_NativeBundle_GetCurrentApplicationInfo](../reference/apis-ability-kit/_bundle.md#oh_nativebundle_getcurrentapplicationinfo) | 获取应用自身相关信息。          |
12e41f4b71Sopenharmony_ci| [OH_NativeBundle_GetAppId](../reference/apis-ability-kit/_bundle.md#oh_nativebundle_getappid) | 获取自身应用的appId信息。 |
13e41f4b71Sopenharmony_ci| [OH_NativeBundle_GetAppIdentifier](../reference/apis-ability-kit/_bundle.md#oh_nativebundle_getappidentifier) | 获取自身应用的appIdentifier信息。 |
14e41f4b71Sopenharmony_ci| [OH_NativeBundle_GetMainElementName](../reference/apis-ability-kit/_bundle.md#oh_nativebundle_getmainelementname) | 获取自身应用入口的信息。 |
15e41f4b71Sopenharmony_ci
16e41f4b71Sopenharmony_ci## 开发步骤
17e41f4b71Sopenharmony_ci
18e41f4b71Sopenharmony_ci**1. 创建工程**
19e41f4b71Sopenharmony_ci
20e41f4b71Sopenharmony_ci<div style="text-align:center;">
21e41f4b71Sopenharmony_ci  <img src="figures/rawfile1.png">
22e41f4b71Sopenharmony_ci</div>
23e41f4b71Sopenharmony_ci
24e41f4b71Sopenharmony_ci**2. 添加依赖**
25e41f4b71Sopenharmony_ci
26e41f4b71Sopenharmony_ci创建完成后,IDE会在工程生成cpp目录,目录有types/libentry/index.d.tsnapi_init.cppCMakeLists.txt等文件。
27e41f4b71Sopenharmony_ci
28e41f4b71Sopenharmony_ci1. 打开src/main/cpp/CMakeLists.txt,在target_link_libraries依赖中添加包管理的libbundle_ndk.z.so29e41f4b71Sopenharmony_ci
30e41f4b71Sopenharmony_ci    ```c++
31e41f4b71Sopenharmony_ci    target_link_libraries(entry PUBLIC libace_napi.z.so libbundle_ndk.z.so)
32e41f4b71Sopenharmony_ci    ```
33e41f4b71Sopenharmony_ci
34e41f4b71Sopenharmony_ci2. 打开src/main/cpp/napi_init.cpp文件,添加头文件。
35e41f4b71Sopenharmony_ci
36e41f4b71Sopenharmony_ci    ```c++
37e41f4b71Sopenharmony_ci    #include "bundle/native_interface_bundle.h"
38e41f4b71Sopenharmony_ci    ```
39e41f4b71Sopenharmony_ci
40e41f4b71Sopenharmony_ci**3. 修改源文件**
41e41f4b71Sopenharmony_ci
42e41f4b71Sopenharmony_ci1. 打开src/main/cpp/napi_init.cpp文件,文件Init会对当前方法进行初始化映射,这里定义对外接口为getCurrentApplicationInfo。
43e41f4b71Sopenharmony_ci
44e41f4b71Sopenharmony_ci    ```c++
45e41f4b71Sopenharmony_ci    EXTERN_C_START
46e41f4b71Sopenharmony_ci    static napi_value Init(napi_env env, napi_value exports)
47e41f4b71Sopenharmony_ci    {
48e41f4b71Sopenharmony_ci        napi_property_descriptor desc[] = {
49e41f4b71Sopenharmony_ci            { "getCurrentApplicationInfo", nullptr, GetCurrentApplicationInfo, nullptr, nullptr, nullptr, napi_default, nullptr}
50e41f4b71Sopenharmony_ci        };
51e41f4b71Sopenharmony_ci
52e41f4b71Sopenharmony_ci        napi_define_properties(env, exports, sizeof(desc) / sizeof(desc[0]), desc);
53e41f4b71Sopenharmony_ci        return exports;
54e41f4b71Sopenharmony_ci    }
55e41f4b71Sopenharmony_ci    EXTERN_C_END
56e41f4b71Sopenharmony_ci    ```
57e41f4b71Sopenharmony_ci
58e41f4b71Sopenharmony_ci2. 在src/main/cpp/napi_init.cpp文件中,增加对应的方法,如下所示:
59e41f4b71Sopenharmony_ci
60e41f4b71Sopenharmony_ci    ```c++
61e41f4b71Sopenharmony_ci    static napi_value GetCurrentApplicationInfo(napi_env env, napi_callback_info info)
62e41f4b71Sopenharmony_ci    ```
63e41f4b71Sopenharmony_ci
64e41f4b71Sopenharmony_ci3. 在src/main/cpp/napi_init.cpp文件中获取Native的包信息对象,并转为js的包信息对象,即可在js测获取应用的信息:
65e41f4b71Sopenharmony_ci
66e41f4b71Sopenharmony_ci    ```c++
67e41f4b71Sopenharmony_ci    static napi_value GetCurrentApplicationInfo(napi_env env, napi_callback_info info)
68e41f4b71Sopenharmony_ci    {
69e41f4b71Sopenharmony_ci        // 调用Native接口获取应用信息
70e41f4b71Sopenharmony_ci        OH_NativeBundle_ApplicationInfo nativeApplicationInfo = OH_NativeBundle_GetCurrentApplicationInfo();
71e41f4b71Sopenharmony_ci        napi_value result = nullptr;
72e41f4b71Sopenharmony_ci        napi_create_object(env, &result);
73e41f4b71Sopenharmony_ci        // Native接口获取的应用包名转为js对象里的bundleName属性
74e41f4b71Sopenharmony_ci        napi_value bundleName;
75e41f4b71Sopenharmony_ci        napi_create_string_utf8(env, nativeApplicationInfo.bundleName, NAPI_AUTO_LENGTH, &bundleName);
76e41f4b71Sopenharmony_ci        napi_set_named_property(env, result, "bundleName", bundleName);
77e41f4b71Sopenharmony_ci        // Native接口获取的指纹信息转为js对象里的fingerprint属性
78e41f4b71Sopenharmony_ci        napi_value fingerprint;
79e41f4b71Sopenharmony_ci        napi_create_string_utf8(env, nativeApplicationInfo.fingerprint, NAPI_AUTO_LENGTH, &fingerprint);
80e41f4b71Sopenharmony_ci        napi_set_named_property(env, result, "fingerprint", fingerprint);
81e41f4b71Sopenharmony_ci
82e41f4b71Sopenharmony_ci        char* appId = OH_NativeBundle_GetAppId();
83e41f4b71Sopenharmony_ci        // Native接口获取的appId转为js对象里的appId属性
84e41f4b71Sopenharmony_ci        napi_value napi_appId;
85e41f4b71Sopenharmony_ci        napi_create_string_utf8(env, appId, NAPI_AUTO_LENGTH, &napi_appId);
86e41f4b71Sopenharmony_ci        napi_set_named_property(env, result, "appId", napi_appId);
87e41f4b71Sopenharmony_ci
88e41f4b71Sopenharmony_ci        char* appIdentifier = OH_NativeBundle_GetAppIdentifier();
89e41f4b71Sopenharmony_ci        // Native接口获取的appIdentifier转为js对象里的appIdentifier属性
90e41f4b71Sopenharmony_ci        napi_value napi_appIdentifier;
91e41f4b71Sopenharmony_ci        napi_create_string_utf8(env, appIdentifier, NAPI_AUTO_LENGTH, &napi_appIdentifier);
92e41f4b71Sopenharmony_ci        napi_set_named_property(env, result, "appIdentifier", napi_appIdentifier);
93e41f4b71Sopenharmony_ci        // 最后为了防止内存泄漏,手动释放
94e41f4b71Sopenharmony_ci        free(nativeApplicationInfo.bundleName);
95e41f4b71Sopenharmony_ci        free(nativeApplicationInfo.fingerprint);
96e41f4b71Sopenharmony_ci        free(appId);
97e41f4b71Sopenharmony_ci        free(appIdentifier);
98e41f4b71Sopenharmony_ci        return result;
99e41f4b71Sopenharmony_ci    }
100e41f4b71Sopenharmony_ci    ```
101e41f4b71Sopenharmony_ci
102e41f4b71Sopenharmony_ci**4. js侧调用**
103e41f4b71Sopenharmony_ci
104e41f4b71Sopenharmony_ci1. 打开src\main\ets\pages\index.ets, 导入"libentry.so"。
105e41f4b71Sopenharmony_ci
106e41f4b71Sopenharmony_ci
107e41f4b71Sopenharmony_ci2. 调用Native接口getCurrentApplicationInfo即可获取应用信息。示例如下:
108e41f4b71Sopenharmony_ci
109e41f4b71Sopenharmony_ci    ```js
110e41f4b71Sopenharmony_ci    import hilog from '@ohos.hilog';
111e41f4b71Sopenharmony_ci    import testNapi from 'libentry.so';
112e41f4b71Sopenharmony_ci
113e41f4b71Sopenharmony_ci    @Entry
114e41f4b71Sopenharmony_ci    @Component
115e41f4b71Sopenharmony_ci    struct Index {
116e41f4b71Sopenharmony_ci    @State message: string = 'Hello World';
117e41f4b71Sopenharmony_ci
118e41f4b71Sopenharmony_ci        build() {
119e41f4b71Sopenharmony_ci            Row() {
120e41f4b71Sopenharmony_ci            Column() {
121e41f4b71Sopenharmony_ci                Text(this.message)
122e41f4b71Sopenharmony_ci                .fontSize(50)
123e41f4b71Sopenharmony_ci                .fontWeight(FontWeight.Bold)
124e41f4b71Sopenharmony_ci
125e41f4b71Sopenharmony_ci                Button(){
126e41f4b71Sopenharmony_ci                Text("GetCurrentApplicationInfo").fontSize(30)
127e41f4b71Sopenharmony_ci                }.type(ButtonType.Capsule)
128e41f4b71Sopenharmony_ci                .margin({
129e41f4b71Sopenharmony_ci                top: 20
130e41f4b71Sopenharmony_ci                })
131e41f4b71Sopenharmony_ci                .backgroundColor('#0D9FFB')
132e41f4b71Sopenharmony_ci                .width('70%')
133e41f4b71Sopenharmony_ci                .height('5%')
134e41f4b71Sopenharmony_ci                .onClick(()=>{
135e41f4b71Sopenharmony_ci                try {
136e41f4b71Sopenharmony_ci                    let data = testNapi.getCurrentApplicationInfo();
137e41f4b71Sopenharmony_ci                    console.info("getCurrentApplicationInfo success, data is " + JSON.stringify(data));
138e41f4b71Sopenharmony_ci                } catch (error) {
139e41f4b71Sopenharmony_ci                    console.error("getCurrentApplicationInfo failed");
140e41f4b71Sopenharmony_ci                    this.message = "getCurrentApplicationInfo failed";
141e41f4b71Sopenharmony_ci                }
142e41f4b71Sopenharmony_ci                })
143e41f4b71Sopenharmony_ci            }
144e41f4b71Sopenharmony_ci            .width('100%')
145e41f4b71Sopenharmony_ci            }
146e41f4b71Sopenharmony_ci            .height('100%')
147e41f4b71Sopenharmony_ci        }
148e41f4b71Sopenharmony_ci    }
149e41f4b71Sopenharmony_ci    ```
150e41f4b71Sopenharmony_ci
151e41f4b71Sopenharmony_ci关于包管理NDK开发,可参考[Bundle模块介绍](../reference/apis-ability-kit/_bundle.md)。
152