最近一直在研究各种推送,ios的由于是apns,比较容易实现,但是andriod的就比较麻烦。后来看了很多解决方案,gcm明显是不行的,其他的方案更是一头雾水,而且需要做第二次开发,太麻烦,后来就选择用第三方的服务来实现推送。 
目前国内做的比较好的有个推和极光。 
个推最优但是需要付费。对于我们这样的小app,根本应付不了,然后果断选择极光。 
以下是我对phonegap 与极光sdk的整合过程。

1.注册极光的开发者账户,并注册应用信息。 创建帐号进入极光推送平台后,首先显示的是创建应用的界面。填上你的应用程序的名称,以及 Android包名这二顶就可以了。

<ignore_js_op>

用创建成功,即进入“应用详情”显示界面。这个界面右下角,你可以看到 “appkey" 后面会用到。

<ignore_js_op>

2,下载 sdk包。就行整合 
具体的流程可以看以下文档,当然phonegap的整合和这个有些不同。 
http://docs.jpush.cn/pages/viewpage.action?pageId=557214

3.SDK集成步骤 1、导入 SDK 开发包到你自己的应用程序项目

  • 解压缩 jpush-sdk_v1.x.y.zip 集成压缩包
  • 复制 libs/jpush-sdk-release1.x.y.jar 到工程 libs/ 目录下
  • 复制 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 。 
主要步骤为:

  • 复制备注为 "Required" 的部分
  • 将备注为替换包名的部分,替换为当前应用程序的包名
  • 将AppKey替换为在Portal上注册该应用的的Key,例如(9fed5bcb7b9b87413678c407)
普通浏览复制代码
  1. <manifest xmlns:android="http://schemas.android.com/apk/res/android" 
  2. package="Your Package" 
  3. android:versionCode="100" 
  4. android:versionName="1.0.0" 
  5.  
  6.  
  7. <uses-permission 
  8. android:name="android.permission.RECEIVE_USER_PRESENT"/> 
  9.  
  10.  
  11.  
  12. <uses-permission 
  13. android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> 
  14. <uses-permission 
  15. android:name="android.permission.READ_EXTERNAL_STORAGE"/> 
  16.  
  17. <uses-permission 
  18. android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/> 
  19. <uses-permission 
  20. android:name="android.permission.ACCESS_NETWORK_STATE"/> 
  21. <uses-permission 
  22. android:name="android.permission.ACCESS_COARSE_LOCATION"/> 
  23. <uses-permission 
  24. android:name="android.permission.ACCESS_COARSE_UPDATES"/> 
  25.  
  26.  
  27. <uses-permission 
  28. android:name="android.permission.ACCESS_FINE_LOCATION"/> 
  29. <uses-permission 
  30. android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS"/> 
  31. <uses-permission 
  32. android:name="android.permission.CHANGE_NETWORK_STATE"/> 
  33. <application 
  34. android:icon="@drawable/ic_launcher" 
  35. android:label="@string/app_name" 
  36. android:name="Your Application"> 
  37. <service 
  38. android:name="cn.jpush.android.service.PushService" 
  39. android:enabled="true" 
  40. android:exported="false"> 
  41.  
  42.  
  43.  
  44.  
  45.  
  46. <receiver 
  47. android:name="cn.jpush.android.service.PushReceiver" 
  48. android:enabled="true"> 
  49.  
  50.  
  51.  
  52.  
  53.  
  54.  
  55.  
  56. <activity 
  57. android:name="cn.jpush.android.ui.PushActivity" 
  58. android:theme="[url=http://my.oschina.net/asia]@android[/url] :style/Theme.Translucent.NoTitleBar" 
  59. android:configChanges="orientation|keyboardHidden"> 
  60.  
  61.  
  62.  
  63.  
  64. <service 
  65. android:name="cn.jpush.android.service.DownloadService" 
  66. android:enabled="true" 
  67. android:exported="false"> 
  68.  
  69. <meta-data 
  70. android:name="JPUSH_CHANNEL"android:value="developer-default"/> 
  71.  

这里需要注意的是:之前已经加过的一些xml信息,这时候要一一对照把这里面的信息 一条一条添加进去。 
注意顺序: 
<ignore_js_op>

3、添加代码 JPush SDK 提供的 API 接口,都主要集中在 cn.jpush.android.api.JPushInterface 类里。 
按照下面的方法来修改:

<ignore_js_op>

4、测试确认 

  • 确认所需的权限都已经添加。如果必须的权限未添加,日志会提示错误。
  • 确认 AppKey(在Portal上生成的)已经正确的写入 Androidmanifest.xml 。
  • 确认在程序启动时候调用了init(context) 接口
  • 确认测试手机(或者模拟器)已成功连入网络
    • 客户端调用 init 后不久,如果一切正常,应有登录成功的日志信息
  • 启动应用程序,在 Portal 上向应用程序发送自定义消息或者通知栏提示。详情请参考管理Portal。
    • 在几秒内,客户端应可收到下发的通知或者正定义消息

如果 SDK 工作正常,则日志信息会如下图所示:

<ignore_js_op>

如图所示,客户端启动分为 4 步:

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

