JPush 极光推送 实战

极光推送的"自定义消息"很给力啊,他不是发送一条消息到状态栏,而是直接把消息内容传到APP中需要的地方,估计很多APP的验证码就是通过这种形式搞出来的。

简介

官网:https://www.jpush.cn/

极光推送(JPush)是一个端到端的推送服务,使得服务器端消息能够及时地推送到终端用户手机上,让开发者积极地保持与用户的连接,从而提高用户活跃度、提高应用的留存率。

主要功能

  • 保持与服务器的长连接,以便消息能够即时推送到达客户端
  • 接收通知与自定义消息,并向开发者App传递相关信息

主要特点

  • 客户端维持连接占用资源少、耗电低
  • SDK丰富的接口,可定制通知栏提示样式
  • 服务器大容量、稳定

原理

  • JPush Android SDK 是作为 Android Service 长期运行在后台的,从而创建并保持长连接,保持永远在线的能力。

包青天备注

  • 客户端推送服务进程必须开启才能接收到推送消息,如果使用助手类的工具把进程杀死了,那就收不到了
  • 客户如果设置不显示通知或消息,也是收不到的

压缩包中的内容

  • AndroidManifest.xml

    • 客户端嵌入SDK参考的配置文件
  • libs/jpush-sdk-release1.x.y.jar
    • SDK Java 开发包
  • libs/armeabi/libjpush.so
    • SDK native 开发包
  • res
    • 集成SDK必须添加的资源文件
  • example
    • 是一个完整的 Android 项目,通过这个演示了 JPush SDK 的基本用法,可以用来做参考。

客户端启动步骤:

  • 检查 metadata 的 appKey 和 channel ,如果不存在,则启动失败
  • 初始化 JPush SDK,检查 JNI 等库文件的有效性,如果库文件无效,则启动失败
  • 检查 Androidmanifest.xml,如果有 Required 的权限不存在,则启动失败
  • 连接服务器登录,如果存在网络问题,则登陆失败

集成步骤

官方文档:http://docs.jpush.io/guideline/android_guide/

详细教程:http://docs.jpush.io/client/android_tutorials/

1、导入SDK

  • 解压缩后,复制 libs、res 中的文件到工程的相应目录下

2、集成 SDK 的混淆

  • 在proguard-android.txt中配置:
-dontoptimize

-dontpreverify

-dontwarn cn.jpush.**

-keep class cn.jpush.** { *; }

#v2.0.5 及以上的版本由于引入了protobuf ,在上面基础之上增加排出混淆的配置。

#==================gson==========================

-dontwarn com.google.**

-keep class com.google.gson.** {*;}

#==================protobuf======================

-dontwarn com.google.**

-keep class com.google.protobuf.** {*;}

3、配置清单文件

  • 详见官方文档

4、添加代码

  • 在应用启动时初始化 JPush。

JPushInterface.init(getApplicationContext());//只需要在应用程序启动时调用一次该 API 即可

  • 定制一个本应用程序 Application 类

public class ExampleApplication extends Application {

private static final String TAG = "JPush";

@Override

public void onCreate() {

Log.d(TAG, "[ExampleApplication] onCreate");

super.onCreate();

JPushInterface.setDebugMode(true);     // 设置开启日志,发布时请关闭日志

JPushInterface.init(this);     //一般建议在自定义 Application 类里初始化。也可以在主 Activity 里。

}

}

清单文件配置实例

步骤

  • 复制备注为 "Required" 的部分
  • 将备注为替换包名的部分,替换为当前应用程序的包名
  • 将AppKey替换为在Portal上注册该应用的的Key 

<?xml version="1.0" encoding="utf-8"?>

<manifest xmlns:android="http://schemas.android.com/apk/res/android"

package="com.example.test"

android:versionCode="1"

android:versionName="1.0.0" >

<uses-sdk

android:minSdkVersion="11"

android:targetSdkVersion="17" />

<!-- Required -->

<permission

android:name="com.example.test.permission.JPUSH_MESSAGE"

android:protectionLevel="signature" />

<!-- Required -->

<!-- 官方定义的权限,允许应用接收JPUSH内部代码发送的广播消息。 -->

