原生鸿蒙的竞争力到底如何?

简介: 长期以来,移动操作系统市场被IOS和安卓所垄断,一直都难以推出完整的自主系统,面临诸多挑战,如推广困难、应用适配难度大,以及技术底座缺乏自主性。但原生鸿蒙操作系统展示其在突破这些瓶颈方面的努力,基于安全牢固的“鸿蒙内核”,上层应用的开发与创新得以实现,不再被卡脖子,更不牵制于外界。本身该系统在OS内核、框架、数据库等方面进行全面自研,实现真正的自主可控。

崛起与挑战

长期以来,移动操作系统市场被IOS和安卓所垄断,一直都难以推出完整的自主系统,面临诸多挑战,如推广困难、应用适配难度大,以及技术底座缺乏自主性。但原生鸿蒙操作系统展示其在突破这些瓶颈方面的努力,基于安全牢固的“鸿蒙内核”,上层应用的开发与创新得以实现,不再被卡脖子,更不牵制于外界。本身该系统在OS内核、框架、数据库等方面进行全面自研,实现真正的自主可控。


image.png

相比原先的鸿蒙版本,HarmonyOS NEXT支持鸿蒙内核和鸿蒙原生应用,不再兼容Android应用。这一转变意味着企业在移动业务场景中必须针对HarmonyOS NEXT开发鸿蒙原生应用,虽然HarmonyOS NEXT目前仍处于推广阶段,但已拥有超过1.1亿行代码和675万注册开发者,越来越多的应用和服务接入,为用户提供更加丰富和智能的体验。

 

安全机制

作为全栈开发者,处理敏感数据的传统方式通常包括加密和解密两个步骤,足以确保数据在存储和传输过程中的安全性。比如使用Java的Cipher类进行AES加密,再通过TLS/SSL协议在网络传输中加密数据,确保防止数据被窃听和篡改,结合对API请求的加密和身份验证,进一步提升了数据安全性,以下为

数据加密:在敏感数据存储之前进行加密处理

Cipher cipher = Cipher.getInstance("AES");  

SecretKeySpec keySpec = new SecretKeySpec(secretKey, "AES");  

cipher.init(Cipher.ENCRYPT_MODE, keySpec);  

byte[] encryptedData = cipher.doFinal(dataToEncrypt.getBytes());  

数据解密:在需要使用数据时进行解密处理:

cipher.init(Cipher.DECRYPT_MODE, keySpec);  

byte[] decryptedData = cipher.doFinal(encryptedData);  

String originalData = new String(decryptedData);  

在网络传输过程中保护敏感数据:

- 使用TLS/SSL:通过HTTPS协议确保数据在传输过程中被加密,防止数据被窃听和篡改

- API安全:对API请求进行加密和身份验证,确保只有经过授权的客户端能够访问敏感数据


尽管应用加密机制相对完善,但用户在授权应用权限时往往对数据采集的具体情况并不清楚,不过原生鸿蒙操作系统的底层安全机制通过透明化敏感数据的处理过程,让用户充分了解哪些数据被采集,如何使用,使得用户在享受个性化服务的同时,能够对自己的数据使用情况心中有数,增强对应用的信任感。这种设计不仅提升了用户体验,也有效保护了用户的隐私权益。

image.png

目前市场上开发者和应用数量众多,若能在底层层面加以限制,从源头做起,将形成良性循环。通过用户主权的设计和严格的安全机制,原生鸿蒙应用市场为开发者提供了构建安全应用的强大基础。这种透明化的数据处理和敏感数据管理不仅提升了用户的信任感,也确保用户能够对自己的数据使用情况有充分了解。在竞争日益激烈的市场环境中,这种安全性和用户信任的提升,无疑成为原生鸿蒙应用市场的一大竞争优势,助力开发者在复杂的生态中脱颖而出。

image.png

VSA安全沙箱SDK能够限制复制、黏贴、分享和转发行为,进一步增强安全性。同时,SDP零信任接入SDK允许用户在零信任模型下安全访问,且无需修改现有的应用架构,简化了开发过程。这种轻量化的嵌入方式不仅降低开发工作量,也提高安全性和效率,实现全面的安全防护,以下是一个伪代码示例。

