polarssl集成到应用hap
本库是在RK3568开发板上基于OpenHarmony3.2 Release版本的镜像验证的,如果是从未使用过RK3568,可以先查看润和RK3568开发板标准系统快速上手。
开发环境
编译三方库
-
下载本仓库
git clone https://gitee.com/openharmony-sig/tpc_c_cplusplus.git --depth=1 -
三方库目录结构
tpc_c_cplusplus/thirdparty/polarssl #三方库polarssl的目录结构如下 ├── docs #三方库相关文档的文件夹 ├── HPKBUILD #构建脚本 ├── SHA512SUM #三方库校验文件 ├── README.OpenSource #说明三方库源码的下载地址,版本,license等信息 ├── HPKCHECK #自动化测试脚本 ├── OAT.xml #版权检验文件 ├── README_zh.md -
在lycium目录下编译三方库 编译环境的搭建参考准备三方库构建环境
cd lycium ./build.sh polarssl -
三方库头文件及生成的库 在lycium目录下会生成usr目录,该目录下存在已编译完成的32位和64位三方库
polarssl/arm64-v8a polarssl/armeabi-v7a
应用中使用三方库
- 在IDE的cpp目录下新增thirdparty目录,将编译生成的库拷贝到该目录下,如下图所示

- 在最外层(cpp目录下)CMakeLists.txt中添加如下语句
#将三方库加入工程中 target_link_libraries(entry PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/polarssl/${OHOS_ARCH}/lib/libpolarssl.a ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/pkcs11-helper/${OHOS_ARCH}/lib/libpkcs11-helper.a ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/openssl/${OHOS_ARCH}/lib/libssl.a ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/zlib/${OHOS_ARCH}/lib/libz.a) #将三方库的头文件加入工程中 target_include_directories(entry PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/polarssl/${OHOS_ARCH}/include ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/pkcs11-helper/${OHOS_ARCH}/include ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/openssl/${OHOS_ARCH}/include ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/zlib/${OHOS_ARCH}/include)
测试三方库
三方库的测试使用原库自带的测试用例来做测试,准备三方库测试环境
- 将测试资源导入到开发板
- 设置依赖服务程序路径
32位系统
export LD_LIBRARY_PATH=/data/local/tmp/tpc_c_cplusplus/lycium/usr/polarssl/armeabi-v7a/lib:/data/local/tmp/tpc_c_cplusplus/lycium/usr/pkcs11-helper/armeabi-v7a/lib:/data/local/tmp/tpc_c_cplusplus/lycium/usr/openssl/armeabi-v7a/lib:/data/local/tmp/tpc_c_cplusplus/lycium/usr/zlib/armeabi-v7a/lib
##64位系统
export LD_LIBRARY_PATH=/data/local/tmp/tpc_c_cplusplus/lycium/usr/polarssl/arm64-v8a/lib:/data/local/tmp/tpc_c_cplusplus/lycium/usr/pkcs11-helper/arm64-v8a/lib:/data/local/tmp/tpc_c_cplusplus/lycium/usr/openssl/arm64-v8a/lib:/data/local/tmp/tpc_c_cplusplus/lycium/usr/zlib/arm64-v8a/lib
- 进入到构建目录$ARCH-build/下执行 ctest 运行测试用例,如下截图(arm64-v8a-build为构建64位的目录,armeabi-v7a-build为构建32位的目录)