<uses-permission android:name="com.example.test.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.SYSTEM_ALERT_WINDOW" />

<!-- Optional. Required for location feature -->

<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />

<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />

<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="com.example.test.ExampleApplication"

android:allowBackup="true"

android:icon="@drawable/ic_launcher"

android:label="@string/app_name" >

<!-- For test only 测试的主程序 -->

<activity

android:name="com.example.test.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>

<!-- For test only 测试高级功能 -->

<activity

android:name="com.example.test.PushSetActivity"

android:label="@string/app_name" >

</activity>

<!-- For test only 测试设置 -->

<activity

android:name="com.example.test.SettingActivity"

android:label="@string/app_name" >

</activity>

<!-- For test only 测试状态通知栏,需要打开的Activity -->

<activity

android:name="com.example.test.TestActivity"

android:exported="false" >

<intent-filter>

<action android:name="jpush.testAction" />

<category android:name="jpush.testCategory" />

</intent-filter>

</activity>

<!-- Rich push 核心功能 since 2.0.6 -->

<activity

android:name="cn.jpush.android.ui.PopWinActivity"

android:exported="false"

android:theme="@style/MyDialogStyle" >

</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.example.test" />

</intent-filter>

</activity>

<!-- Required SDK核心功能 -->

<service

android:name="cn.jpush.android.service.DownloadService"

android:enabled="true"

android:exported="false" />

<!-- option since 2.0.5 可配置PushService,DaemonService,PushReceiver,AlarmReceiver的android:process参数 -->

<!-- 将JPush相关组件设置为一个独立进程。如:android:process=":remote" -->

<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>

<!-- since 1.8.0 option 可选项。用于同一设备中不同应用的JPush服务相互拉起的功能。 -->

<!-- 若不启用该功能可删除该组件,将不拉起其他应用也不能被其他应用拉起 -->

<service

android:name="cn.jpush.android.service.DaemonService"

android:enabled="true"

android:exported="true" >

<intent-filter>

<action android:name="cn.jpush.android.intent.DaemonService" />

<category android:name="com.example.test" />

</intent-filter>

</service>

<!-- Required -->

<receiver

android:name="cn.jpush.android.service.PushReceiver"

android:enabled="true" >

<intent-filter android:priority="1000" >

<action android:name="cn.jpush.android.intent.NOTIFICATION_RECEIVED_PROXY" />

<!-- Required  显示通知栏 -->

<category android:name="com.example.test" />

</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" />

<!-- User defined. 用户自定义的广播接收器 -->

<receiver

android:name="com.example.test.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.example.test" />

</intent-filter>

</receiver>

<!-- Required. For publish channel feature -->

<!-- JPUSH_CHANNEL 是为了方便开发者统计APK分发渠道。 -->

<!-- 例如:发到 Google Play 的APK可以设置为 google-play; 发到其他市场的 APK 可以设置为 xxx-market。 -->

<!-- 目前这个渠道统计功能的报表还未开放。 -->

<meta-data

android:name="JPUSH_CHANNEL"

android:value="developer-default" />

<!-- 值来自开发者平台取得的AppKey -->

<meta-data

android:name="JPUSH_APPKEY"

android:value="2310ef7d8dac10ff69973eb2" />

</application>

</manifest>

来自为知笔记(Wiz)

附件列表

时间: 2024-08-07 08:38:03

JPush 极光推送 实战的相关文章

atitit.web 推送实现方案集合(2)---百度云,jpush 极光推送 ,个推的选型比较.o99

atitit.web 推送实现方案集合(2)---百度云,jpush 极光推送 ,个推的选型比较.o99 1.1. 云推送有推送次数或频率的限制吗? 1 1.2. 推送的消息长度 1 1.3. 离线消息的支持 2 1.4. 是否支持转义字符 2 2. 客户端身份识别机制 2 3. 绑定客户端的区别流程::jpush胜出 2 4. 文档风格比较::百度,jpush胜出 3 5. 编程sdk框架比较..个推,百度胜出 3 6. 编程风格的比较 3 6.1. 个推 3 6.2. 百度 4 6.3. J

Android JPush极光推送应用

