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.ts、napi_init.cpp、CMakeLists.txt等文件。 27e41f4b71Sopenharmony_ci 28e41f4b71Sopenharmony_ci1. 打开src/main/cpp/CMakeLists.txt,在target_link_libraries依赖中添加包管理的libbundle_ndk.z.so。 29e41f4b71Sopenharmony_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