phonegap添加消息推送插件教程
来源:互联网 发布:网络贷款app 编辑:程序博客网 时间:2024/05/16 15:41
1.注册极光的开发者账户,并注册应用信息。
(a)创建帐号进入极光推送平台后,首先显示的是创建应用的界面。填上你的应用程序的名称,以及 Android包名这二顶就可以了。
(b)用创建成功,即进入“应用详情”显示界面。这个界面右下角,你可以看到 “appkey" 后面会用到。
2.下载 sdk包。
3.SDK集成步骤
1、导入 SDK 开发包到你自己的应用程序项目
A)解压缩 jpush-SDK_v1.x.y.zip 集成压缩包
B)复制 libs/jpush-SDK-release1.x.y.jar 到工程 libs/ 目录下
C)复制libs/armeabi/libsys1.x.y.so 到工程 libs/armeabi 目录下(如果你的项目有libs/armeabi-v7a这个目录,请把libsys1.x.y.so也复制一份到这个目录)
这里需求注意的是:包导入进去之后一定要把包configuer building path。
2、配置 AndroidManifest.xml
根据 SDK 压缩包里的 AndroidManifest.xml 样例文件,来配置应用程序项目的 AndroidManifest.xml 。
注意:
将备注为替换包名的部分,替换为当前应用程序的包名
将AppKey替换为在Portal上注册该应用的的Key,例如(9fed5bcb7b9b87413678c407)。
<!-- Required -->
<permission android:name="You Package.permission.JPUSH_MESSAGE" android:protectionLevel="signature" />
<!-- Required -->
<uses-permission android:name="You Package.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.VIBRATE" />
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<!-- Optional. Required for location feature -->
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_COARSE_UPDATES" />
<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:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:name="Your Application">
<!-- Required -->
<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 -->
<receiver
android:name="cn.jpush.android.service.PushReceiver"
android:enabled="true" >
<intent-filter>
<action android:name="android.intent.action.USER_PRESENT" />
<action android:name="android.net.conn.CONNECTIVITY_CHANGE" />
</intent-filter>
<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核心功能-->
<activity
android:name="cn.jpush.android.ui.PushActivity"
android:theme="@android:style/Theme.Translucent.NoTitleBar"
android:configChanges="orientation|keyboardHidden" >
<intent-filter>
<action android:name="cn.jpush.android.ui.PushActivity" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="Your Package" />
</intent-filter>
</activity>
<!-- Required SDK核心功能-->
<service
android:name="cn.jpush.android.service.DownloadService"
android:enabled="true"
android:exported="false" >
</service>
<!-- Required SDK核心功能-->
<receiver android:name="cn.jpush.android.service.AlarmReceiver" />
<meta-data android:name="JPUSH_CHANNEL" android:value="developer-default"/>
<!-- Required. AppKey copied from Portal -->
<meta-data android:name="JPUSH_APPKEY" android:value="Your AppKey"/>
</application>
</manifest>
这里需要注意的是:之前已经加过的一些xml信息,这时候要一一对照把这里面的信息 一条一条添加进去。一定要注意顺序。
3、添加代码
JPush SDK 提供的 API 接口,都主要集中在 cn.jpush.android.api.JPushInterface 类里。
按照下面的方法来修改:
Package cn.包名
Import org.apache.cordova.*;
Import android.content.Intent;
Import android.OS.Bundle;
Import android.view.View
Import android.view.View.OnClickListener;
Import android.widget.TextView;
Import android.widget.Button
Import.on.jpush.android.api.InstrumentedActiviity;
import.on.jpush.android.api.JPushInterface;
Public class Test extends DroidGap{
@Override
Public void onCreate(Bundle savedInstanceState){
super.OnCreate(savedInstanceState);
JPushInterface.setDebugNode(true);
JPushInterface.inite(this);
Super.setIntegerProperty(“splashscreen”,R.drawable.splashshscreen);
super.loadUrl(“file:///android_asset/www/boot.html”,3000);
}
}
4、测试确认
1.确认所需的权限都已经添加。如果必须的权限未添加,日志会提示错误。
2.确认AppKey(在Portal上生成的)已经正确的写入 Androidmanifest.xml 。
3.确认在程序启动时候调用了init(context) 接口
4.确认测试手机(或者模拟器)已成功连入网络
5.客户端调用init后不久,如果一切正常,应有登录成功的日志信息
6.启动应用程序,在 Portal 上向应用程序发送自定义消息或者通知栏提示。详情参考管理Portal。
7.在几秒内,客户端应可收到下发的通知或者正定义消息
如果 SDK 工作正常,则日志信息会如下图所示:
如图所示,客户端启动分为 4 步:
Com.quentin JPush [JPushInterface]action:init
Com.quentin JPush [JPush]metadata:appKey-72d7bd7b7
Com.quentin JPush [JPush]metadata:channel-develope
Com.quentin JPush [PushService] action:checkValidManif
Com.quentin JPush [PushService] Login succeed!
检查 metadata 的 appKey 和 channel ,如果不存在,则启动失败
初始化 JPush SDK,检查 JNI 等库文件的有效性,如果库文件无效,则启动失败
检查 Androidmanifest.xml,如果有 Required 的权限不存在,则启动失败
连接服务器登录,如果存在网络问题,则登陆失败,或者前面三步有问题,不会启动JPush SDK
注意:只要测试成功,就可以管理Portal,去发送信息了。没有意外的话,就能收到信息。
KeyMob是最专业的移动广告平台,致力于为广告主提供自由定价、自主销售广告、广告互推、应用内交叉推广推广服务,同时为开发者提供市场审核,使得双方对广告功能进行统一管理、动态配置。
(a)创建帐号进入极光推送平台后,首先显示的是创建应用的界面。填上你的应用程序的名称,以及 Android包名这二顶就可以了。
(b)用创建成功,即进入“应用详情”显示界面。这个界面右下角,你可以看到 “appkey" 后面会用到。
2.下载 sdk包。
3.SDK集成步骤
1、导入 SDK 开发包到你自己的应用程序项目
A)解压缩 jpush-SDK_v1.x.y.zip 集成压缩包
B)复制 libs/jpush-SDK-release1.x.y.jar 到工程 libs/ 目录下
C)复制libs/armeabi/libsys1.x.y.so 到工程 libs/armeabi 目录下(如果你的项目有libs/armeabi-v7a这个目录,请把libsys1.x.y.so也复制一份到这个目录)
这里需求注意的是:包导入进去之后一定要把包configuer building path。
2、配置 AndroidManifest.xml
根据 SDK 压缩包里的 AndroidManifest.xml 样例文件,来配置应用程序项目的 AndroidManifest.xml 。
注意:
将备注为替换包名的部分,替换为当前应用程序的包名
将AppKey替换为在Portal上注册该应用的的Key,例如(9fed5bcb7b9b87413678c407)。
<!-- Required -->
<permission android:name="You Package.permission.JPUSH_MESSAGE" android:protectionLevel="signature" />
<!-- Required -->
<uses-permission android:name="You Package.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.VIBRATE" />
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<!-- Optional. Required for location feature -->
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_COARSE_UPDATES" />
<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:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:name="Your Application">
<!-- Required -->
<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 -->
<receiver
android:name="cn.jpush.android.service.PushReceiver"
android:enabled="true" >
<intent-filter>
<action android:name="android.intent.action.USER_PRESENT" />
<action android:name="android.net.conn.CONNECTIVITY_CHANGE" />
</intent-filter>
<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核心功能-->
<activity
android:name="cn.jpush.android.ui.PushActivity"
android:theme="@android:style/Theme.Translucent.NoTitleBar"
android:configChanges="orientation|keyboardHidden" >
<intent-filter>
<action android:name="cn.jpush.android.ui.PushActivity" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="Your Package" />
</intent-filter>
</activity>
<!-- Required SDK核心功能-->
<service
android:name="cn.jpush.android.service.DownloadService"
android:enabled="true"
android:exported="false" >
</service>
<!-- Required SDK核心功能-->
<receiver android:name="cn.jpush.android.service.AlarmReceiver" />
<meta-data android:name="JPUSH_CHANNEL" android:value="developer-default"/>
<!-- Required. AppKey copied from Portal -->
<meta-data android:name="JPUSH_APPKEY" android:value="Your AppKey"/>
</application>
</manifest>
这里需要注意的是:之前已经加过的一些xml信息,这时候要一一对照把这里面的信息 一条一条添加进去。一定要注意顺序。
3、添加代码
JPush SDK 提供的 API 接口,都主要集中在 cn.jpush.android.api.JPushInterface 类里。
按照下面的方法来修改:
Package cn.包名
Import org.apache.cordova.*;
Import android.content.Intent;
Import android.OS.Bundle;
Import android.view.View
Import android.view.View.OnClickListener;
Import android.widget.TextView;
Import android.widget.Button
Import.on.jpush.android.api.InstrumentedActiviity;
import.on.jpush.android.api.JPushInterface;
Public class Test extends DroidGap{
@Override
Public void onCreate(Bundle savedInstanceState){
super.OnCreate(savedInstanceState);
JPushInterface.setDebugNode(true);
JPushInterface.inite(this);
Super.setIntegerProperty(“splashscreen”,R.drawable.splashshscreen);
super.loadUrl(“file:///android_asset/www/boot.html”,3000);
}
}
4、测试确认
1.确认所需的权限都已经添加。如果必须的权限未添加,日志会提示错误。
2.确认AppKey(在Portal上生成的)已经正确的写入 Androidmanifest.xml 。
3.确认在程序启动时候调用了init(context) 接口
4.确认测试手机(或者模拟器)已成功连入网络
5.客户端调用init后不久,如果一切正常,应有登录成功的日志信息
6.启动应用程序,在 Portal 上向应用程序发送自定义消息或者通知栏提示。详情参考管理Portal。
7.在几秒内,客户端应可收到下发的通知或者正定义消息
如果 SDK 工作正常,则日志信息会如下图所示:
如图所示,客户端启动分为 4 步:
Com.quentin JPush [JPushInterface]action:init
Com.quentin JPush [JPush]metadata:appKey-72d7bd7b7
Com.quentin JPush [JPush]metadata:channel-develope
Com.quentin JPush [PushService] action:checkValidManif
Com.quentin JPush [PushService] Login succeed!
检查 metadata 的 appKey 和 channel ,如果不存在,则启动失败
初始化 JPush SDK,检查 JNI 等库文件的有效性,如果库文件无效,则启动失败
检查 Androidmanifest.xml,如果有 Required 的权限不存在,则启动失败
连接服务器登录,如果存在网络问题,则登陆失败,或者前面三步有问题,不会启动JPush SDK
注意:只要测试成功,就可以管理Portal,去发送信息了。没有意外的话,就能收到信息。
KeyMob是最专业的移动广告平台,致力于为广告主提供自由定价、自主销售广告、广告互推、应用内交叉推广推广服务,同时为开发者提供市场审核,使得双方对广告功能进行统一管理、动态配置。
0 0
- phonegap添加消息推送插件教程
- IOS版添加phonegap--本地消息推送教程
- IOS版添加phonegap--paypal插件教程
- IOS版添加phonegap--插件写法教程
- Android版添加phonegap--Crosswalk插件教程
- Android版添加phonegap--imagePicker插件教程
- Android版添加phonegap--ChildBrowser插件教程
- Android版添加phonegap--Camera插件教程
- Html5添加phonegap--Accelerometer插件教程
- Android添加phonegap--sencha touch2插件教程
- Html5添加phonegap--Contacts插件教程
- Android添加phonegap--文件上传插件教程
- h5 消息推送 jpush-phonegap-plugin 插件的使用
- Android版添加phonegap--ionic时间选择插件插件教程
- phonegap push-消息推送实现
- PhoneGap极光推送插件使用
- Android版添加phonegap-百度地图插件教程
- Android版添加phonegap-百度社会化分享插件教程
- GPRS 数据传输
- VC++编写ActiveX控件
- Android API 中文(13) —— ToggleButton
- Android上gdb+gdbserver调试初体验
- 警告: No mapping found for HTTP request with URI的解决方案
- phonegap添加消息推送插件教程
- Webpower:2016节日营销趋势
- (第一行代码笔记)活动的4种启动模式详解
- 安装HP ALM 11(QC 11)问题---windows 2012 server R2
- 数据库
- Spark修炼之道(高级篇)——Spark源码阅读:第十三节 Spark SQL之SQLContext(一)
- AOP(2)
- 代码规范
- viewDidUnload与dealloc的执行时机