React Navigation 身份验证流程

转载于 何洲的个人博客

几乎所有的应用都需要进行身份验证,今天我就来介绍一下如何通过 React Navigation 实现这一流程。我将会使用 Express 构建一个简单的服务器使 Demo 看起来更加真实,验证的过程基于 Token 实现。

Demo 的源码请在 Github 上查看:https://github.com/hezhii/react-native-auth-example

概述

我们的 APP 将会是这样子……

  1. 当用户第一次打开 APP 时将会进入到登录页面,在此页面输入正确的用户名和密码并点击登录后,将会进入到主页。此时,除非用户退出登录,否则无法回到登录页面。

  2. 登录页面还提供了一个“新用户注册”按钮,点击此按钮会进入到注册页面,用户可以在此页面注册成为新用户。

  3. 主页由两个标签页组成,用户可以在“我的”页面通过点击“退出登录”按钮注销登录。注销登录后,除非用户再次登录,否则无法再回到主页。

  4. 如果用户以前登录过,那么当用户打开 APP 后,将会直接进入到主页。

rn_auth_demo.gif

界面及路由

考虑 APP 的概述,我们会用到 4 个界面,分别是:注册、登录、主页、我的,其中“主页”和“我的”是两个标签页,它们组成了 APP 的主界面。因此,我们需要用到两个导航器:TabNavigator 和 StackNavigator,其中 StackNavigator 用来完成注册、登录和 APP 主界面的跳转,而 TabNavigator 则完成主页和我的页面的切换。

路由器的配置如下:

const Main = TabNavigator({
  Home: {
    screen: Home,
    navigationOptions: {
      headerTitle: '主页'
    }
  },
  Profile: {
    screen: Profile,
    navigationOptions: {
      headerTitle: '我的'
    }
  }
}, {
  tabBarOptions: {
    labelStyle: {
      fontSize: 16
    }
  }
});

const AppNavigator = StackNavigator({
  Login: {
    screen: Login,
    navigationOptions: {
      headerTitle: '登录'
    }
  },
  Main: {
    screen: Main
  },
  Register: {
    screen: Register,
    navigationOptions: {
      headerTitle: '注册'
    }
  }
});

export default AppNavigator;

接着,我们在应用入口点(App.js)使用 AppNavigator:

import React, { Component } from 'react';
import {
  StyleSheet,
  View
} from 'react-native';

import AppNavigator from './AppNavigator';

class App extends Component {
  render() {
    return (
      <View style={styles.container}>
        <AppNavigator />
      </View>
    );
  }
}

const styles = StyleSheet.create({
  container: {
    flex: 1
  }
});

export default App;

各个界面及后台服务的代码这里就不贴出来了,请查看相应源码:https://github.com/hezhii/react-native-auth-example/tree/step1

这一步主要完成的工作如下:

  • 后台服务及各界面的 UI。
  • 简单的封装了 fetch API。
  • 点击注册按钮时,使用 navigation.navigate('Register') 跳转到注册界面。
  • 登录请求成功后,利用 NavigationActions.reset()navigation.dispatch(resetAction) 跳转到 APP 主界面并 Reset 路由。
  • 点击登出按钮时,同样 Reset 路由并跳转到登录页面。

这一步实现的效果就和上图中一样,完成了用户注册、登录、登出这一流程。

记住登录状态

完成第一步之后,我们实现了 APP 概述中提到了第 1、第 2 和第 3 个功能点。接下来,我们需要实现第 4 个功能点,也就是实现一个记住登录状态的功能。

在 APP 中通常使用 Token 机制来完成身份验证,这里参考 OAuth2.0 来实现这样的一个机制:

当用户登录成功后,服务器会返回这样的 JSON 数据:

{
  access_token: 'xxxx',
  refresh_token: 'xxxx',
  expires_in: 7200 // 有效时长为 2 小时
}

其中 access_token 用来鉴定用户身份,请求需要权限的接口时需要带上该信息;expires_in 表示 access_token 的有效时长,单位为秒;因为 access_token 的有效时长只有 2 小时,为了避免用户需要再次登录,当 access_token 过期后,可以调用后台接口刷新 token,该接口需要验证 refresh_token,验证通过后,服务器会返回一组新的 token。

当用户登录成功后,APP 需要缓存下用户的 token 信息,在请求敏感信息时,带上 access_token,而当 access_token 过期时,则利用 refresh_token 刷新 token。同时,当用户打开 APP 后,读取 refresh_token 并刷新 token,如果这一操作成功,那么就可以认为用户已经登录,直接进入到 APP 主界面,否则则进入到登录界面。当用户登出时,我们则需要清除本地和服务器上的缓存。

这里涉及到两个关键点:一是如何缓存和读取 token,二是如何根据刷新 token 的结果跳转到指定界面。

缓存和读取 token 推荐使用 react-native-storage,它提供了丰富的 API 帮助我们实现缓存机制。

初始页面的跳转可以通过 initialRouteName 指定,如果刷新 token 成功,则设置为 'Main',否则设置为 'Login'

这一部分的源码:https://github.com/hezhii/react-native-auth-example/tree/step2

实现的效果如下图所示。

rn_auth_demo1.gif

从图中可以看到,当登录成功后,重新加载时会进入到主界面而不是登录界面,而登出后,则会进入到登录界面。

总结

以上就是基于 React Navigation 和 Token 缓存机制实现的身份验证流程,主要涉及到的是 react-navigation 和 react-native-storage 这两个库的使用和 Token 鉴权机制。这只是一种实现思路,更完美的方案我也还在摸索中,期待下次相遇。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,132评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,802评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,566评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,858评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,867评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,695评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,064评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,705评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,915评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,677评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,796评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,432评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,041评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,992评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,223评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,185评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,535评论 2 343

推荐阅读更多精彩内容