// 导入VSA安全沙箱SDK和SDP零信任接入SDK  

import VSASandboxSDK  

import SDPZeroTrustSDK  

// 初始化VSA安全沙箱  

function initializeSandbox() {  

   sandbox = new VSASandboxSDK()  

   sandbox.setRestrictions(copy=false, paste=false, share=false, forward=false)  

   sandbox.enable()  

}  

 

// 初始化SDP零信任接入  

function initializeZeroTrustAccess(userCredentials) {  

   sdp = new SDPZeroTrustSDK()  

   sdp.authenticate(userCredentials)  

   if (!sdp.isAuthenticated()) {  

       throw new Error("User authentication failed!")  

   }  

   sdp.grantAccess()  

}  

 

// 主程序入口  

function main() {  

   // 用户输入凭证  

   userCredentials = getUserCredentials()  

 

   // 初始化安全沙箱  

   initializeSandbox()  

   // 初始化零信任接入  

   initializeZeroTrustAccess(userCredentials)  

   // 启动应用主逻辑  

   launchApplication()  

}  

 

// 启动主程序  

main()  

值得注意的是,用户分享的文件具备系统级加密功能,允许用户自主选择加密设置来发送文件,确保只有指定的接受者可以查看文件内容。这有效防止未授权的第三方访问,即使接收者转发文件,未授权的他人也无法解密和查看。这种透明的数据处理流程不仅增强了用户对数据使用的理解,还使用户能够随时查看自身的授权应用权限,促使开发者在应用设计时更加重视隐私保护,从而推动整个行业的良性发展。


再说说安卓以及IOS底层的系统级安全是怎么处理的,安卓系统的安全机制中有一个IPC机制允许不同进程间安全地交换数据,主要通过Binder驱动实现,先了解以下的一些特性:

权限控制:每个Binder调用都可以进行权限验证,只有拥有特定权限的应用才能进行相应的操作。例如,系统服务会在接收调用时检查调用者的UID是否有权限。

安全性隔离:每个应用运行在其独立的进程中,使用用户ID(UID)来隔离不同应用的资源,避免一个应用直接访问另一个应用的数据。

本身权限控制和安全性隔离是安卓系统的重要安全机制,但也存在一些缺陷。虽然Binder调用进行权限验证,但开发者在申请权限时可能会出现过度申请的问题,用户往往会因为权限要求繁琐而拒绝安装应用,降低应用的接受度。其次,尽管每个应用运行在独立的进程中,UID隔离机制防止直接访问,但如果应用的权限配置不当,恶意应用仍有可能通过其他方式获取敏感数据,从而引发数据泄露和安全风险。这些缺陷可能导致用户对应用的信任度下降,影响整体生态的健康发展。


而iOS的安全机制通过应用代码签名和地址空间布局随机化(ASLR)来保护用户数据和系统安全。

在iOS中,所有应用在安装前必须进行代码签名,主要体现在以下两个方面:

身份验证:开发者使用Apple提供的证书进行签名,系统在安装时会验证该签名,以确保应用未被篡改。这一机制有效地保护用户免受恶意软件的攻击。

沙盒机制:每个应用运行在独立的沙盒环境中,限制对系统资源和其他应用数据的访问,确保应用之间的隔离。

尽管代码签名和沙盒机制提供了安全保障,但如果开发者未能有效管理证书或配置沙盒权限,仍可能导致安全风险。此外,应用审核过程虽严谨,但难以完全排除潜在的恶意软件,尤其是在未经过审查的企业应用中。


放眼整个市场,一个安全可靠的底座及应用尤为重要,特别在这个裸奔的信息时代,而星盾隐私安全架构提供了一种有效解决方案,确保应用在未经用户明确统一授权的情况下无权访问其数据,只有在用户明确授权后,应用才能获取相关信息。这一机制将选择权和控制权完全集中在用户手中,增强用户的信任感,而且其多数数据本地化,隐私数据不上云的措施,再也无需担心云数据泄露的风险。


自动化检测前移

将测试活动向开发过程的早期阶段移动,主打的越早发现权限并修复。大致了解这个概念之后,以往的实施策略有如下:

