Android第三方推送(基于JPush极光)

弄了一段时间,算是把Android推送部分弄好了,对以后的开发肯定也是有帮助的。然后想总结一下,第三方的东西比如:地图,IM(即时通讯),推送等,其实使用方法基本都是类似的:
1:官网注册ID,创建应用获取key
2:导入第三方sdk,配置sdk要求的各种jar以及权限
3:使用第三方封装好的各种工具类对自己应用进行功能添加和扩展
接下来,我将介绍下推送部分的实现:

1:官网注册:
1:注册地址:极光官方网址:https://www.jpush.cn/
2:创建应用,申请key:这里可以直接按照官方文档来:http://docs.jpush.io/guideline/android_3m/ 创建完成之后,页面会有”下载应用Example “ 可以直接下载,里面是个完整的demo,不管会不会配置,里面的目录结构,清单文件什么的对我们还是有帮助的。【不过在这里简单说下】该demo的教程,个人认为不好用,一是整合了太多的功能,导入项目时容易让自己混乱摸不着头脑,二是该项目不好配置。所以建议直接从0开始。

2:导入第三方:

1:下载资源:官方地址:http://docs.jpush.io/resources/ 下载Android版本就可以了,里面有demo,有文档,有清单文件例子

2:导入,解压下载的资源后:
a : 将jar包,例如:jpush-android-2.1.5.jar添加至libs,并添加依赖。
b :在Androidstudio项目的src–>main下新建文件夹jniLibs,并将上面提到的jar包例如:jpush-android-2.1.5.jar所在的同级的所有文件夹(其中包含.so文件)拷至该文件夹。
至此资源导入就完成了,很简单。

3:配置,使用
1:首先配置清单文件吧,可参照官方demo里的清单文件,复制需要的东西就行。
这里拿出我的清单文件,其中会有解释,

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.inext.test.thridlogin" >

    <permission
        android:name="com.inext.test.thridlogin.permission.JPUSH_MESSAGE"
        android:protectionLevel="signature" />
    <!-- Required  一些系统要求的权限,如访问网络等 -->
    <uses-permission android:name="com.inext.test.thridlogin.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.WAKE_LOCK" />
    <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.WRITE_SETTINGS" />
    <uses-permission android:name="android.permission.VIBRATE" />
    <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
    <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" />

    <!-- Optional for location -->
    <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" />

    <application
        android:name=".myapp.MyApp" //这里是自己建立的MyApp继承自application,目的是初始化第三方组件,官方解释是初始化时调用init(),并且只调用一次,所以在MyApp中首先调用该方法初始化,读者也可以在activity中调用,这样的话,这里就不用配置android:name。后面会有完整的MyApp代码。
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name=".MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>

//所有配置前带有“Rich push 核心功能”或“Required  ”这句话的都是必须要的,可直接复制

        <!-- Rich push 核心功能 since 2.0.6 -->
        <activity
            android:name="cn.jpush.android.ui.PopWinActivity"
            android:exported="false" >
        </activity>

        <!-- Required SDK核心功能 -->
        <activity
            android:name="cn.jpush.android.ui.PushActivity"
            android:configChanges="orientation|keyboardHidden"
            android:exported="false"
            android:theme="@android:style/Theme.NoTitleBar" >
            <intent-filter>
                <action android:name="cn.jpush.android.ui.PushActivity" />

                <category android:name="android.intent.category.DEFAULT" />
                <category android:name="com.inext.test.thridlogin" />
            </intent-filter>
        </activity>
        <!-- Required  SDK核心功能 -->
        <service
            android:name="cn.jpush.android.service.DownloadService"
            android:enabled="true"
            android:exported="false" >
        </service>

        <!-- Required SDK 核心功能 -->
        <!-- 可配置android:process参数将PushService放在其他进程中 -->
        <service
            android:name="cn.jpush.android.service.PushService"
            android:enabled="true"
            android:exported="false" >
            <intent-filter>
                <action android:name="cn.jpush.android.intent.REGISTER" />
                <action android:name="cn.jpush.android.intent.REPORT" />
                <action android:name="cn.jpush.android.intent.PushService" />
                <action android:name="cn.jpush.android.intent.PUSH_TIME" />
            </intent-filter>
        </service>
        <!-- Required SDK核心功能 -->
        <receiver
            android:name="cn.jpush.android.service.PushReceiver"
            android:enabled="true"
            android:exported="false" >
            <intent-filter android:priority="1000" >
                <action android:name="cn.jpush.android.intent.NOTIFICATION_RECEIVED_PROXY" /> <!-- Required  显示通知栏 -->
                <category android:name="com.inext.test.thridlogin" />
            </intent-filter>
            <intent-filter>
                <action android:name="android.intent.action.USER_PRESENT" />
                <action android:name="android.net.conn.CONNECTIVITY_CHANGE" />
            </intent-filter>
            <!-- Optional -->
            <intent-filter>
                <action android:name="android.intent.action.PACKAGE_ADDED" />
                <action android:name="android.intent.action.PACKAGE_REMOVED" />

                <data android:scheme="package" />
            </intent-filter>
        </receiver>

        <!-- Required SDK核心功能 -->
        <receiver
            android:name="cn.jpush.android.service.AlarmReceiver"
            android:exported="false" />

//下面的receiver的配置,是针对用户自定义接收推送的,即开发者可以自定义用户点击后要做的事,比如打开另一个activity。类似:点击今日头条的推送就能打开画面并展示新闻。这里强烈建议参考官方文档:[http://docs.jpush.io/client/android_api/#receiver]

        <receiver
            android:name=".myreceiver.MyReceiver"
            android:enabled="true"
            android:exported="false" >
            <intent-filter>
                <action android:name="cn.jpush.android.intent.REGISTRATION" /> <!-- Required  用户注册SDK的intent -->
                <action android:name="cn.jpush.android.intent.UNREGISTRATION" />
                <action android:name="cn.jpush.android.intent.MESSAGE_RECEIVED" /> <!-- Required  用户接收SDK消息的intent -->
                <action android:name="cn.jpush.android.intent.NOTIFICATION_RECEIVED" /> <!-- Required  用户接收SDK通知栏信息的intent -->
                <action android:name="cn.jpush.android.intent.NOTIFICATION_OPENED" /> <!-- Required  用户打开自定义通知栏的intent -->
                <action android:name="cn.jpush.android.intent.ACTION_RICHPUSH_CALLBACK" /> <!-- Optional 用户接受Rich Push Javascript 回调函数的intent -->
                <action android:name="cn.jpush.android.intent.CONNECTION" /> <!-- 接收网络变化 连接/断开 since 1.6.3 -->
                <category android:name="com.inext.test.thridlogin" />
            </intent-filter>
        </receiver>
        <!-- Required  . Enable it you can get statistics data with channel -->
        <meta-data
            android:name="JPUSH_CHANNEL"
            android:value="developer-default" />
        <meta-data
            android:name="JPUSH_APPKEY"
            android:value="你的key" /> <!-- </>值来自开发者平台取得的AppKey -->
    </application>
</manifest>

至此配置清单文件就ok了,同时读者可以多参考文档,以便了解更多。

2:使用

首先给大家我的MyApp,如果不想在Application 里初始化那就在activity中初始化,不过建议在Application 中:

/**
 * Created by Administrator on 2016/5/31.
 */
public class MyApp extends Application {
    @Override
    public void onCreate() {
        super.onCreate();
        JPushInterface.setDebugMode(true);  // 设置开启日志,发布时请关闭日志
        JPushInterface.init(this);          // 初始化 JPush
    }
}

运行,然后在后台管理推送一条消息应该就能收到通知了

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值