Flutter for OpenHarmony: Flutter 三方库 http_multi_server 在鸿蒙上同时开启多地址 HTTP 服务(局域网协作神器)

Flutter for OpenHarmony: Flutter 三方库 http_multi_server 在鸿蒙上同时开启多地址 HTTP 服务(局域网协作神器)

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net

在这里插入图片描述

前言

在进行 OpenHarmony 应用开发时,有时我们需要在 App 内部启动一个本地服务器,例如:

  • 为内嵌的 Webview 提供本地资源访问。
  • 在局域网内进行设备间的数据同步(如投屏、文件传输)。
  • 进行自动化集成测试。

通常的 HttpServer.bind 只能绑定一个地址(要么是 localhost,要么是具体的 IP)。而 http_multi_server 允许你一次性绑定多个地址,让你的鸿蒙 App 同时在本地回环和局域网 IP 上提供服务。

一、核心原理解析

它实际上是一个 HttpServer 的聚合器。它通过同时启动多个底层的 Dart HttpServer 实例,并将它们分发的请求流(Request Stream)进行合并。

鸿蒙 Flutter App

HttpMultiServer

HttpServer (localhost:8080)

HttpServer (192.168.1.10:8080)

HttpServer (::1:8080)

统一的 HttpRequest 流

业务处理逻辑 (如 shelf)

二、核心 API 实战

2.1 绑定所有可用地址

这是最通用的用法,会自动绑定 IPv4 和 IPv6 的所有可用环回或全局地址。

