project

发布时间 2023-08-02 14:31:39作者: cps666

编译构建

OHPM CLI

安装依赖

npm包引用在会有问题,带解决 TODO
安装的npm需要在 oh-package.json5中 "@ohos/httpclient": "file:./node_modules/@ohos/httpclient" 引用本地包
将node-modules中@ohos -> httpclient -> package.json 文件名字改成 oh-package.json5,要不然引用不成功
 
常用三方库介绍
常用的三方库可以分为UI、动画、网络、数据、安全、多媒体、框架、工具等。

UI库:
PhototView:可以通过该组件快速实现图片的缩放、平移和旋转等操作。
RoundImageView:可以生成圆角矩形、或者椭圆形等图片形状。
网络库:
HttpClient:其以耳熟能详的OKHTTP为基础,整合android-async-http、AutobahnAndroid、OkGo等库的功能特性,实现了自定义拦截器、cookie管理等功能。
axios:运行在nodejs和浏览器中的axios,也是比较熟知的基于promise的网络请求库,同样实现了强大的网络功能。
动画库:
lottie:用于解决应用中复杂动画的问题。
reboud:可以模拟弹簧动力学,实现驱动物理效果等。
其他类别不单独介绍,感兴趣的可以通过以上获取途径进行访问了解详情。

三方库在系统能力的基础上,提供了更加方便的使用,在许多场景下,能够极大提升开发者的开发效率,下面将以lottie为例介绍三方库的基本使用。
方式一:在Terminal窗口中,执行如下命令安装三方包,DevEco Studio会自动在工程的oh-package.json5中自动添加三方包依赖。
ohpm install @ohos/lottie
方式二:在工程的oh-package.json5中设置三方包依赖,配置示例如下:
"dependencies": { "@ohos/lottie": "^2.0.0"}
依赖设置完成后,需要执行ohpm install命令安装依赖包,依赖包会存储在工程的oh_modules目录下。
ohpm install

工程的目录结构

AppScope中存放应用全局所需要的资源文件。
entry是应用的主模块,存放HarmonyOS应用的代码、资源等。
oh_modules是工程的依赖包,存放工程依赖的源文件。
build-profile.json5是工程级配置信息,包括签名、产品配置等。
hvigorfile.ts是工程级编译构建任务脚本,hvigor是基于任务管理机制实现的一款全新的自动化构建工具,主要提供任务注册编排,工程模型管理、配置管理等核心能力。
oh-package.json5是工程级依赖配置文件,用于记录引入包的配置信息

模块级目

main文件夹中,ets文件夹用于存放ets代码,resources文件存放模块内的多媒体及布局文件等,module.json5文件为模块的配置文件。
ohosTest是单元测试目录。
build-profile.json5是模块级配置信息,包括编译构建配置项。
hvigorfile.ts文件是模块级构建脚本。
oh-package.json5是模块级依赖配置信息文件。

entryability存放ability文件,用于当前ability应用逻辑和生命周期管理。
pages存放UI界面相关代码文件,初始会生成一个Index页面。
resources目录下存放模块公共的多媒体、字符串及布局文件等资源,分别存放在element、media文件夹中。

app.json5

AppScope>app.json5是应用的全局的配置文件,用于存放应用公共的配置信息。
{
  "app": {
    "bundleName": "com.example.healthy_life",
    "vendor": "example",
    "versionCode": 1000000,
    "versionName": "1.0.0",
    "icon": "$media:app_icon",
    "label": "$string:app_name"
  }
}

bundleName是包名。
vendor是应用程序供应商。
versionCode是用于区分应用版本。
versionName是版本号。
icon对应于应用的显示图标。
label是应用名。

module.json5

entry>src>main>module.json5是模块的配置文件,包含当前模块的配置信息。
其中module对应的是模块的配置信息,一个模块对应一个打包后的hap包,hap包全称是HarmonyOS Ability Package,其中包含了ability、第三方库、资源和配置文件。其具体属性及其描述可以参照下表1。

表1 module.json5默认配置属性及描述

name:该标签标识当前module的名字,module打包成hap后,表示hap的名称,标签值采用字符串表示(最大长度31个字节),该名称在整个应用要唯一。

type: 表示模块的类型,类型有三种,分别是entry、feature和har。

srcEntry:当前模块的入口文件路径。

description:当前模块的描述信息。

mainElement:该标签标识hap的入口ability名称或者extension名称。只有配置为mainElement的ability或者extension才允许在服务中心露出。

deviceTypes:该标签标识hap可以运行在哪类设备上,标签值采用字符串数组的表示。

deliveryWithInstall:标识当前Module是否在用户主动安装的时候安装,表示该Module对应的HAP是否跟随应用一起安装。- true:主动安装时安装。- false:主动安装时不安装。

installationFree:标识当前Module是否支持免安装特性。- true:表示支持免安装特性,且符合免安装约束。- false:表示不支持免安装特性。

pages:对应的是main_pages.json文件,用于配置ability中用到的page信息。

abilities:是一个数组,存放当前模块中所有的ability元能力的配置信息,其中可以有多个ability。
对于abilities中每一个ability的属性项,其描述信息如下表2。

name : 该标签标识当前ability的逻辑名,该名称在整个应用要唯一,标签值采用字符串表示(最大长度127个字节)。

srcEntry:ability的入口代码路径。

description:ability的描述信息。

icon:ability的图标。该标签标识ability图标,标签值为资源文件的索引。该标签可缺省,缺省值为空。如果ability被配置为MainElement,该标签必须配置。

label:ability的标签名。

startWindowIcon:启动页面的图标。

startWindowBackground:启动页面的背景色。

visible:ability是否可以被其他应用程序调用,true表示可以被其它应用调用, false表示不可以被其它应用调用。

skills:标识能够接收的意图的action值的集合,取值通常为系统预定义的action值,也允许自定义。

entities:标识能够接收的Want的Action值的集合,取值通常为系统预定义的action值,也允许自定义。

actions:标识能够接收Want的Entity值的集合。

main_pages.json

src/main/resources/base/profile/main_pages.json文件保存的是页面page的路径配置信息,所有需要进行路由跳转的page页面都要在这里进行配置。
{
  "src": [
    "pages/SplashPage",
    "pages/AdvertisingPage",
    "pages/MainPage",
    "pages/TaskListPage",
    "pages/TaskEditPage"
  ]
}

打包发布

生成密钥和证书请求文件

HarmonyOS应用/服务通过数字证书(.cer文件)和Profile文件(.p7b文件)来保证应用/服务的完整性,数字证书和Profile文件可通过申请发布证书和Profile文件获取。

申请数字证书和Profile文件前,首先需要通过DevEco Studio来生成密钥(存储在格式为.p12的密钥库文件中)和证书请求文件(.csr文件)。同时,也可以使用命令行工具的方式来生成密钥文件和证书请求文件。

基本概念

密钥:包含非对称加密中使用的公钥和私钥,存储在密钥库文件中,格式为.p12,公钥和私钥对用于数字签名和验证。
证书请求文件:格式为.csr,全称为Certificate Signing Request,包含密钥对中的公钥和公共名称、组织名称、组织单位等信息,用于向AppGallery Connect申请数字证书。
数字证书:格式为.cer,由华为AppGallery Connect颁发。
Profile文件:格式为.p7b,包含HarmonyOS应用/服务的包名、数字证书信息、描述应用/服务允许申请的证书权限列表,
以及允许应用/服务调试的设备列表(如果应用/服务类型为Release类型,则设备列表为空)等内容,每个应用/服务包中均必须包含一个Profile文件。