Flutter 极光推送android实现

 

Flutter集成极光推送

目前众多推送厂家只有极光支持了flutter,支持一下!!!
废话不多说,开始撸代码

第一步

因为设备的原因目前只在安卓上测试成功,就先分享安卓的配置过程,首先在极光官网创建应用,完成之后在 android/app/build.gradle文件下添加配置:

<permission
android:name="您的应用包名.permission.JPUSH_MESSAGE"
android:protectionLevel="signature" />

<!-- Required -->
<uses-permission android:name="您的应用包名.permission.JPUSH_MESSAGE" />
<uses-permission android:name="android.permission.RECEIVE_USER_PRESENT" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.WRITE_SETTINGS" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />

<!-- Optional. Required for location feature -->
<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" /> <!-- 用于开启 debug 版本的应用在 6.0 系统上的层叠窗口权限 -->
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS" />
<uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" />
<uses-permission android:name="android.permission.GET_TASKS" />
<uses-permission android:name="android.permission.VIBRATE" />
manifestPlaceholders = [
        JPUSH_PKGNAME : "您的应用包名",
        JPUSH_APPKEY : "38a101c09adf57ef70eda9be", // NOTE: JPush 上注册的包名对应的 Appkey.
        JPUSH_CHANNEL : "developer-default", //暂时填写默认值即可.
]
  • 第二步

老规矩,添加依赖

dependencies:
  flutter:
    sdk: flutter
    flutter_jpush: ^0.0.4
  • 第三步
  • import 'package:flutter/material.dart';
    import 'package:flutter_jpush/flutter_jpush.dart';
    import 'jpushpage.dart';
    
    void main() => runApp(MyApp());
    
    class MyApp extends StatelessWidget {
      @override
      Widget build(BuildContext context) {
        return MaterialApp(
          title: 'Flutter Demo',
          theme: ThemeData(
            primarySwatch: Colors.blue,
          ),
          home: MyHomePage(title: 'Flutter Demo Home Page'),
        );
      }
    }
    
    class MyHomePage extends StatefulWidget {
      MyHomePage({Key key, this.title}) : super(key: key);
    
    
      final String title;
    
      @override
      _MyHomePageState createState() => _MyHomePageState();
    }
    
    class _MyHomePageState extends State<MyHomePage> {
      int _counter = 0;
    
      void _incrementCounter() {
        setState(() {
          _counter++;
        });
      }
    
    
      @override
      void initState() {
        // TODO: implement initState
        super.initState();
    
        _startupJpush();
        _ReceiveNotification();
        _OpenNotification();
        _ReceiveCustomMsg();
      }
    
      void _startupJpush() async {
        print("初始化jpush");
        await FlutterJPush.startup();
        print("初始化jpush成功");
      }
    
      /*
    * 收到推送提醒
    * */
      void _ReceiveNotification() async {
        FlutterJPush.addReceiveNotificationListener(
                (JPushNotification notification) {
              setState(() {
                /// 收到推送
                print("收到推送提醒: $notification");
              });
            });
      }
    
      /*
      * 监听接收自定义消息
      * */
    
      void _ReceiveCustomMsg() async {
        FlutterJPush.addReceiveCustomMsgListener((JPushMessage msg) {
          setState(() {
            print("收到推送消息提醒: $msg");
          });
        });
      }
    
      /*
      * 打开推送提醒
      * */
    
      void _OpenNotification() async {
        FlutterJPush.addReceiveOpenNotificationListener(
                (JPushNotification notification) {
              setState(() {
                print("打开了推送提醒: $notification");
                Navigator.push<String>(context,MaterialPageRoute(builder: (context){
                  return jpushPage();
                })).then((String value){
    
                });
              });
            });
      }
    
    
      @override
      Widget build(BuildContext context) {
        return Scaffold(
          appBar: AppBar(
            title: Text(widget.title),
          ),
          body: Center(
            child: Column(
    
              mainAxisAlignment: MainAxisAlignment.center,
              children: <Widget>[
                Text(
                  'You have pushed the button this many times:',
                ),
                Text(
                  '$_counter',
                  style: Theme.of(context).textTheme.display1,
                ),
              ],
            ),
          ),
          floatingActionButton: FloatingActionButton(
            onPressed: _incrementCounter,
            tooltip: 'Increment',
            child: Icon(Icons.add),
          ),
        );
      }
    }
    

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值