第三方SDK:JPush:Android Studio

2024-01-28 21:38

本文主要是介绍第三方SDK:JPush:Android Studio,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Jpush手动集成

JPushSDK下载地址:http://docs.jiguang.cn/resources/

解压下载文件,解压后是:
这里写图片描述

步骤:
这里写图片描述

步骤就是上图,所有的操作就是对上图的详解。

Key值获取地址:https://www.jiguang.cn/app/list

.so文件的2种导入方法:http://blog.csdn.net/ss1168805219/article/details/52443124

源码下载:https://github.com/s1168805219/JPushDemo

Jpush jcenter自动集成

官网jcenter自动集成地址:https://docs.jiguang.cn/jpush/client/Android/android_guide/#jcenter

上面的是手动集成,手动集成需要我们导入jar和so文件,配置AndroidManifest.xml文件。jcenter自定集成就不需要这些步骤了,即:不需要导入导入jar和so文件,不需要配置AndroidManifest.xml文件。

官网说明
这里写图片描述

以下是官网jcenter自动集成的步骤截图:

这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述

以下是官网jcenter 自动集成步骤

说明 使用jcenter自动集成的开发者,不需要在项目中添加jar和so,jcenter会自动完成依赖;在AndroidManifest.xml中不需要添加任何JPush SDK 相关的配置,jcenter会自动导入, 如果手动添加则是以开发者添加的为准覆盖掉默认配置。

  • 确认android studio的 Project 根目录的主 gradle 中配置了jcenter支持。(新建project默认配置就支持)
buildscript {repositories {jcenter()}......
}allprojets {repositories {jcenter()}
}
  • 在 module 的 gradle 中添加依赖和AndroidManifest的替换变量。