1. 自动化测试:采用自动化测试工具(如Selenium、JUnit、pytest等)来加快测试过程,并确保在每次代码提交时都能快速验证代码的正确性

2. 代码审查:在代码合并之前进行同伴审查,有助于及早发现代码中的问题,并提高代码质量

3. 单元测试:在开发过程中编写单元测试,以验证单个模块或组件的正确性,确保每个部分都能正常工作

4. 集成测试:在组件集成后进行测试,以确保各部分之间的交互正常


常用一种Gitlab CICD模式去集成代码并自动化运行测试,这里贴上以往我内网测试的一套模版:


image.png

HarmonyOS NEXT集成的Hypium自动化测试框架大大简化了测试流程,使得开发者可以更高效地进行软件测试。与传统的CI/CD工具相比,Hypium以插件形式嵌入DevEco Studio,自动生成测试目录、测试类和用例模板,开发者无需从零开始,直接可以进行测试。这种设计不仅提升了使用的便利性,也提高了测试的效率。


Hypium支持两种主要的自动化测试场景:单元测试和UI测试。单元测试框架(HJsUnit)提供了编写和执行单元测试用例的基础接口,并能生成详细的测试报告,帮助开发者快速验证内部逻辑。而UI测试框架(HUiTest)则通过简洁的API使得界面控件的查找和操作变得轻松,支持端到端的自动化测试,确保用户界面的功能符合预期。


以下为Hypium测试模板示例,增加了测试套件开始和结束的日志,以便更好地跟踪测试进度。

import { describe, beforeAll, beforeEach, afterEach, afterAll, it, expect } from '@ohos/hypium';  

 

export default function abilityTest() {  

   describe('ActsAbilityTest', function() {  

       beforeAll(() => {  

           console.info("Test suite starting");  

       });  

 

       afterAll(() => {  

           console.info("Test suite finished");  

       });  

 

       it('assertContain', function() {  

           console.info("it begin");  

           let a = 'abc';  

           let b = 'b';  

           expect(a).assertContain(b);  

           expect(a).assertEqual(a);  

       });  

   });  

}  

总体而言, Hypium框架不仅方便易用,还提供了高效和安全的测试环境,助力开发者提升软件质量,缩短开发周期。


深入探讨开发者服务优势

image.png


写在最后,原生鸿蒙应用市场凭借自主可控的技术底座和强有力的安全隐私保障,展现其强大竞争力。通过引入各类开发者,涵盖社交、金融、健康、教育等多个领域,致力于构建一个丰富的应用生态,这种多样性满足用户的多元需求,也为开发者提供广阔的发展空间。作为一名全栈开发者,深知安全的重要性,在广州的网络攻防演练中,我们每年都会进行一次,以防止信息泄密。每次的应用开发后,始终坚持完好的测开服务,以确保每个应用能够安全上线。


HarmonyOS NEXT的微内核架构和高效的资源管理为开发者提供创建高性能应用的基础,还为开发者提供丰富的支持,包括技术文档、培训课程和社区交流平台,这些资源极大地促进了创新。在开发实践中,发现鸿蒙底层的API和SDK的完善性也增强我们的信任感,确保应用的可靠性。


我们也有理由相信,HarmonyOS NEXT将在未来发挥更大的作用。随着原生鸿蒙应用市场持续构建优质的开发者服务,越来越多开发者融入这一新兴平台,共同贡献智慧,让HarmonyOS NEXT成为企业和用户共同信赖的平台。

相关文章
|
移动开发 JavaScript 前端开发
HarmonyOS鸿蒙应用开发——探索原生与H5通信框架DSBridge
HarmonyOS版DSBridge是一个桥梁库,允许鸿蒙原生环境与JavaScript交互。它兼容Android和iOS的第三方DSBridge核心功能,支持同步和异步调用、命名空间API管理、进度回调及页面关闭监听等功能。主要特性包括适配鸿蒙NEXT版本、支持串行异步并发任务、兼容DSBridge 2.0与3.0版本JS脚本,并提供类形式集中管理API及自定义页面组件注册。源码仓库:HarmonyOS版 - DSBridge-HarmonyOS。安装命令为`ohpm install @hzw/ohos-dsbridge`。通过该库,开发者可以方便地在鸿蒙系统中实现原生与JS的高效交互。
1059 1
|
JavaScript 小程序 API
UniApp X:鸿蒙原生开发的机会与DCloud的崛起之路·优雅草卓伊凡
UniApp X:鸿蒙原生开发的机会与DCloud的崛起之路·优雅草卓伊凡
834 12
UniApp X:鸿蒙原生开发的机会与DCloud的崛起之路·优雅草卓伊凡
|
人工智能 搜索推荐 数据挖掘
原生鸿蒙版小艺APP接入DeepSeek-R1,为HarmonyOS应用开发注入新活力
原生鸿蒙版小艺APP成功接入DeepSeek-R1,为HarmonyOS用户带来更智能高效的交互体验。通过此次升级,用户在编程、学习和工作中的问题可迅速获得专业解答。同时,此举为HarmonyOS应用开发者提供了新的技术参考,激发了更多创新应用场景的开发,助力打造差异化竞争优势,推动HarmonyOS生态繁荣发展。
1261 68
原生鸿蒙版小艺APP接入DeepSeek-R1,为HarmonyOS应用开发注入新活力
|
监控 开发工具 Android开发
ARMS 用户体验监控正式发布原生鸿蒙应用 SDK
阿里云 ARMS 用户体验监控(RUM)推出了针对原生鸿蒙应用的 SDK。SDK 使用 ArkTS 语言开发,支持页面采集、资源加载采集、异常采集及自定义采集等功能,能够全面监控鸿蒙应用的表现。集成简单,只需几步即可将 SDK 接入项目中,为鸿蒙应用的开发者提供了强有力的支持。
870 118
|
人工智能 文字识别 API
|
监控 测试技术 项目管理
鸿蒙原生开发环境的创新与性能优化:从工具到跨平台支持的全方位提升
鸿蒙原生开发环境不断创新与优化,涵盖实时预览、智能代码提示、多设备调试等创新功能,显著提升开发效率和跨平台支持。通过性能优化、用户界面改进、插件支持及详细的错误提示优化,进一步增强用户体验。此外,工具还强化了团队协作、性能监控、自动化测试及社区建设,助力开发者高效工作,推动鸿蒙生态繁荣发展。
846 18
鸿蒙原生开发环境的创新与性能优化:从工具到跨平台支持的全方位提升
|
安全
【HarmonyOS Next】原生沉浸式界面
在实际项目中,为了软件使用整体色调看起来统一,一般顶部和底部的颜色需要铺满整个手机屏幕。因此,这篇帖子是介绍设置的方法,也是应用沉浸式效果。如下图:底部的绿色延伸到上面的状态栏和下面的导航栏
484 6
【HarmonyOS  Next】原生沉浸式界面
|
小程序 测试技术 API
鸿蒙原生开发手记:03-元服务开发全流程(开发元服务,只需要看这一篇文章)
本文详细介绍元服务的开发及上架全流程,涵盖元服务的特点、创建项目、服务卡片、签名打包、开发测试及上架审核等环节,帮助开发者轻松掌握从零开始开发并发布元服务的全过程。元服务以其轻量、免安装、易于使用等特点,成为未来服务提供的重要形式。
2607 13
鸿蒙原生开发手记:03-元服务开发全流程(开发元服务,只需要看这一篇文章)
鸿蒙原生开发手记:02-服务卡片开发
服务卡片是桌面小组件,分为静态和动态两类。本文介绍如何在 DevEco 中创建静态服务卡片,并实现点击事件传参和参数接收。创建时需选择支持的卡片大小,使用 FormLink 实现跳转,参数在 `entryability` 的生命周期方法中接收。注意:服务卡片不支持热重载。
661 1
鸿蒙原生开发手记:02-服务卡片开发
|
Dart 小程序 API
鸿蒙原生开发手记:01-元服务开发
元服务是鸿蒙系统中的一种轻量级应用形态,无需下载即可直接运行,类似于微信小程序但更轻量。使用原生开发,性能和体验更优。创建元服务需使用 DevEco 工具,支持深色模式和服务卡片功能,开发测试和上架流程详见相关文档。
1079 0
鸿蒙原生开发手记:01-元服务开发