• Jpush推送模块


     

    此文章已于 14:17:10 2015/3/24 重新发布到 鲸歌

    Jpush推送模块

     

     

    目前SDK只支持Android 2.1或以上版本的手机系统。

    SDK集成步骤

    1、导入 SDK 开发包到你自己的应用程序项目

    •    解压缩 jpush-sdk_v1.x.y.zip 集成压缩包

    •    复制 libs/jpush-sdk-release1.x.y.jar 到工程 libs/ 目录下

    •    复制 libs/armeabi/libjpush1xy.so 到工程 libs/armeabi 目录下

        如果您的项目有 libs/armeabi-v7a 这个目录,请把armeabi so文件 也复制一份到这个目录。

    2、配置 AndroidManifest.xml

    根据 SDK 压缩包里的 AndroidManifest.xml 样例文件,来配置应用程序项目的 AndroidManifest.xml

    主要步骤为:

    1.    复制备注为 "Jpush Required" 的部分

    2.    将备注为替换包名的部分,替换为当前应用程序的包名

    3.    AppKey替换为在Portal上注册该应用的的Key,例如(9fed5bcb7b9b87413678c407

     

    权限配置:

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

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

    package="com.orca.jpush"

    android:versionCode="100"

    android:versionName="1.0.0"

    >

     

    <!-- Jpush Required -->

    <permission android:name="com.orca.jpush.permission.JPUSH_MESSAGE" android:protectionLevel="signature" />

     

    <!-- Jpush Required -->

    <uses-permission android:name="com.orca.jpush.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" />

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

    <uses-permission android:name="android.permission.WRITE_SETTINGS" /> <!--since 1.6.0 -->

     

    <!-- Optional. Jpush 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" />

     

    <!--应用包名及appkey替换: >

    <application

    android:icon="@drawable/ic_launcher"

    android:label="@string/app_name"

    android:name="Your Application">

     

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

     

    <!-- Jpush Required -->

    <receiver

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

    android:enabled="true" >

    <intent-filter android:priority="1000"> <!--since 1.3.5 -->

    <action android:name="cn.jpush.android.intent.NOTIFICATION_RECEIVED_PROXY" /> <!--since 1.3.5 -->

    <category android:name="com.orca.jpush" /> <!--since 1.3.5 -->

    </intent-filter> <!--since 1.3.5 -->

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

    <!-- Jpush 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="com.orca.jpush" />

    </intent-filter>

    </activity>

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

    <service

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

    android:enabled="true"

    android:exported="false" >

    </service>

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

    <receiver android:name="cn.jpush.android.service.AlarmReceiver" />

     

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

    <!-- Jpush Required. AppKey copied from Portal -->

    <meta-data android:name="JPUSH_APPKEY" android:value="14177cf8b6389078bafb6b33"/>

    </application>

    </manifest>

     

    3、必须权限说明

    权限    用途

    You Package.permission.JPUSH_MESSAGE    官方定义的权限,允许应用接收JPUSH内部代码发送的广播消息。

    RECEIVE_USER_PRESENT    允许应用可以接收点亮屏幕或解锁广播。

    INTERNET    允许应用可以访问网络。

    WAKE_LOCK    允许应用在手机屏幕关闭后后台进程仍然运行

    READ_PHONE_STATE    允许应用访问手机状态。

    WRITE_EXTERNAL_STORAGE    允许应用写入外部存储。

    READ_EXTERNAL_STORAGE    允许应用读取外部存储。

    WRITE_SETTINGS    允许应用读写系统设置项。

    VIBRATE    允许应用震动。

    MOUNT_UNMOUNT_FILESYSTEMS    允许应用挂载/卸载 外部文件系统。

    ACCESS_NETWORK_STATE    允许应用获取网络信息状态,如当前的网络连接是否有效。

    SYSTEM_ALERT_WINDOW    允许应用显示系统窗口,位于显示的顶层。

     

    4、添加代码

    JPush SDK 提供的 API 接口,都主要集中在 cn.jpush.android.api.JPushInterface 类里。

    基础 API

    •    init 初始化SDK

    ?

    public static void init(Context context)

    •    setDebugMode 设置调试模式

    ?

    // You can enable debug mode in developing state. You should close debug mode when release.

    public static void setDebugMode(boolean debugEnalbed)

    添加统计代码

    •    参考文档: 统计分析 API

    调用示例代码(参考 example 项目)

    •    init 只需要在应用程序启动时调用一次该 API 即可。

    •    以下代码定制一个本应用程序 Application 类。需要在 AndoridManifest.xml 里配置。请参考上面 AndroidManifest.xml 片断,或者 example 项目。

    ?

    public class ExampleApplication extends Application {

    @Override

    public void onCreate() {

    super.onCreate();

    JPushInterface.setDebugMode(true);

    JPushInterface.init(this);

    }

    }

    5、测试确认

    1.    确认所需的权限都已经添加。如果必须的权限未添加,日志会提示错误。

    2.    确认 AppKey(在Portal上生成的)已经正确的写入 Androidmanifest.xml

    3.    确认在程序启动时候调用了init(context) 接口

    4.    确认测试手机(或者模拟器)已成功连入网络

    •    客户端调用 init 后不久,如果一切正常,应有登录成功的日志信息

    5.    启动应用程序,在 Portal 上向应用程序发送自定义消息或者通知栏提示。详情请参考管理Portal

    •    在几秒内,客户端应可收到下发的通知或者正定义消息

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

     

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

    1.    检查 metadata appKey channel ,如果不存在,则启动失败

    2.    初始化 JPush SDK,检查 JNI 等库文件的有效性,如果库文件无效,则启动失败

    3.    检查 Androidmanifest.xml,如果有 Required 的权限不存在,则启动失败

    4.    连接服务器登录,如果存在网络问题,则登陆失败,或者前面三步有问题,不会启动JPush SDK

     

  • 相关阅读:
    解决调用未定义 swoole_async_readfile函数问题
    7000字 Redis 超详细总结笔记总 | 收藏必备!
    C/C++语言编程修养
    glib 队列
    sprintf 详解
    json 需替换 特殊字符串
    glib 关系
    glib 简介
    gprof 代码效率测量
    glib 树
  • 原文地址:https://www.cnblogs.com/jinglecode/p/4362656.html
Copyright © 2020-2023  润新知