android {......defaultConfig {applicationId "com.xxx.xxx" //JPush上注册的包名.......ndk {//选择要添加的对应cpu类型的.so库。 abiFilters 'armeabi', 'armeabi-v7a', 'armeabi-v8a' // 还可以添加 'x86', 'x86_64', 'mips', 'mips64'}manifestPlaceholders = [JPUSH_PKGNAME : applicationId,JPUSH_APPKEY : "你的appkey", //JPush上注册的包名对应的appkey.JPUSH_CHANNEL : "developer-default", //暂时填写默认值即可.]......}......
}dependencies {......compile 'cn.jiguang:jpush:2.1.8'  // 此处以SDK 2.1.8版本为例......
}

注 : 如果在添加以上 abiFilter 配置之后android Studio出现以下提示:

NDK integration is deprecated in the current plugin. Consider trying the new experimental plugin.

则在 Project 根目录的gradle.properties文件中添加:

android.useDeprecatedNdk=true

实际操作

我用了jcenter自动集成,步骤和官网一致,只不过,“如果在添加以上 abiFilter 配置之后android Studio出现以下提示。。。”,我的没提示,我就没加android.useDeprecatedNdk=true。,发现集成失败,发送不了通知,于是我就添加了这行代码没加句号( 。),这样发送通知就可以接收到了。见下图:

这里写图片描述

混淆代码

官网:
这里写图片描述
我:
这里写图片描述

-dontoptimize
-dontpreverify

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

以上的是通知,没有消息,因为我们也没配置BroadcasetReceiver,不配置的话,可以成功发送通知和自定义消息,app可以接受到通知并显示出来,但是自定义消息不会显示。

官网的说明:
这里写图片描述

集成Jpush需要添加

JPushInterface.setDebugMode(true);
JPushInterface.init(this);

一般在Applicatio中的onCreate()方法中添加

注意:

自定义消息不会展示在通知栏,完全要开发者写代码去处理。

为什么jcenter自动集成发送通知或自定义消息失败?

采用jcenter的方式集成Jpush,需要我们在设置接线停止该app,然后开开启,此时发送通知,发现是成功的。

采用jcenter自动集成发送自定义消息还需在配置receiver吗?

需要,需要我们自己创建类继承BroadcastReceiver,并且在AndroidManifest.xml中配置。

推送合集
第三方开源库:个推
第三方SDK:JPush:Android Studio
第三方SDK:JPush SDK Eclipse

JAnalyticsInterface jcenter自动集成

在 module 的 gradle 中添加依赖和AndroidManifest的替换变量。

android {......defaultConfig {applicationId "com.xxx.xxx" // 你应用的包名.......manifestPlaceholders = [JPUSH_APPKEY : "你的appkey", //JPush上注册的包名对应的appkey.JPUSH_CHANNEL : "developer-default", //暂时填写默认值即可.]......}......
}dependencies {......compile 'cn.jiguang.sdk:janalytics:1.0.0' // 此处以JAnalytics 1.0.0 版本为例。compile 'cn.jiguang.sdk:jcore:1.0.0' // 此处以JCore 1.0.0 版本为例。......
}

添加代码

初始化 sdk : 传入 application 的 context 来初始化 sdk 。

JAnalyticsInterface.init(Context context);

设置调试模式:参数为 true 表示打开调试模式,可看到 sdk 的日志

JAnalyticsInterface.setDebugMode(boolean isDebugMode);

自定义消息

先自定义类继承BroadcastReceiver

public class JpushReceiver extends BroadcastReceiver {private static final String TAG = "MyReceiver";private NotificationManager nm;@Overridepublic void onReceive(Context context, Intent intent) {if (null == nm) {nm = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);}Bundle bundle = intent.getExtras();Log.d(TAG, "onReceive - " + intent.getAction());if (JPushInterface.ACTION_REGISTRATION_ID.equals(intent.getAction())) {Log.d(TAG, "JPush用户注册成功");} else if (JPushInterface.ACTION_MESSAGE_RECEIVED.equals(intent.getAction())) {Log.d(TAG, "接受到推送下来的自定义消息");Log.d(TAG,"自定义消息,EXTRA_TITLE="+bundle.getString(JPushInterface.EXTRA_TITLE));Log.d(TAG,"自定义消息,EXTRA_MESSAGE="+bundle.getString(JPushInterface.EXTRA_MESSAGE));Log.d(TAG,"自定义消息,EXTRA_EXTRA="+bundle.getString(JPushInterface.EXTRA_EXTRA));} else if (JPushInterface.ACTION_NOTIFICATION_RECEIVED.equals(intent.getAction())) {Log.d(TAG, "接受到推送下来的通知");Log.d(TAG,"通知,EXTRA_NOTIFICATION_TITLE="+bundle.getString(JPushInterface.EXTRA_NOTIFICATION_TITLE));Log.d(TAG,"通知,EXTRA_MESSAGE="+bundle.getString(JPushInterface.EXTRA_MESSAGE));Log.d(TAG,"通知,EXTRA_ALERT="+bundle.getString(JPushInterface.EXTRA_ALERT));Log.d(TAG,"通知,EXTRA_EXTRA="+bundle.getString(JPushInterface.EXTRA_EXTRA));} else if (JPushInterface.ACTION_NOTIFICATION_OPENED.equals(intent.getAction())) {Log.d(TAG, "用户点击打开了通知");} else {Log.d(TAG, "Unhandled intent - " + intent.getAction());}}
}

再配置如下

<receiver
    android:name=".JpushReceiver"android:enabled="true"><intent-filter><action android:name="cn.jpush.android.intent.REGISTRATION"/><action android:name="cn.jpush.android.intent.MESSAGE_RECEIVED"/><action android:name="cn.jpush.android.intent.NOTIFICATION_RECEIVED"/><action android:name="cn.jpush.android.intent.NOTIFICATION_OPENED"/><action android:name="cn.jpush.android.intent.NOTIFICATION_CLICK_ACTION"/><action android:name="cn.jpush.android.intent.CONNECTION"/><category android:name="com.cqc.jpush01"/></intent-filter>
</receiver>

自定义JpushReceiver后,通知不收影响,顶部通知栏仍然会显示通知文字和声音,但是自定义消息需要自己处理

获取通知和自定义消息中的数据

通知

JPushInterface.EXTRA_NOTIFICATION_TITLE 默认是appName
JPushInterface.EXTRA_MESSAGE null
PushInterface.EXTRA_ALERT  在Jpush开发者服务页面中发的的通知
JPushInterface.EXTRA_EXTRA  额外数据

自定义消息

JPushInterface.EXTRA_TITLE 不写就没有值
JPushInterface.EXTRA_MESSAGE 在Jpush开发者服务页面中发送的自定义消息
JPushInterface.EXTRA_EXTRA  额外的数据

这篇关于第三方SDK:JPush:Android Studio的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/654844

相关文章

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class

Visual Studio 2022 编译C++20代码的图文步骤

《VisualStudio2022编译C++20代码的图文步骤》在VisualStudio中启用C++20import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标... 默认创建Visual Studio桌面控制台项目代码包含C++20的import方法。右键项目的属性:

Android DataBinding 与 MVVM使用详解

《AndroidDataBinding与MVVM使用详解》本文介绍AndroidDataBinding库,其通过绑定UI组件与数据源实现自动更新,支持双向绑定和逻辑运算,减少模板代码,结合MV... 目录一、DataBinding 核心概念二、配置与基础使用1. 启用 DataBinding 2. 基础布局

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级

VSCode设置python SDK路径的实现步骤

《VSCode设置pythonSDK路径的实现步骤》本文主要介绍了VSCode设置pythonSDK路径的实现步骤,包括命令面板切换、settings.json配置、环境变量及虚拟环境处理,具有一定... 目录一、通过命令面板快速切换(推荐方法)二、通过 settings.json 配置(项目级/全局)三、

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

java对接第三方接口的三种实现方式

《java对接第三方接口的三种实现方式》:本文主要介绍java对接第三方接口的三种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录HttpURLConnection调用方法CloseableHttpClient调用RestTemplate调用总结在日常工作

Android NDK版本迭代与FFmpeg交叉编译完全指南

《AndroidNDK版本迭代与FFmpeg交叉编译完全指南》在Android开发中,使用NDK进行原生代码开发是一项常见需求,特别是当我们需要集成FFmpeg这样的多媒体处理库时,本文将深入分析A... 目录一、android NDK版本迭代分界线二、FFmpeg交叉编译关键注意事项三、完整编译脚本示例四

Android与iOS设备MAC地址生成原理及Java实现详解

《Android与iOS设备MAC地址生成原理及Java实现详解》在无线网络通信中,MAC(MediaAccessControl)地址是设备的唯一网络标识符,本文主要介绍了Android与iOS设备M... 目录引言1. MAC地址基础1.1 MAC地址的组成1.2 MAC地址的分类2. android与I