Flutter for OpenHarmony: Flutter 三方库 openid_client 深度打通鸿蒙应用的单点登录 (SSO)(基于 OpenID Connect 标准)

Flutter for OpenHarmony: Flutter 三方库 openid_client 深度打通鸿蒙应用的单点登录 (SSO)(基于 OpenID Connect 标准)

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

在这里插入图片描述

前言

在现代企业级 OpenHarmony 应用中,为了安全和便捷,往往会使用 OpenID Connect (OIDC) 协议进行统一身份认证。无论是集成 Google 登录、GitHub 登录,还是对接企业内部的 Keycloak、Okta 等身份提供商(IdP),我们都需要一个健壮的库来处理繁杂的 OAuth2 握手流程。

openid_client 是一个功能极其全面的 Dart 实现。它能够自动发现服务器端点(Discovery)、处理 PKCE 流程并安全地交换令牌,是构建高安全级别鸿蒙应用的首选。

一、核心认证流程

OIDC 认证流程通常是通过浏览器重定向完成的,openid_client 充当了流程的指挥官。

身份服务器 (IdP)openid_client鸿蒙 App身份服务器 (IdP)openid_client鸿蒙 App用户在浏览器登录并授权发起授权请求获取 Discovery 文档 (well-known)返回 endpoints打开浏览器授权页重定向回 App (带 Code)传入 Code交换 Access & ID Token返回 JWT 令牌完成登录

二、核心 API 实战

2.1 自动发现服务器端点