只要测试成功,ok,你可以去管理Portal,去发送信息了。没有意外的话,就能收到信息。 当然这个仅仅是简单的推送消息功能,具体的一些应用,可以再参考官方的api文档来自己开发。

原文链接: phonegap push-消息推送实现

phonegap 使用极光推送实现消息推送的更多相关文章

  1. [转]PhoneGap使用PushPlugin插件实现消息推送

    本文转自:http://my.oschina.net/u/1270482/blog/217661 http://devgirl.org/2013/07/17/tutorial-implement-pu ...

  2. .NET对接极光消息推送

    什么是APP消息推送? 很多手机APP会不定时的给用户推送消息,例如一些新闻APP会给用户推送用户可能感兴趣的新闻,或者APP有更新了,会给用户推送是否选择更新的消息等等,这就是所谓的"消息 ...

  3. 我有 7种 实现web实时消息推送的方案,7种!

    技术交流,公众号:程序员小富 大家好,我是小富- 我有一个朋友- 做了一个小破站,现在要实现一个站内信web消息推送的功能,对,就是下图这个小红点,一个很常用的功能. 不过他还没想好用什么方式做,这里 ...

  4. 基于ajax与msmq技术的消息推送功能实现

    周末在家捣鼓了一下消息推送的简单例子,其实也没什么技术含量,欢迎大伙拍砖.我设计的这个推送demo是基于ajax长轮询+msmq消息队列来实现的,具体交互过程如下图: 先说说这个ajax长轮询,多长时 ...

  5. Android消息推送完美方案[转]

    转自 Android消息推送完美方案 推送功能在手机应用开发中越来越重要,已经成为手机开发的必须.在Android应用开发中,由于众所周知的原因,Android消息推送我们不得不大费周折.本文就是用来 ...

  6. Android消息推送完美方案

    转自:http://bbs.hiapk.com/thread-4652657-1-1.html 推送功能在手机应用开发中越来越重要,已经成为手机开发的必须.在Android应用开发中,由于众所周知的原 ...

  7. Android消息推送完美解决方案全析

    推送功能在手机应用开发中越来越重要,已经成为手机开发的必须.在Android应用开发中,由于众所周知的原因,Android消息推送我们不得不大费周折.本文就是用来和大家共同探讨一种Android消息推 ...

  8. 基于socket.io的实时消息推送

    用户访问Web站点的过程是基于HTTP协议的,而HTTP协议的工作模式是:请求-响应,客户端发出访问请求,服务器端以资源数据响应请求. 也就是说,服务器端始终是被动的,即使服务器端的资源数据发生变化, ...

  9. How Javascript works (Javascript工作原理) (九) 网页消息推送通知机制

    个人总结: 1.介绍了网页消息推送通知机制 全文地址:https://github.com/Troland/how-javascript-works 这是 JavaScript 工作原理的第九章. 现 ...

随机推荐

  1. 【hdu3247-Resource Archiver】位压DP+AC自动机+SPFA

    题意:给定n个文本串,m个病毒串,文本串重叠部分可以合并,但合并后不能含有病毒串,问所有文本串合并后最短多长. (2 <= n <= 10, 1 <= m <= 1000) 题 ...

  2. lintcode:背包问题II

    背包问题II 给出n个物品的体积A[i]和其价值V[i],将他们装入一个大小为m的背包,最多能装入的总价值有多大? 注意事项 A[i], V[i], n, m均为整数.你不能将物品进行切分.你所挑选的 ...

  3. hdu 4664 Triangulation(题意已在讨论版中说明)

    题意: 给定n个平面(平面之间相互独立),每个平面上有一些点,并且构成凸集,C和D轮流选一个平面连接两个点画线段,并保证线段之间除了端点之外没有其它交点,当平面上出现一个完整的三角形之后此平面就不能继 ...

  4. Linux之proc详解

    1. /proc目录    Linux内核提供了一种通过/proc文件系统,在运行时访问内核内部数据结构.改变内核设置的机制.proc文件系统是一个伪文件系统,它只存在内存当中,而不占用外存空间.它以 ...

  5. C++不能显式调用构造函数,会生成匿名对象,这点与Java完全不一样!

    Java可以直接调用同名构造函数,仅仅起初始化的功能,并不构造新的对象,但是C++里面没有.看一下这段代码: class A { public: A() { printf("A() \n&q ...

  6. jquery.flip插件翻转效果

    首先去网站http://lab.smashup.it/flip/下载插件 简单应用: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Tran ...

  7. Spring boot 整合jsp和tiles模板

    首先贴上我的pox.xml文件,有详细的支持注释说明 <?xml version="1.0" encoding="UTF-8"?> <proj ...

  8. nodejs 文件上传

    var multipart = require('connect-multiparty'); var fs = require('fs'); var multipartMiddleware = mul ...

  9. USACO Section 2.1: Hamming Codes

    挺简单的一道题 /* ID: yingzho1 LANG: C++ TASK: hamming */ #include <iostream> #include <fstream> ...

  10. DOJO 八 event dojo/on

    官网教程:Events with Dojo在元素上绑定events,需要引用包dojo/on,通过on方法来实现. <button id="myButton">Clic ...