import'package:http_multi_server/http_multi_server.dart';voidstartServer()async{// 💡 在 8080 端口绑定所有可用地址final server =awaitHttpMultiServer.bind('any',8080);print('服务器已启动,正在监听:${server.address}'); server.listen((request){ request.response ..write('来自鸿蒙本地服务器的消息')..close();});}
在这里插入图片描述


在这里插入图片描述

2.2 绑定特定列表

final server =awaitHttpMultiServer.bind([InternetAddress.loopbackIPv4,'192.168.31.100',// 💡 鸿蒙真机的局域网 IP],8081);
在这里插入图片描述


在这里插入图片描述

2.3 获取实际监听地址

由于是多地址绑定,你可以通过属性查看具体详情。

print('连接地址列表: ${server.connections}');
在这里插入图片描述


在这里插入图片描述

三、OpenHarmony 平台适配

3.1 端口占用处理

在鸿蒙设备上启动服务器前,请务必检查端口是否被系统或其他应用占用。建议使用随机端口(端口号设为 0)。

3.2 局域网访问权限

💡 注意:如果希望局域网内的其他设备(如 PC 浏览器)访问鸿蒙手机上的该服务,除了 ohos.permission.INTERNET,通常还需要确保手机和电脑在同一个 WiFi 下,且关闭了 AP 隔离。

3.3 性能与能耗建议

在鸿蒙系统中,后台运行的 HTTP 服务可能会被系统挂起。如果用于长时间的文件传输,建议配合鸿蒙的“持续任务”申请相关的保活权限。

四、完整实战示例:鸿蒙企业级多端口分发中心

本示例展示了如何结合 shelf 框架,在鸿蒙设备上构建一个结构化的多址 HTTP 服务。

import'package:http_multi_server/http_multi_server.dart';import'package:shelf/shelf.dart';import'package:shelf/shelf_io.dart'as shelf_io;voidsetupOhosService()async{// 1. 💡 绑定所有地址 (any) 在 9000 端口final multiServer =awaitHttpMultiServer.bind('any',9000);// 2. 💡 路由处理逻辑 (包含路径过滤与 HTML 返回)Response_handler(Request request){// 过滤浏览器自动发起的图标请求if(request.url.path =='favicon.ico')returnResponse.notFound(null);returnResponse.ok('<h1>🚀 鸿蒙企业中心</h1><p>已成功处理来自 ${request.url.path} 的请求</p>', headers:{'content-type':'text/html; charset=utf-8'},);}// 3. 💡 集成 Shelf 管道与多址监听器var pipeline =constPipeline().addMiddleware(logRequests()).addHandler(_handler);// 💡 将 multiServer 实例传给 shelf_io 进行分发 shelf_io.serveRequests(multiServer, pipeline);print("✅ 服务已上线: http://localhost:9000");}
在这里插入图片描述


在这里插入图片描述

五、总结

http_multi_server 为 OpenHarmony 开发者处理复杂的网络拓扑提供了极大的便利。它屏蔽了 IPv4/IPv6 以及不同网络接口的底层差异,让你能通过同一套逻辑实现“内外网同时监听”。无论是做本地调试工具还是跨设备分发功能,它都是构建鸿蒙嵌入式服务的标准底板。

Read more

JavaScript 前端开发:从入门到精通的奇幻之旅

JavaScript 前端开发:从入门到精通的奇幻之旅

目录 一、引言 二、JavaScript 基础 (一)变量与数据类型 (二)运算符 (三)控制结构 三、函数 (一)函数定义与调用 (二)函数作用域 (三)闭包 四、DOM 操作 (一)DOM 简介 (二)获取元素 (三)修改元素属性 (四)添加和删除元素 五、事件处理 (一)事件简介 (二)添加事件处理程序 (三)常见事件类型 一、引言 在当今的互联网世界中,前端开发扮演着至关重要的角色。而 JavaScript 无疑是前端开发领域的核心技术之一。它就像一把神奇的钥匙,打开了创建交互式网页的大门。无论是炫酷的动画效果、

By Ne0inhk

Java集成PaddlePaddle OCR:让文字识别变得如此简单

还在为Java项目中需要文字识别功能而烦恼吗?传统方案要么依赖复杂的Python环境,要么调用云端API存在延迟和安全风险。现在,通过SmartJavaAI项目,你可以轻松实现Java环境下的离线OCR识别,无需任何Python依赖! 【免费下载链接】SmartJavaAIJava免费离线AI算法工具箱,支持人脸识别(人脸检测,人脸特征提取,人脸比对,人脸库查询,人脸属性检测:年龄、性别、眼睛状态、口罩、姿态,活体检测)、目标检测(支持 YOLO,resnet50,VGG16等模型)等功能,致力于为开发者提供开箱即用的 AI 能力,无需 Python 环境,Maven 引用即可使用。目前已集成 RetinaFace、SeetaFace6、YOLOv8 等主流模型。 项目地址: https://gitcode.com/geekwenjie/SmartJavaAI 技术解密:PaddlePaddle与Java的完美融合 SmartJavaAI采用DJL(Deep

By Ne0inhk
Bun替代Nodejs,JavaScrpit运行新环境-Bun,更快、更现代的开发体验

Bun替代Nodejs,JavaScrpit运行新环境-Bun,更快、更现代的开发体验

nodejs我想很多人在使用,已经得到广泛运用。但今天介绍一款比node.js高阶的一个新组件Bun,它在HTTP服务器性能、文件系统操作、启动时间、包安装时间性能上高于node.js。 什么是bun,Bun的设计理念是开箱即用,减少配置和依赖,让开发者可以更专注于编写代码。Bun是一个全新的JavaScript运行时和工具链,它的核心目标是替代Node.js,提供更快的性能、更简洁的API和更好的开发体验。Bun使用JavaScriptCore引擎(也是Safari浏览器使用的引擎),V8引擎是Node.js使用的引擎,这是其性能优势的主要来源之一。 Bun不仅是一个运行时,它还集成了包管理器、打包工具、测试运行器等功能,目标成为一站式的JavaScript开发平台。我这里重点对这两位前端的主角在性能、内置功能、环境、兼容性、nodejs项目迁移、bun的适用场景进行对比总结。 性能优势 启动速度更快 Bun的底层做了大量的优化,启动速度比Node.js快10-20倍。这主要是因为Bun使用了JavaScriptCore引擎,特别是在微服务和serverless环境中,由

By Ne0inhk
使用飞算JavaAI实现在线图书借阅平台

使用飞算JavaAI实现在线图书借阅平台

标签<JavaAI> 在软件开发领域,寻找高效的开发工具一直是开发者的追求。飞算 JavaAI 作为一款新兴的 AI 辅助开发工具,宣称能实现从需求分析到代码生成的高效流程。本次,我选择使用飞算 JavaAI 开发在线图书借阅平台,并将生成的项目转换为 SpringBoot 项目,沉浸式体验其在实际开发中的表现,同时对比同类产品,探索它在开发效率、代码质量等方面的优势与不足。 一、飞算 JavaAI 操作流程全记录 (一)需求分析与功能拆解 在线图书借阅平台需要满足多方面的功能需求,包括用户管理(注册、登录、个人信息维护、权限控制)、图书资源管理(信息录入、分类、搜索、展示)、借阅管理(申请、审批、记录追踪)、归还管理(归还处理、逾期提醒、罚款计算)、预约管理(预约图书、

By Ne0inhk