import'package:openid_client/openid_client.dart';voidinitClient()async{// 💡 只需要输入 OIDC 基地址,自动拉取 .well-known/openid-configurationvar uri =Uri.parse('https://keycloak.harmony.com/realms/ohos');var issuer =awaitIssuer.discover(uri);// 初始化客户端var client =Client(issuer,"my-ohos-app-client-id");print('✅ 授权端点: ${issuer.metadata.authorizationEndpoint}');}
在这里插入图片描述

2.2 启动身份验证

// 💡 定义需要的权限范围 (Scopes)var authenticator =Authenticator( client, scopes:['openid','profile','email'], port:8888,// 桌面端/开发模式回调端口);var credential =await authenticator.authorize();
在这里插入图片描述

2.3 获取用户信息

var userInfo =await credential.getUserInfo();print('登录用户姓名: ${userInfo.name}');
在这里插入图片描述

三、OpenHarmony 平台适配

3.1 跨端重定向适配

💡 技巧:在鸿蒙真机上,OAuth2 的回调通常是通过系统 Custom Scheme (如 myohosapp://callback) 实现的。你需要确保在 module.json5 中声明了该 Scheme,并将截获的 URL 传入 credential 对象的处理函数中。

3.2 证书与 HTTPS

生产环境下的 OIDC 必须强制 HTTPS。鸿蒙系统的证书校验非常严格,请确保你的身份服务器配置了合法的、受信任的证书,否则 Issuer.discover 会抛出证书异常。

四、完整实战示例:鸿蒙企业级单点登录模块

本示例展示如何优雅地封装一个登录服务。

import'package:openid_client/openid_client_io.dart';import'package:url_launcher/url_launcher.dart';classOhosLoginService{finalString _clientId ="ohos_business_app";finalString _issuerUrl ="https://id.harmony.com";Future<void>login()async{print('🚀 正在启动鸿蒙企业 SSO 认证...');// 1. 发现服务器final issuer =awaitIssuer.discover(Uri.parse(_issuerUrl));final client =Client(issuer, _clientId);// 2. 构造授权逻辑 (适配鸿蒙外部浏览器启动)final authenticator =Authenticator( client, scopes:['openid','offline_access'], urlLancher:(url)async{if(awaitcanLaunchUrl(Uri.parse(url))){awaitlaunchUrl(Uri.parse(url), mode:LaunchMode.externalApplication);}},);// 3. 等待认证结果final credential =await authenticator.authorize();// 4. 安全地交换 Token (或者处理凭证)final tokenResponse =await credential.getTokenResponse();print('✅ 登录成功!AccessToken 发放完毕');print('Token 内容: ${tokenResponse.accessToken}');}}
在这里插入图片描述

五、总结

openid_client 软件包是 OpenHarmony 开发者在构建标准化身份架构时的数字盾牌。它遵循 RFC 标准,极大地简化了 OIDC 中极其复杂的令牌刷新机制和安全性验证(如 nonce 检查、签名验证)。在构建对安全性有极高要求的鸿蒙大型应用时,采用此类标准化的第三方库,能有效降低认证系统的漏洞风险。

Read more

Flutter 三方库 http_cache_hive_store 的鸿蒙化适配指南 - 在鸿蒙系统上构建极致、透明、工业级的 HTTP 二级缓存与 Hive 数据库持久化联动引擎

Flutter 三方库 http_cache_hive_store 的鸿蒙化适配指南 - 在鸿蒙系统上构建极致、透明、工业级的 HTTP 二级缓存与 Hive 数据库持久化联动引擎

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 三方库 http_cache_hive_store 的鸿蒙化适配指南 - 在鸿蒙系统上构建极致、透明、工业级的 HTTP 二级缓存与 Hive 数据库持久化联动引擎 在鸿蒙(OpenHarmony)系统的端云一体化网络架构、针对高频 API 的请求压实(Debounce)或者是需要实现“秒开离线”的网络应用场景中,如何让 http 或 dio 库自动具备缓存能力,并将缓存物理落地到极速的 Hive 非关系型数据库中?http_cache_hive_store 为开发者提供了一套工业级的、基于 Hive 的网络响应持久化缓存方案。本文将深入实战其在鸿蒙端网络响应加速中的应用。 前言 什么是 HTTP

By Ne0inhk
Flutter 三方库 flutter_adaptive_scaffold 的鸿蒙化适配指南 - 掌握一套代码适配全场景终端的自适应架构技术、助力鸿蒙应用构建从手机到平板及折叠屏的极致无缝交互体系

Flutter 三方库 flutter_adaptive_scaffold 的鸿蒙化适配指南 - 掌握一套代码适配全场景终端的自适应架构技术、助力鸿蒙应用构建从手机到平板及折叠屏的极致无缝交互体系

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 三方库 flutter_adaptive_scaffold 的鸿蒙化适配指南 - 掌握一套代码适配全场景终端的自适应架构技术、助力鸿蒙应用构建从手机到平板及折叠屏的极致无缝交互体系 前言 在 OpenHarmony 鸿蒙应用追求“万物互联、全场景覆盖”的伟大进程中,屏幕尺寸的多样性(从 6 英寸手机到 12 英寸平板,再到 2D/3D 模式切换的折叠屏)是每一位 UI 开发者必须正面迎接的挑战。如何在不为每种设备重写 UI 的前提下,实现导航栏自动从“底部”平滑流转到“侧边”?如何在宽屏模式下自动开启“双栏(Master-Detail)”布局?flutter_adaptive_scaffold 作为一个由 Flutter

By Ne0inhk
AIGC | Midjourney使用指南,直接拿捏~

AIGC | Midjourney使用指南,直接拿捏~

目录 前言:第一篇ZEEKLOG博客,还请各位大佬多多指教!! 一、认识Midjourney 二、Midjourney算法原理 三、Midjourney基本操作指南 1、安装 2、使用演示及基本分区讲解 3、命令解析 4、后缀解析 总结:     前言:第一篇ZEEKLOG博客,还请各位大佬多多指教!!   一、认识Midjourney   Midjourney是由David Holz 2022年3月推出的一款AI制图工具。处于聊天软件discord中,主要功能涵盖图像生成、风格化、变体生成、图生图等,且提供高级工具精细控制生成过程。 使用上需创建账户、获邀请后通过Discord频道输入文字提示来操作。相比于SD(stable diffusion) MJ随机性更大,细节处理精度不够。 二、Midjourney算法原理   MJ基于深度学习中的生成对抗网络(GAN)和扩散模型等技术。 * 生成对抗网络(GAN):由生成器和判别器组成。生成器的任务是根据输入的随机噪声和文本描述等信息,生成尽可能逼真的图像;

By Ne0inhk
Flutter 三方库 objectbox_generator — 自动化构建鸿蒙极速 NoSQL 数据库映射(适配鸿蒙 HarmonyOS Next ohos)

Flutter 三方库 objectbox_generator — 自动化构建鸿蒙极速 NoSQL 数据库映射(适配鸿蒙 HarmonyOS Next ohos)

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net。 Flutter 三方库 objectbox_generator — 自动化构建鸿蒙极速 NoSQL 数据库映射(适配鸿蒙 HarmonyOS Next ohos) 在高性能移动应用开发中,本地数据的持久化存储效率往往是决定用户感知流畅度的木桶短板。传统的 SQLite 虽然结构化程度高,但在处理大规模对象关系映射(ORM)时,复杂的 SQL 拼接和反射解析往往会成为性能瓶颈。 ObjectBox 作为一个专为移动设备打造的、跨平台的超高速 NoSQL 数据库,已经成为了许多追求极致体验开发者的首选。而在 Flutter for OpenHarmony 开发中,配合 objectbox_generator,我们可以通过注解驱动的自动化流程,掌握这套高性能数据库的核心用法。 ⚠️ 鸿蒙适配现状提示:截至本文撰写时,ObjectBox 的 Dart 插件尚未提供官方的 OpenHarmony

By Ne0inhk