网罗开发小红书、快手、视频号同名大家好我是展菲目前在上市企业从事人工智能项目研发管理工作平时热衷于分享各种编程领域的软硬技能知识以及前沿技术包括iOS、前端、Harmony OS、Java、Python等方向。在移动端开发、鸿蒙开发、物联网、嵌入式、云原生、开源等领域有深厚造诣。图书作者《ESP32-C3 物联网工程开发实战》图书作者《SwiftUI 入门进阶与实战》超级个体COC上海社区主理人特约讲师大学讲师谷歌亚马逊分享嘉宾科技博主华为HDE/HDG我的博客内容涵盖广泛主要分享技术教程、Bug解决方案、开发工具使用、前沿科技资讯、产品评测与使用体验。我特别关注云服务产品评测、AI 产品对比、开发板性能测试以及技术报告同时也会提供产品优缺点分析、横向对比并分享技术沙龙与行业大会的参会体验。我的目标是为读者提供有深度、有实用价值的技术洞察与分析。展菲您的前沿技术领航员 大家好我是展菲 全网搜索“展菲”即可纵览我在各大平台的知识足迹。 公众号“Swift社区”每周定时推送干货满满的技术长文从新兴框架的剖析到运维实战的复盘助您技术进阶之路畅通无阻。 微信端添加好友“fzhanfei”与我直接交流不管是项目瓶颈的求助还是行业趋势的探讨随时畅所欲言。 最新动态2025 年 3 月 17 日快来加入技术社区一起挖掘技术的无限潜能携手迈向数字化新征程文章目录HarmonyOS 网络请求与数据持久化前言网络请求使用 http 模块发 GET 请求在 UI 线程中更新结果POST 与请求体封装为 Promise可选数据持久化Preferences 轻量键值存储关系型数据库RDB简要总结HarmonyOS 网络请求与数据持久化前言HarmonyOS 应用开发中网络请求和数据持久化是两类最常用的能力前者用于拉取服务端数据后者用于在本地缓存用户数据、配置等。ArkTS 侧通过ohos.net.http、ohos.request等模块发请求通过ohos.data.preferences、关系型数据库等做持久化。本文只讲这两块的核心 API 和典型用法并给出关键代码与注意点不贴完整 Demo。网络请求使用 http 模块发 GET 请求ohos.net.http提供 createHttp()得到 httpRequest 对象后可发起请求。典型流程创建 → 设置 URL/方法/头 → 请求 → 关闭。importhttpfromohos.net.http// 在页面或异步方法中consthttpRequesthttp.createHttp()httpRequest.request(https://api.example.com/list,{method:http.RequestMethod.GET,header:{Content-Type:application/json},connectTimeout:60000,readTimeout:60000},(err,data){if(err){console.error(请求失败,err)return}if(data.responseCode200){constresultJSON.parse(data.resultasstring)// 更新 State驱动 UI 刷新}httpRequest.destroy()})要点回调在子线程执行若要在回调里更新State、刷新 UI需要封装成runOnUIThread或使用异步封装见下务必 destroy请求完成后调用httpRequest.destroy()避免泄漏超时connectTimeout、readTimeout按需设置单位毫秒在 UI 线程中更新结果ArkTS 中 UI 只能在主线程更新而 http 回调可能在工作线程因此需要把「结果处理 状态更新」抛回主线程import{runOnUIThread}fromkit/ArkUI// 在 request 的回调里if(data.responseCode200){constlistJSON.parse(data.resultasstring)runOnUIThread((){this.listDatalist// this 指向 ComponentlistData 为 State})}这样this.listData的变更会在主线程执行触发界面刷新。POST 与请求体POST 请求只需把method改为http.RequestMethod.POST并在extraData里传 body 字符串httpRequest.request(https://api.example.com/submit,{method:http.RequestMethod.POST,header:{Content-Type:application/json},extraData:JSON.stringify({name:test,id:1}),connectTimeout:60000,readTimeout:60000},(err,data){// 同上err/data 处理 destroy})服务端若要求表单编码则Content-Type改为application/x-www-form-urlencodedextraData改为key1value1key2value2等形式。封装为 Promise可选为避免回调嵌套、便于在 async 函数里使用可对 request 做一层 Promise 封装functionrequestT(url:string,options:http.HttpRequestOptions):PromiseT{constreqhttp.createHttp()returnnewPromise((resolve,reject){req.request(url,options,(err,data){req.destroy()if(err){reject(err)return}if(data.responseCode200data.responseCode300){try{resolve(JSON.parse(data.resultasstring)asT)}catch(e){reject(e)}}else{reject(newError(HTTP${data.responseCode}))}})})}在页面里await requestRespType(url, opts)得到结果后再在runOnUIThread里赋给State即可。数据持久化Preferences 轻量键值存储ohos.data.preferences适用于配置项、简单键值对数据以文件形式存在应用沙箱内。获取与读写importdataPreferencesfromohos.data.preferencesimport{common}fromkit.AbilityKit// 在 EntryAbility 或异步上下文中constcontextgetContext(this)ascommon.UIAbilityContextconststoreawaitdataPreferences.getPreferences(context,my_prefs)// 写awaitstore.put(token,xxx)awaitstore.put(userId,100)awaitstore.flush()// 读consttokenawaitstore.get(token,)constuserIdawaitstore.get(userId,0)注意getPreferences为异步需在 async 函数或 Promise 中调用写入后建议调用flush()保证落盘键为 string值为 string | number | boolean 等基础类型在页面中的用法在aboutToAppear()里异步getPreferences并get结果赋给State在用户操作如登录成功时putflush即可实现「打开应用读缓存、操作后写缓存」。关系型数据库RDB简要需要本地表结构、查询条件时可使用关系型数据库。流程一般为获取 RdbStore → 建表若不存在→ insert/update/query/delete。获取 RdbStoreimportrelationalStorefromohos.data.relationalStoreconstconfig:relationalStore.StoreConfig{name:app.db,securityLevel:relationalStore.SecurityLevel.S1}conststoreawaitrelationalStore.getRdbStore(context,config)建表与插入constsqlCreateCREATE TABLE IF NOT EXISTS user ( id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER )awaitstore.executeSql(sqlCreate)constvalueBucket:relationalStore.ValuesBucket{name:张三,age:20}awaitstore.insert(user,valueBucket)查询constpredicatesnewrelationalStore.RdbPredicates(user)predicates.equalTo(age,20)constresultSetawaitstore.query(predicates,[id,name,age])while(resultSet.goToNextRow()){constidresultSet.getLong(resultSet.getColumnIndex(id))constnameresultSet.getString(resultSet.getColumnIndex(name))// 使用 id, name...}resultSet.close()RDB 适合列表、草稿、离线缓存等结构化数据简单配置仍建议用 Preferences两者可搭配使用。总结网络http.createHttp()发请求回调中注意线程用runOnUIThread更新 UI和及时destroy可按需封装为 Promise。持久化配置/简单键值用dataPreferences.getPreferences的 put/get flush结构化数据用 RDB 建表 insert/query。把「请求 → 解析 → 主线程更新 State」和「启动读 Preferences/RDB、操作后写回」串起来即可覆盖大部分 HarmonyOS 应用的数据与持久化场景。