Flutter 三方库 galileo_mysql 的鸿蒙化适配指南 - 支持 MySQL 8.0 协议、高性能长连接与异步事务处理

Flutter 三方库 galileo_mysql 的鸿蒙化适配指南 - 支持 MySQL 8.0 协议、高性能长连接与异步事务处理

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

Flutter 三方库 galileo_mysql 的鸿蒙化适配指南 - 支持 MySQL 8.0 协议、高性能长连接与异步事务处理

前言

在 Flutter for OpenHarmony 的应用开发中,直接在端侧进行数据库操作虽然不是主流(通常通过 API),但在某些边缘计算或内网工具类场景下,直接连接 MySQL 数据库依然是刚需。galileo_mysql 作为一个纯 Dart 实现的 MySQL 驱动,其天然的跨平台属性使其成为鸿蒙端直接操作 MySQL 的首选。本文将详细介绍如何在 OpenHarmony 环境下适配并使用该库。

一、原理解析 / 概念介绍

1.1 基础原理

galileo_mysql 是基于 MySQL 客户端/服务器协议的纯 Dart 实现。它通过底层 Socket 与 MySQL Server 进行通信,支持认证、查询、结果解析等核心流程。

Flutter App (OpenHarmony)

galileo_mysql 驱动

Socket 通信 (Dart IO)

MySQL Server

1.2 核心优势

  • 纯 Dart 实现:不依赖原生 C 库,适配鸿蒙零门槛。
  • 支持 MySQL 8.0:兼容最新的认证插件。
  • 连接池管理:有效减少频繁建连带来的性能损耗。
  • 全异步设计:完美契合 Flutter 的事件循环模式。

二、鸿蒙基础指导

2.1 适配情况

  1. 是否原生支持? 是,基于 Dart 标准库 dart:io
  2. 是否鸿蒙官方支持? 社区支持。
  3. 是否需要安装额外的 package? 不需要,直接引入即可。

2.2 适配代码

在鸿蒙工程的 pubspec.yaml 中添加依赖:

dependencies:galileo_mysql: ^2.1.0 

由于是纯 Dart 库,在鸿蒙端无需配置 module.json5 中的特殊原生权限,只需确保应用拥有网络访问权限。

三、核心 API / 组件详解

3.1 快速上手

API说明
MySqlConnection.connect()异步建立数据库连接
query()执行 SQL 查询
execute()执行非查询 SQL(如 INSERT/UPDATE)
transaction()开启事务处理

3.2 基础配置

import'package:galileo_mysql/galileo_mysql.dart';Future<void>basicConnect()async{final settings =ConnectionSettings( host:'192.168.1.100',// 数据库地址 port:3306, user:'root', password:'password', db:'test_db');// 建立连接final conn =awaitMySqlConnection.connect(settings);print('鸿蒙端已成功连接至 MySQL!');await conn.close();}

四、典型应用场景

4.1 数据查询

Future<void>queryData()async{final conn =awaitMySqlConnection.connect(settings);// 查询用户表var results =await conn.query('select name, email from users where id = ?',[1]);for(var row in results){print('用户名称: ${row[0]}, 邮箱: ${row[1]}');}await conn.close();}

4.2 事务处理

Future<void>runTransaction()async{final conn =awaitMySqlConnection.connect(settings);await conn.transaction((ctx)async{await ctx.query('update accounts set balance = balance - 100 where id = 1');await ctx.query('update accounts set balance = balance + 100 where id = 2');print('鸿蒙端转账事务执行成功');});await conn.close();}

五、OpenHarmony 平台适配挑战

5.1 网络沙箱限制

鸿蒙系统对网络访问有严格的沙箱管控。在真机调试时,必须在 module.json5 中声明 ohos.permission.INTERNET 权限,否则 Socket 连接会直接被系统拦截。

5.2 字符编码转换

在处理中文数据时,需确保 MySQL Server 编码为 utf8mb4galileo_mysql 底层会自动处理 Dart 字符串到 UTF-8 的转换,但在复杂的中文字符集环境下,建议显式设置数据库连接校对集。

六、综合实战演示

import'package:flutter/material.dart';import'package:galileo_mysql/galileo_mysql.dart';classMySqlDemoextendsStatefulWidget{@override _MySqlDemoState createState()=>_MySqlDemoState();}class _MySqlDemoState extendsState<MySqlDemo>{String _status ="等待连接...";Future<void>_testConnection()async{try{final settings =ConnectionSettings( host:'your_mysql_host', user:'admin', password:'password', db:'demo');final conn =awaitMySqlConnection.connect(settings);setState((){ _status ="鸿蒙真机连接 MySQL 成功!";});await conn.close();}catch(e){setState((){ _status ="连接失败: $e";});}}@overrideWidgetbuild(BuildContext context){returnScaffold( appBar:AppBar(title:Text('MySQL 鸿蒙适配演示')), body:Center( child:Column( mainAxisAlignment:MainAxisAlignment.center, children:[Text(_status),ElevatedButton( onPressed: _testConnection, child:Text('点击测试连接'),),],),),);}}

七、总结

galileo_mysql 在 Flutter for OpenHarmony 上的表现非常稳定。由于其纯 Dart 的特性,开发者可以无缝从其他平台迁移数据库逻辑。只要处理好鸿蒙的网络权限和 Socket 连接稳定性,它就能成为你鸿蒙应用中可靠的数据引擎。

Read more

llama.cpp加载多模态gguf模型

llama.cpp预编译包还不支持cuda12.6 llama.cpp的编译,也有各种坑 llama.cpp.python的也需要编译 llama.cpp命令行加载多模态模型 llama-mtmd-cli -m Qwen2.5-VL-3B-Instruct-q8_0.gguf --mmproj Qwen2.5-VL-3B-Instruct-mmproj-f16.gguf -p "Describe this image." --image ./car-1.jpg **模型主gguf文件要和mmporj文件从一个库里下载,否则会有兼容问题,建议从ggml的官方库里下载 Multimodal GGUFs官方库 llama.cpp.python加载多模态模型 看官方文档 要使用LlamaChatHandler类,官方已经写好了不少多模态模型的加载类,比如qwen2.5vl的写法: from llama_cpp import Llama

By Ne0inhk
2026年Midjourney AI 图像生成器使用教程详解

2026年Midjourney AI 图像生成器使用教程详解

Midjourney 是一款领先的 AI 图像生成工具,用户只需输入简单的文本描述(提示词),即可快速生成高质量、富有艺术感的图像。它主要通过 Discord 平台操作,无需本地安装,但需要订阅付费计划。本文将系统介绍 Midjourney 的核心功能、详细使用教程、价格方案以及提升出图效果的实用技巧,适合设计师、内容创作者和 AI 绘画新手阅读。 一、什么是 Midjourney? Midjourney 是一个由独立研究实验室开发的人工智能图像生成程序,能够根据用户输入的文字描述生成数字图像。它通过深度学习模型理解自然语言,并将其转化为细节丰富、风格多样的视觉作品。 由于其出色的艺术表现力和视觉冲击力,Midjourney 已成为设计师、插画师、品牌创意人员以及 AI 爱好者广泛使用的工具之一。 Midjourney 核心特点 * 文本生成图像:将抽象想法直接转化为可视画面 * 高艺术质量:在光影、构图、风格化方面尤为出色 * 云端运行:通过 Discord 操作,

By Ne0inhk
llama.cpp重大更新:自带Web UI,性能超越Ollama,本地大模型部署新选择!

llama.cpp重大更新:自带Web UI,性能超越Ollama,本地大模型部署新选择!

Ollama 背后执行推理的核心技术其实是由 llama.cpp 承担的,GGUF 模型格式也是由 llama.cpp 的作者所开发。 现在 llama.cpp 迎来重大更新,它也有了自己的 Web UI,我测试了安装部署和自行打包,很多地方确实比 Ollama 还有方便好用。 官方介绍,优势如下: * 完全免费、开源且由社区驱动 * 在所有硬件上表现出色 * 高级上下文和前缀缓存 * 并行和远程用户支持 * 极其轻量级且内存高效 * 充满活力且富有创造力的社区 * 100% 隐私 使用之前需要先安装 llama.cpp server 我还是喜欢命令行直接安装 ## Winget (Windows)winget install llama.cpp## Homebrew (Mac and Linux)brew install llama.

By Ne0inhk
工具篇-如何在Github Copilot中使用MCP服务?

工具篇-如何在Github Copilot中使用MCP服务?

Model Context Protocol (MCP) 是由 Anthropic 公司于 2024 年 11 月推出的一种开放协议标准,目的在于标准化 LLM 与外部数据源、工具及服务之间的交互方式。MCP 被广泛类比为“AI 领域的 USB-C 接口”。 一、vscode的安装 下载vscodeVisual Studio Code - Code Editing. Redefined安装完成打开 选择copilot,这个是AI助手,帮助你编程  然后注册登录,可以使用GitHub的账号登录,很多工具都可以通过GitHub帐号登录,所以注册一个GitHub帐号是很有必要的。 二、使用MCP 2.1 准备好MCP 先按这篇文章准备好高德地图的MCP:工具篇-Cherry Studio之MCP使用-ZEEKLOG博客 2.2 在Github Copilot中配置 MCP服务

By Ne0inhk