flutter应用开发中集成极光推送(flutter极光推送第一篇)

题记
—— 执剑天涯,从你的点滴积累开始,所及之处,必精益求精,即是折腾每一天。

重要消息


本文章将讲述:

  • 在 flutter 项目中集成极光推送
  • 在 flutter 项目中初化极光推送并接收到消息
  • 在 flutter 项目中,对Android ios 不同平台的配制

1 简述

极光推送,英文简称 JPush,免费的第三方消息推送服务,官方也推出众多平台的SDK以及插件。
如下图:
在这里插入图片描述
我们本文章讲述的是在 Flutter 应用程序开发中集成极光推送,参考官方极光推送文档中-客户端集成插件中 有提供极光推送的 flutter 插件,所以首先我们可以在 flutter 项目中直接使用这个插件。
在这里插入图片描述

2 flutter 项目中集成官方提供的 极光推送flutter插件
2.1 flutter 项目中添加 极光推送依赖
2.1.1 通过git 的方式来添加依赖(方式一)

极光推送flutter插件github
在 flutter 项目中的 pubspec.yaml 配制文件中添加 git 依赖

# 极光推送插件
  jpush_flutter:
    # git 依赖方式
    git:
      # git 依赖的地址
      url: git://github.com/jpush/jpush-flutter-plugin.git
      # git 仓库中的分支
      ref: master

如下图示:
在这里插入图片描述
点击 Packages get 下载依赖
在这里插入图片描述
或者直接在terminal 命令行中 使用 flutter packages get 来加载依赖
在这里插入图片描述
直接通过git 的方式从 github上加载,与你的网速有很大关系,也很有可能加载不成功,需要耐心等待,小编通过此方式加载时就花了比较长的时间。

2.1.2 通过本地添加极光推送 flutter 插件依赖(方式二)

在极光推送 flutter 插件官方github中,我们点击下载依赖库


然后把下载下来的 zip 文件解压,放到一个目录中,小编这里是放在了与项目同一级的目录空间中了,如下图
在这里插入图片描述
然后在 flutter 项目中的 pubspec.yaml 配制极光推送的本地依赖如下


  # 极光推送插件
  jpush_flutter:
    path: ../jpush-flutter-plugin
  • 注: 在这里使用到的 …/ 是校对路径的表示方法,当然也可以使用jpush-flutter-plugin文件夹的全路径。

如图所示:
在这里插入图片描述

2.1.3 通过 pub.dev 添加极光推送 flutter 插件依赖(方式三)
  • pub 是Google官方的Dart Packages仓库,类似于node中的npm仓库,android中的jcenter,我们可以在上面查找我们需要的包和插件。

我们可以访问国内的pub仓库来更快的搜索我们需要的插件
在这里插入图片描述

然后在 flutter 项目中的 pubspec.yaml 配制极光推送的pub依赖如下

  jpush_flutter: 0.1.0

或者写成

  jpush_flutter: ^0.1.0
  • 注: 两种写法的区别是 后者会自动下载更高版本的,比如说这里配制的是 0.1.0 ,当 pub 仓库中的版本升级为 0.1.3 的时候,那么我们项目中本地依赖的版本不一定是 当前设置的 0.1.0 版本,而是其他版本

或者写成

  jpush_flutter: any
  • 注: 与前者的区别是 会根据当前的项目环境加载适合当前项目环境中的版本插件,如有时我们指定版本加载时,会出现各种异常的冲突,当几个版本中与你使用到的功能无太大差异时,就可以考虑使用这种方法来简单粗暴的解决。

配制好依赖后,我们点击 package get 来加载依赖:
在这里插入图片描述

2.1.4 极光推送flutter插件依赖成功

在 flutter 项目中有多种方式方法来依赖 极光推送的插件,那么依赖成功的标识如下图所示:
在这里插入图片描述


3 在 flutter 项目中初始化极光推送

我们可以考虑在项目启动的时候配置初始化极光推送

3.1 第一步 导包
import 'package:jpush_flutter/jpush_flutter.dart';
3.2 第二步 初始化
import 'package:flutter/material.dart';
import 'package:jpush_flutter/jpush_flutter.dart';

import 'index_page.dart';


///程序入口
void main() => runApp(RootApp());

class RootApp extends StatefulWidget{
  @override
  State<StatefulWidget> createState() {
    return RottAppState();
  }

}

class RottAppState extends State<RootApp>{

  ///根布局的初始化
  @override
  void initState() {
    super.initState();
    ///创建 JPush
    JPush jpush = new JPush();
    ///配置应用 Key
    jpush.setup(
      appKey: "替换成你自己的 appKey",
      channel: "theChannel",
      production: false,
      /// 设置是否打印 debug 日志
      debug: true, 
    );
  }
  @override
  Widget build(BuildContext context) {

    ///来构建
    return MaterialApp(
      ///应用程序默认显示的页面
      home: IndexPage(),
    );
  }

}

这里使用到了 appKey

3.3 配置 flutter 项目中android平台的相关信息

然后在 android 目录下配置 build.gradle
android 清单文件配置
极光开发者平台中创建你的应用程序
在这里插入图片描述
然后配置推送设置 android
在这里插入图片描述
这里的应用包名对应上述 android 目录下的 build.gradle 中的applicationId

配置好后运行flutter 项目
在这里插入图片描述
运行android手机上 会有 Running Gradle task … 的提示,去 maven jcenter 下载 android 平台使用到的依赖库以及os库等。

在这里插入图片描述
走到这里,flutter 项目中,极光推送在android方面便配制好了。
日志信息如下
在这里插入图片描述
然后在极光开发者平台发送测试消息

在这里插入图片描述
然后在运行的手机上我们可以看到:
在这里插入图片描述

3.4 配置 flutter 项目中 ios 平台的极光推送相关信息

在 xcode 中打开 flutter 项目
在这里插入图片描述
然后在 xcode 目录中
在这里插入图片描述
然后在极光开发者平台中配制 ios 的相关推送认证
在这里插入图片描述
然后在这里配置 ios 的推送证书推送证书生成可参考 官方文档 证书设置指南
在这里插入图片描述
配制好证书后 运行 flutter 项目于 iphone 手机上
在这里插入图片描述

也可以在 xcode 中进行运行查看日志
在这里插入图片描述


4 错误处理

4.1 错误一

在这里插入图片描述
需要在 android 目录下配置
android 清单文件配置

4.2 android ios 平台无法接收到推送消息

在注册 推送的时候,可以先添加上接收通知消息的权限申请,申请成功权限后再进行注册.


本小节完结,如有疑问可回复评论

早起的年轻人 CSDN认证博客专家 移动开发 项目管理 Java
只要用心去做,每一件事情还是有可能成功的,当然成功是没有界限的,只不过是达到自己心里的那个目标,公众号:我的大前端生涯,一个爱喝茶的程序员,通常会搞搞SpringBoot 、Herbinate、Mybatiys、Android、iOS、Flutter、Vue、小程序等.
©️2020 CSDN 皮肤主题: 代码科技 设计师:Amelia_0503 返回首页