梦应逍遥 发表于 2024-9-8 12:03:59

【鸿蒙南向开辟】OpenHarmony 应用开机自启

实现原理

整个实现原理就是专门弄个应用当启动器,让这个应用进行开机自启(此处的开机自启并不是直接打开应用,而是自启一个服务挂在背景运行),然后让这个应用去打开需要自启的那个应用,在此也是参考了这篇文章
创建应用及替换 full-sdk

https://img-blog.csdnimg.cn/img_convert/1759540f0d682ffbcb5b64a215a03e18.webp?x-oss-process=image/format,png
创建完毕之后需要替换一下 sdk,使用 full-sdk 才有权限使用 ServiceExtensionAbility 模块
具体替换步调可以去参考官方文档,我大概说下步调
https://docs.openharmony.cn/pages/v4.1/zh-cn/application-dev/faqs/full-sdk-switch-guide.md
1.起首去这个地址下载 full-sdk 包
下载地址
https://img-blog.csdnimg.cn/img_convert/f625d2d4f6cb5fd754ec7bb50a9a722f.webp?x-oss-process=image/format,png
选择全量包进行下载,我是 windows 就以 windows 为例,解压选择 windows,只需要这个包 ets-windows-x64-3.2.14.1-Release,版本按照你自己的来。
下一步打开 sdk 目次,在编辑器-> 工具->sdk 管理找到 sdk 安装路径
https://img-blog.csdnimg.cn/img_convert/2ea87b3654143337eb39e6be28bfa568.webp?x-oss-process=image/format,png
https://img-blog.csdnimg.cn/img_convert/b6e6153c9b1a9d504db6ba41b3daae75.webp?x-oss-process=image/format,png
只需要替换 ets 文件夹里面的文件即可,起首先记录 ets 目次下随便哪个文件夹里的 oh-uni-package.json 文件里的版本号,好比我这里是 3.2.13.5
https://img-blog.csdnimg.cn/img_convert/73d95c9643bd93a15877c618dc3b6a2a.webp?x-oss-process=image/format,png
然后将 ets 里的文件删除,也可以备份到表面去,然后将这个压缩包 ets-windows-x64-3.2.14.1-Release 解压,解压的文件全部放进 ets 目次中,然后将每个文件夹里面的 oh-uni-package.json 的版本号改为之前所记录的版本号,我是 3.2.13.5 我就全改成 3.2.13.5 了。
替换完成之后把依赖安装一下,也就是 \build-tools\ets-loader 目次中打开 cmd 执行 npm install 依赖装完就替换完成
应用修改为体系应用

因为背景打开体系应用的 api 是只有体系应用才有权限的以是更改一下
照旧进入 sdk 目次下打开这个文件
https://img-blog.csdnimg.cn/img_convert/49c5ee440dc6e2a73e71e371217914be.webp?x-oss-process=image/format,png
修改这两个的值就行了
"apl":"system_core",
"app-feature":"ohos_system_app"
https://img-blog.csdnimg.cn/img_convert/19b0b770cc4720e399ef6a90541bd898.webp?x-oss-process=image/format,png
然后保存就 ok 了
应用设置工程署名

单击 文件 > 项目结构 > Project > SigningConfigs 界面勾选 Automatically generate signature,等待自动署名完成即可,单击 OK。
https://img-blog.csdnimg.cn/img_convert/a254178d4e6693ddef150a2bdc33c938.webp?x-oss-process=image/format,png
设置 ServiceExtensionAbility


[*]在工程 Module(entry)对应的 ets 目次下,右键选择 New > Directory,新建一个目次并定名为 ServiceExtAbility。
[*]在 ServiceExtAbility 目次,右键选择 New > TypeScript File ,新建一个 TypeScript 文件并定名为 ServiceExtAbility.ets。
[*]在 ServiceExtAbility.ts 文件中,导入 ServiceExtensionAbility 的依赖包,自界说类继续 ServiceExtensionAbility 并实现生命周期回调。
[*]代码如下,包含跳转应用的代码,我加了个二十秒的延长,否则的话开机是检测不到应用包的是跳转不了的,这里应该也可以去检测之类的吧,大佬可以优化下。
import ServiceExtensionAbility from '@ohos.app.ability.ServiceExtensionAbility';
import Want from '@ohos.app.ability.Want';

const TAG: string = "";

