当前位置: 首页 > news >正文

Getx学习笔记之中间件鉴权

目录

前言

一、实现步骤

1.添加依赖

2.创建鉴权中间件

3.定义路由

4.设置初始路由

5.模拟登陆状态

二、Getx鉴权步骤总结

三、本文demo示例

四、参考文章


前言

        在 Flutter 中,使用 GetX 可以很方便地实现中间件鉴权(Authentication)。中间件可以在导航之前拦截路由请求,并进行相应的处理,例如检查用户是否已登录。如果未登录,则可以重定向到登录页面。

        本文通过一个登陆页面的例子,介绍下Getx如何实现中间件鉴权。

一、实现步骤

        我们看一下我们要实现的页面:

图1.鉴权页面

1.添加依赖

        在 pubspec.yaml 文件中添加 GetX 依赖:

dependencies:
  flutter:
    sdk: flutter
  get: ^4.6.6

shared_preferences: ^2.2.3

2.创建鉴权中间件

        创建一个中间件类,用于检查用户的登录状态。

        这里是模仿登陆页面,登陆成功之后把登陆成功之后的标记使用SharedPreference保存在本地。中间类从本地读取这个标记,如果没有登陆,重定向到登陆页面。

import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'package:shared_preferences/shared_preferences.dart';
import '../routes.dart';class AuthMiddleware extends GetMiddleware {@overrideRouteSettings? redirect(String? route) {// 检查用户是否已登录// 从 SharedPreferences 中获取登录状态SharedPreferences.getInstance().then((prefs) {bool isLoggedIn = prefs.getBool('isLoggedIn') ?? false;if (!isLoggedIn) {return const RouteSettings(name: Routes.login); // 重定向到登录页面}return null; // 继续导航});return null; // 继续导航}
}

3.定义路由

        在路由配置中应用中间件。

        这里仅有两个页面,首页和登陆页面。实际开发的过程中可能页面比较多,有些页面即使不登录也可以进入,有些页面必须登陆之后才能进入。

import 'package:get/get.dart';
import 'package:your_app_name/middlewares/auth_middleware.dart';
import 'package:your_app_name/pages/home_page.dart';
import 'package:your_app_name/pages/login_page.dart';class Routes {static const home = '/home';static const login = '/login';static final routes = [GetPage(name: home,page: () => HomePage(),middlewares: [AuthMiddleware()], // 应用鉴权中间件),GetPage(name: login,page: () => LoginPage(),),];
}

4.设置初始路由

        在应用程序的入口文件中,设置 GetX 路由。

import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'package:your_app_name/routes/routes.dart';void main() {runApp(MyApp());
}class MyApp extends StatelessWidget {@overrideWidget build(BuildContext context) {return GetMaterialApp(initialRoute: Routes.home,getPages: Routes.routes,);}
}

5.模拟登陆状态

        在实际应用中,你可能会从持久存储(如 SharedPreferences)或服务器端获取用户的登录状态。以下是一个简单的示例,这里仅做演示,逻辑比较简单,用户输入用户名和密码之后,默认用户登录,并且把登陆的凭证保存在本地,同时在应用启动时检查登录状态:

import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'package:shared_preferences/shared_preferences.dart';
import 'package:your_app_name/routes/routes.dart';void main() async {WidgetsFlutterBinding.ensureInitialized();final prefs = await SharedPreferences.getInstance();final isLoggedIn = prefs.getBool('isLoggedIn') ?? false;runApp(MyApp(isLoggedIn: isLoggedIn));
}class MyApp extends StatelessWidget {final bool isLoggedIn;MyApp({required this.isLoggedIn});@overrideWidget build(BuildContext context) {return GetMaterialApp(initialRoute: isLoggedIn ? Routes.home : Routes.login,getPages: Routes.routes,);}
}

二、Getx鉴权步骤总结

        1.自定义一个AuthMiddleware类:实现自定义的中间件类 AuthMiddleware,继承 GetMiddleware。在 redirect 方法中检查用户的登录状态,若未登录则重定向到登录页面。

        2.Routes:定义应用的路由配置,在需要鉴权的路由上应用 AuthMiddleware。

        3.使用 GetMaterialApp 设置路由和初始页面,根据用户的登录状态设置初始路由。

        通过上述步骤,你可以在 GetX 中实现中间件鉴权,确保未登录用户无法访问需要鉴权的页面。根据实际需求,你可以进一步完善鉴权逻辑,例如集成第三方认证服务、处理不同类型的用户权限等。

三、本文demo示例

        本文的代码在这里。

四、参考文章

1.Getx官方文档

2.Getx路由鉴权

http://www.lryc.cn/news/403334.html

相关文章:

  • 介绍 Elasticsearch 中的 Learning to Tank - 学习排名
  • 2024年计算机软考中级【硬件工程师】面试题目汇总(附答案)
  • ThinkPad改安装Windows7系统的操作步骤
  • 微软Edge浏览器全解析教程
  • 【过题记录】7.20
  • Linux系统学习日记——vim操作手册
  • 【深度学习图片】图片清洗,只留下图像中只有一张人脸的,而且人脸是全的
  • 如何在 PostgreSQL 中处理海量数据的存储和检索?
  • 【中项】系统集成项目管理工程师-第2章 信息技术发展-2.2新一代信息技术及应用-2.2.1物联网与2.2.2云计算
  • Redis集群的主从复制原理-全量复制和增量复制-哨兵机制
  • 23年阿里淘天笔试题 | 卡码网模拟
  • 【SpringBoot】单元测试之测试Service方法
  • 剪辑师和小白都能用的AI解说神器,一键把短剧变解说视频-手把手教程-2024
  • 我去,怎么http全变https了
  • IDEA的详细设置
  • 为什么Spring选择使用容器来管理对象,而不是直接使用new
  • 腾讯云发送短信验证码
  • 嵌入式人工智能(13-基于树莓派4B的指纹识别-AS608)
  • 【Vue】`v-on` 指令详解:事件绑定与处理的全面指南
  • 【Spark On Hive】—— 基于电商数据分析的项目实战
  • 哪种SSL证书可以快速签发保护http安全访问?
  • 深入探究理解大型语言模型参数和内存需求
  • maven 私服搭建(tar+docker)
  • 银行业务知识全篇(财务知识、金融业务知识)
  • 解决ElasticJob项目重启ZooKeeper注册冲突以及zkCli删除目录
  • 【EI检索】第二届机器视觉、图像处理与影像技术国际会议(MVIPIT 2024)
  • vscode通过ssh链接远程服务器上的docker
  • 使用NIFI连接瀚高数据库_并从RestFul的HTTP接口中获取数据局_同步到瀚高数据库中---大数据之Nifi工作笔记0067
  • IDEA的工程与模块管理
  • [M前缀和] lc3096. 得到更多分数的最少关卡数目(前缀和+思维)