目录

HarmonyOS-Android混合开发,直接吞并APK,这路子太野了

HarmonyOS-Android混合开发,直接“吞并”APK,这路子太野了

先给HarmonyOS比个心心

随着HarmonyOS2.0发布,HarmonyOS更加地进入大众视野,也越来越多的开发者涉足HarmonyOS领域,HarmonyOS的生态建设也在逐渐扩大、深入。

虽然HarmonyOS有着强大的分布式场景、AI等高级能力,但是毕竟还处于新生面世阶段,对于一些开发组件、生态市场等还有着一定的不成熟。最近想用HarmonyOS开发一款智慧场景的应用,深入了解后,无奈发现HarmonyOS对于相应的场景支持并不给力,所以就打算用Android开发并融合HarmonyOS的智慧能力。这就需要HarmonyOS-Android混合开发,所以也就有了这篇文章。

HarmonyOS-Android混合开发教程分为两个章节,都是干货满满:

  • 第一节:Android混入HarmonyOS工程
  • 第二节:HarmonyOS与Android交互

当前为第一章节,最后罗列了项目源码的git地址,以及混入过程中可能存在的一系列问题的整理文档,我踩过的坑,我也搭上了桥,希望能够帮助大家顺利通行,头发帮你们掉了。

需要注意的是,混合开发配置HarmonyOS应用证书时,需要绑定HarmonyOS真机,所以有真机的大吉大利,没有的赶快入手一台吧

1、新建工程

新建Android、HarmonyOS工程;

两个工程报名必须一致!!!

  • Android工程:

    https://i-blog.csdnimg.cn/blog_migrate/cba301a8e1f42fcecf9c40c3cdbb46ef.png

  • HarmonyOS工程·:

    https://i-blog.csdnimg.cn/blog_migrate/1b8c18c948ff118b8ad66fd92717bcfb.png

  • HarmonyOS - Android工程

    https://i-blog.csdnimg.cn/blog_migrate/68825553a2c546f750f4865b8d2dd95b.png

  • 启动两个工程,确保运行OK。

2、Android工程改造

以适配HarmonyOS

  • 引入abilityshell_ide_java.jar到libs中,并在app module的gradle中引入依赖(别忘了 sync now)

     compileOnly files('libs/abilityshell_ide_java.jar')

    该jar包就在HarmonyOS工程的SDK中,打开文件管理器即可获得:

    https://i-blog.csdnimg.cn/blog_migrate/5bc90fbb39af2d7de7c08e470f1d3d92.png

  • 创建Application,继承HarmonyApplication:

    https://i-blog.csdnimg.cn/blog_migrate/ec2f0cbbf0899e8fe7058d4701ba9b6f.png

  • 修改AndroidManifest.xml文件:

    // 根结点添加:
    <uses-feature android:name="zidane.software.ability" android:required="false" />
    // application节点中添加:
    <meta-data android:name="permZA" android:value="true" />
    <meta-data android:name="multiFrameworkBundle" android:value="true" />

    https://i-blog.csdnimg.cn/blog_migrate/63a23fc92c1b2520f5ecad8553bb65b9.png

3、生成应用签名,打包apk

  • Build -> Generate Signed Bundle/APK… -> APK -> NEXT:

https://i-blog.csdnimg.cn/blog_migrate/1ed7d182f9d5b5f9cdedcbc9f03c27de.png

  • 生成当前应用的签名文件:

https://i-blog.csdnimg.cn/blog_migrate/70f8e261bea9b49a0553242e5ea936ff.png

配置的密码规则要满足如下DevECO生成签名时配置的密码规则:

https://i-blog.csdnimg.cn/blog_migrate/e6f3245170e3d5146cc9fb22588b2ea1.png

  • 验证密码

https://i-blog.csdnimg.cn/blog_migrate/532da39ee633f2f0618908b31b4e7082.png

  • 打包成APK:

https://i-blog.csdnimg.cn/blog_migrate/bd96730ea8bd2f6812b8e6ffe3d3de38.png

  • 将生成的apk文件命名为android-entry(因为HarmonyOS要求引入的apk文件必须以entry.apk结尾)

    https://i-blog.csdnimg.cn/blog_migrate/75c265654ce6e829a869565299643d07.png

    为了不每次手动修改名称,在app module -> build.gradle -> android下添加:

    applicationVariants.all { variant ->
        variant.outputs.all {
            //文件名格式要求 xxx-entry.apk
            outputFileName = "android-entry.apk"
        }
    }

**注:**Android工程必须是64位

5、HarmonyOS工程改造

  • 迁入Android工程生成的jks和apk文件:

    https://i-blog.csdnimg.cn/blog_migrate/27de205a06c89281fd6415b16a3d7eea.png

  • entry module -> build.gradle -> ohs下,添加混入配置:

    legacyApkOptions{
        legacyApk rootProject.file('android/android-entry.apk').absolutePath //混入apk的存放路径
        signConfig{
            storeFile rootProject.file('android/sign.jks')   //混入apk所用签名文件
        }
    }
  • 更改entry module -> src -> main -> config.json -> app-> version参数和Android工程version保持一致:

    https://i-blog.csdnimg.cn/blog_migrate/0b80943de718cb548ab15051faf6416f.png

  • 更改entry module -> src -> main -> config.json -> module -> distro -> installationFree值为false:

    https://i-blog.csdnimg.cn/blog_migrate/e2d3e94e5e482473226ed340232c243e.png

  • 新建sign文件夹,存放所需的签名文件证书

    https://i-blog.csdnimg.cn/blog_migrate/eee11435175492d4ad96c3197eef93a8.png

  • 生成HarmonyOS应用的签名文件,必须和创建Android签名时参数保持一致。Build -> Generate Key and CSR

  • 新建p12文件:

    https://i-blog.csdnimg.cn/blog_migrate/df9147c0af42ca5cf6a29da5c84c72f8.png

    https://i-blog.csdnimg.cn/blog_migrate/32d37733652f607f583202888e87f823.png

    p12文件也可以根据Android项目的签名文件sign.jsk生成:

    keytool -importkeystore -srckeystore sign.jks -srcstoretype JKS
    -deststoretype PKCS12 -destkeystore sign.p12

    这里我们在DevECO中生成也是一样的,密码保持一致就行。

  • 创建csr证书,注意和创建sign.jks时配置参数保持一样:

    https://i-blog.csdnimg.cn/blog_migrate/3b0d7cc6bed95671f4802c7ca3610891.png

https://i-blog.csdnimg.cn/blog_migrate/9210158c54a0587d6d769b63fbdfe346.png

  • 创建成功:

    https://i-blog.csdnimg.cn/blog_migrate/09f19e9446571f00a5372966df3e569e.png

    https://i-blog.csdnimg.cn/blog_migrate/5ae984014fbfa23729d15150eaac0847.png

6、创建cer证书

文档地址:https://developer.harmonyos.com/cn/docs/documentation/doc-guides/ide_debug_device-0000001053822404

  • 进入 :

    https://i-blog.csdnimg.cn/blog_migrate/964a5f40ee7e5c9d5dcd1b4184dc5383.png

  • 进入【用户与访问】-> 【证书管理】:

    新建证书,上传刚才创建的csr证书,如下:

    https://i-blog.csdnimg.cn/blog_migrate/a22483b4d138f20d4af9090c977b3ead.png

  • 下载cer证书:

    https://i-blog.csdnimg.cn/blog_migrate/dd5dacff00e4c60223e0c0a6ec8ec972.png