export default class ServiceExtAbility extends ServiceExtensionAbility {

onCreate(want: Want) {
    setTimeout(() => {
      let params: Want = {
      'bundleName': 'com.example.app_question_40', // 这里是你的应用包名
      'moduleName': 'entry',
      'abilityName': 'EntryAbility'
      };
      try {
      this.context.startAbility(params, (error) => {
          if (error.code) {
            // 处理业务逻辑错误
            console.error(`startAbility failed, error.code: ${error.code}, error.message: ${error.message}`);
            return;
          }

      });
      } catch (paramError) {
      // 处理入参错误异常
      console.error(`error.code错误:${paramError.code}, error.message: ${paramError.message}`);
      }
    }, 20000)
    console.info(TAG, `onCreate_____end, want: ${want.abilityName}`);
}

onRequest(want: Want, startId: number) {
    console.info(TAG, `onRequest, want: ${want.abilityName}`);
}

onConnect(want: Want) {
    console.info(TAG, `onConnect, want: ${want.abilityName}`);
    return null
}

onDisconnect(want: Want) {
    console.info(TAG, `onDisconnect, want: ${want.abilityName}`);
}

onDestroy() {
    console.info(TAG, `onDestroy`);
}
}


[*]然后再去 src/main/module.json5 去添加注册 ServiceExtensionAbility,并修改 module.mainElement 为 ServiceExtAbility
"mainElement": "ServiceExtAbility"
"extensionAbilities": [
      {
      "name": "ServiceExtAbility",
      "icon": "$media:icon",
      "description": "service",
      "type": "form",
      "exported": true,
      "srcEntry": "./ets/ServiceExtAbility/ServiceExtAbility.ets"
      }
    ],


[*]然后这个文件下还要再设置一个权限
"requestPermissions": [
      {
      "name": "ohos.permission.INTERNET"
      },
      {
      "name": "ohos.permission.START_ABILITIES_FROM_BACKGROUND"
      }
    ],

获取指纹证书

如今把应用安装到呆板上是安装不上的因为要改设置文件才支持 ServiceExtensionAbility 服务,我们先把 module.json5 里面的 extensionAbilities 里 type 类型改下,先把应用装到呆板上去。
https://img-blog.csdnimg.cn/img_convert/0a602725ffa0155bcb3730a8993c3df5.webp?x-oss-process=image/format,png
然后执行 hdc 命令
   hdc shell “bm dump -n 包名 | grep finger”
然后就可以得到指纹代码了
https://img-blog.csdnimg.cn/img_convert/f0f89cc2eb6aaac43949abd3641bca3b.webp?x-oss-process=image/format,png
然后将呆板上的特权设置文件**install_list_capability.json **放到当地
   hdc file recv /etc/app/install_list_capability.json D:\
添加应用信息
bundleName:应用包名。
app_signature:就是刚刚获取到的指纹
allowAppUsePrivilegeExtension:是否允许应用使用 ServiceExtension、DataExtension。
singleton:是否允许应用安装到单用户下(U0),常驻和自启动需设置。
keepAlive:是否允许应用常驻,常驻和自启动需设置。
https://img-blog.csdnimg.cn/img_convert/536c6fa753a625ed50413b7b13bf16a3.webp?x-oss-process=image/format,png
然后将其推回到呆板上
   hdc shell “mount -o remount,rw /”
hdc file send D:\install_list_capability.json /etc/app/install_list_capability.json
然后重启呆板
   hdc shell reboot
记得把设置文件的 type 改回去改为 service
应用安装

因为设置了 singletion 以是需要单用户安装

[*]把 Build 完成的 hap 包推入体系中。
   hdc file send D:\data\start_run.hap /data

[*]使用 bm 命令安装应用
   hdc shell “bm install -p /data/start_run.hap -u 0”

[*]重启体系,然后就可以了
   hdc shell reboot
在这里再加一个卸载的命令,卸载这个应用也是需要 id 的
   hdc shell “bm uninstall -n com.example.start_run -u 0”
写在最后

●假如你以为这篇内容对你还蛮有帮助,我想约请你帮我三个小忙:
●点赞,转发,有你们的 『点赞和批评』,才是我创造的动力。
●关注小编,同时可以期待后续文章ing
页: [1]
查看完整版本: 【鸿蒙南向开辟】OpenHarmony 应用开机自启