JPush纠结了5-6个小时,一直报下面的错误,纠结! [AndroidUtil] AndroidManifest.xml missing required intent filter for PushReceiver: cn.jpush.android.intent.NOTIFICATION_RECEIVED_PROXY 觉得明明是已经添加了cn.jpush.android.intent.NOTIFICATION_RECEIVED_PROXY 主要问题是主包名没有弄好,才导致的错误!接下来感谢

Java.lang.UnsatisfiedLinkError android studio集成Jpush极光推送

今天学习了极光推送,想把它集成到自己的应用里面,我的开发环境是android studio 1.2,期间遇到了错误: Couldn't load jpush174 from loader dalvik.system.PathClassLoader findLibrary returned null,原因是由于android studio不能正确的解决libjpush174.so文件造成的,解决步骤如下: 1.首先按照官网教程配置环境,链接如下:http://docs.jpush.io/guide

JPush (极光推送) For Xamarin.Android

官方教程上讲的是 GCM (Google Cloud Messaging) , 不过 GFW 是 GCM 过不去的坎. 极光推送 JPush 是国内的一个不错的替代方案. JPush 提供的 API 易于理解, 使用也很简单, 但是要使用于 Xamarin 还是要费些周章: 要转制成 Binding Library. JPush 提供了一篇转制的示例: http://smilehyh.blog.163.com/blog/static/123343886201362110857402/ 按照过程走

IONIC集成jPush极光推送

一.简介: 极光推送(JPush)是独立的第三方云推送平台,致力于为全球移动应用开发者提供专业.高效的移动消息推送服务. 极光推送,英文简称 JPush,是一个面向普通开发者开放的,免费的第三方消息推送服务. 二.官网:https://www.jiguang.cn/ 首先注册一个账号,登陆平台,在控制台添加我们的应用信息 点击提交 会成一个AppKey和Master Secret这两个密钥主要用来配置服务端发送通知使用. 三.开整 官方的栗子:https://github.com/jpush/j

Ionic JPush极光推送 插件实例

1.需要去这里注册https://www.jiguang.cn 注册成功获取AppKey 备注填写应用包名规范点,在项目还要用那 2.创建ionic 项目 指定你注册时候的包名(假如:com.ionicframework.ltapp) ionic start  -i com.ionicframework.ltapp ltapp blank 3.添加JPush 插件 进入 项目目录下 cd  ltapp git clone https://github.com/jpush/jpush-phoneg

JPush极光推送快速创建Android Demo

第一步:创建极光推送开发者帐号 第二步:Portal上创建应用 第三步:下载应用Example 第四步:把Example(Android项目)导入 Eclipse 里 第五步:运行 Example 这个应用 第六步:Portal上推送消息 第七步:手机上收到消息 第八步:在LogCat中查看收到的消息 本文目的在于,指导新接触极光推送的开发者,在短短几分钟时间内把极光推送跑起来: 安装Demo客户端到手机 在Portal上推送通知 客户端收到推送并显示在状态栏p 第一步:创建极光推送开发者帐号

用JPUSH极光推送实现服务端向安装了APP应用的手机推送消息(C#服务端接口)

这次公司要我们做一个功能,就是当用户成功注册以后,他登录以后要收到消息,当然这个消息是安装了我们的手机APP应用的手机咯. 极光推送的网站的网址是:https://www.jpush.cn/ 极光推送的官方API以及帮助文档都在这里:http://docs.jpush.cn/display/dev/Index 其中服务端的接口以及示例代码都在这里:http://docs.jpush.cn/display/dev/Server-SDKs 大家有兴趣的可以看看,因为这次我做的不是客户端APP,所以一

用Jpush极光推送实现实时抓取用户Log到七牛云服务器.md

##场景## 我们的app常常会出现某个特定用户的手机出现异常情况,(注意不是所有用户,特定机型特定用户)如果用友盟,那么多log你也抓不完 ,看不到log就无法解决问题. 那么问题来了,如何实现对特定某个用户实时抓取log呢,比如我就想要用户id为 **lixiaodaoaaa**这个用户的日志信息呢?(用户自己不知道我们要抓她的log,对了你可以干点邪恶的事) 发送通知给他,而接收到通知,设备可以啥都不提示,可以干点邪恶的事,不过我想想还是算了.(他的log.我们默认log都会用LogUti