7、创建p7b证书

  • 回到 首页,进入【我的项目 】-> 【添加项目】:

    https://i-blog.csdnimg.cn/blog_migrate/58de70466b7a8b487ccb34628a6e0c1c.png

  • 不要立即在项目页面添加应用,虽然流程相似,但配置参数不一样(会出现异常)。下滑左侧菜单栏,进入HarmonyOS应用,添加HarmonyOS应用:

    https://i-blog.csdnimg.cn/blog_migrate/7360eea5856d758c9e1fcac3eeffae6a.png

  • 并根据提示设置SDK:

    https://i-blog.csdnimg.cn/blog_migrate/f73c227d0a64007cc6a09dd2b626492f.png

    第二步:

    https://i-blog.csdnimg.cn/blog_migrate/8207ff716c80f9e6111bb46e04270422.png

    注意去掉上面箭头的空格,不然sync时会报错:

    https://i-blog.csdnimg.cn/blog_migrate/b1282c0d4c1c454e5c06680c7a15db14.png

    classpath 'com.huawei.agconnect:agcp-harmony:1.0.0.300'
    implementation 'com.huawei.agconnect:agconnect-core-harmony:1.0.0.300'
  • 然后再进入HarmonyOS应用菜单下,添加Profile文件:

    https://i-blog.csdnimg.cn/blog_migrate/b278d822cbdf10d0720dd29c8fb15c2c.png

    https://i-blog.csdnimg.cn/blog_migrate/f015d1d540bc3f21698c6858589a6ee4.png

    需要添加设备,自行百度设备添加方式吧(需要有HarmonyOS系统的真机哦)。

    https://i-blog.csdnimg.cn/blog_migrate/6724a638ba7e3cae1431032525788306.png

  • 下载p7b证书,至此所有证书已集齐完毕,准备召唤神龙:

https://i-blog.csdnimg.cn/blog_migrate/b64bf8550e26f8c4d06fa8a97d5e8e94.png

8、添加业务module

默认入口entry作为引入apk的加壳,我们需要创建新的module来作为HarmonyOS应用的入口。

  • 创建module:

    https://i-blog.csdnimg.cn/blog_migrate/028b2d11393d65418971506f8e63512f.png

**注:**要保证module的version也保持一致。

9、配置签名证书

  • 进入Project Structure:

    https://i-blog.csdnimg.cn/blog_migrate/64f7aa563d5eecb7d1e905ecda48a900.png

  • 配置Project -> Signing Configs:

    https://i-blog.csdnimg.cn/blog_migrate/0b062e37a13c7211ed89d5144a193b85.png

  • 配置Modules -> Signing Configs,把module都配置上(只配置entry也行)

    https://i-blog.csdnimg.cn/blog_migrate/01d53853db96c5da42a0bd172b99b443.png

10、配置启动类型

由于我们新的入口变为myentry,所以我们在启动myentry时需要把entry部署进去,如下:

https://i-blog.csdnimg.cn/blog_migrate/b921b79f9456a27792efe0659b453fb3.gif

10、启动myentry

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OQaPfi6p-1630873581296)(https://gitee.com/harmony-os-jt/harmony-os-android-mix/raw/master/doc/Pictures/run.gif)]

至此Android apk已成功混入HarmonyOS工程。

11、验证Android混入成功

怎么检测Android工程被引入进来了呢,

  • 判断当前运行环境

    /**
     * 判断当前运行平台还是否是HarmonyOS平台
     * @return
     */
    public boolean isHarmonyOS() {
        Class<?> aClass = null;
        try {
            Class clz = Class.forName("com.huawei.system.BuildEx");
            Method method = clz.getMethod("getOsBrand");
            return "harmony".equals(method.invoke(clz));
        } catch (Exception e) {
            return false;
        }
    }
  • 验证从Ability跳转到Activity页面。

    Intent androidIntent = new Intent();
    Operation operation = new Intent.OperationBuilder()
        .withDeviceId("")
        .withBundleName(getBundleName())
        .withAbilityName("com.jt.mix.SecondActivity")
        .withFlags(Intent.FLAG_NOT_OHOS_COMPONENT)
        .build();
    androidIntent.setOperation(operation);
    // 传递参数
    androidIntent.setParam("ohosMsg", "I'm HarmonyOS!");
    startAbility(androidIntent);

12、相关链接

  • 项目地址:
  • HarmonyOS与Android交互:
  • 问题集锦: