魅族开放平台 PUSH 系统 JAVA 版本 SDK JavaPushSdk 发布说明 ( 请使用最新版本 ) 中央仓库获取 MVN Repository 或者 Central Repository 直接下载获取 Java Server SDK 更新日志 [ ]V

Similar documents
集成推送平台 JAVA 版本 SDK JavaPushSdk 发布说明 ( 请使用最新版本 ) 中央仓库获取 MVN Repository 或者 Central Repository 直接下载获取 Java Server SDK 更新日志 [ ]V

魅族推送平台接入文档 (JAVA-SDK)

推送平台开放接口

1005 错误, 请参考 API 文档 1006 签名认证失败 不合法 appkey 不合法 不能为空 应用被加入黑名单 应用推送速率过快 透传超过限制 接口签名规范 请求分别是 k1 k2 k3, 它们的值分别是

推送平台开放接口

上述字符串的 MD5 值即为签名的值 (32 位小写 ) 将签名值放在请求的参数中例如 sign=md5_sign 服务端 SDK 调用 API 的应用的私钥 Secret Key 为 appsecret /** parammap 请求参数 secret 密钥 *

获取 Access Token access_token 是接口的全局唯一票据, 接入方调用各接口时都需使用 access_token 开发者需要进行妥善保存 access_token 的存储至少要保留 512 个字符空间 access_token 的有效期目前为 2 个小时, 需定时刷新, 重复

OPPO 推送平台服务端 API 修订记录 : 版本号修订人修订日期修订描述 V0.1 宫建涛 初始版本 V0.2 宫建涛 部分 API 修改 V0.3 宫建涛 修改返回码 V0.4 宫建涛 修改推送统计接口 V

在设备联网情况下, 到达率可达到 99.9% 三 基本架构 四 组件说明 Push Service:Flyme OS 上的一个常驻系统服务, 在网络可达的情况下时刻保持与推送服务器的长连接 Push SDK: 用于接收 Push Service 透传过来的消息并回调给应用, 它包括 Android

此文章将会根据不同厂商的 SDK 的接入方式逐步分析, 进而梳理出最为精简的接入方式, 同时说明各个接入配置的细节问题 一接入准备工作 关于组件的基本配置将会全部打包到 aar 中的 AndroidManifest 中, 用户只需要手动配置一些与包名相关的权限配置 1.1 小米 混淆配置 基于 aa

集成推送平台 PushSDK 设计文档 此文档在于向开发者介绍魅族统一推送平台 PushSDK 如何对各个厂家的 PushSDK 进行整合以及我们在统一接口设计中遵循的规则, 由于各个厂家的 API 接口功能差异巨大我们只对各个厂商共用的接口进行统一封装, 当然你也可以直接使用厂商提供的接口 Ups

停止混流接口 请注意 : 该功能需要联系 ZEGO 技术支持开通 1 接口调用说明 http 请求方式 : POST/FORM, 需使用 https 正式环境地址 access_token=access_token (http

1.JasperReport ireport JasperReport ireport JDK JDK JDK JDK ant ant...6

新・解きながら学ぶJava

魅族推送平台接入文档 (Push-Demo)

RPC SOAP REST API API HTTP JSON XML PHP PHP PHP PHP PHP HTTP request/response cycle HTTP HTTP verbs headers Cookies JSON XML PHP RPC SOAP RESTful HTTP

Guava学习之Resources

优斗士微分销产品使用指南

SDK 概要 使用 Maven 的用户可以从 Maven 库中搜索 "odps-sdk" 获取不同版本的 Java SDK: 包名 odps-sdk-core odps-sdk-commons odps-sdk-udf odps-sdk-mapred odps-sdk-graph 描述 ODPS 基

概述

09 (File Processes) (mkdir) 9-3 (createnewfile) 9-4 (write) 9-5 (read) 9-6 (deletefile) 9-7 (deletedir) (Exercises)

3.1 num = 3 ch = 'C' 2

Microsoft Word - 01.DOC

新美大酒店开放平台SDK(.NET版)使用说明.pages

EJB-Programming-3.PDF

untitled

RxJava

國家圖書館典藏電子全文

(TestFailure) JUnit Framework AssertionFailedError JUnit Composite TestSuite Test TestSuite run() run() JUnit

1. 访 问 最 新 发 行 公 告 信 息 jconnect for JDBC 访 问 最 新 发 行 公 告 信 息 最 新 版 本 的 发 行 公 告 可 以 从 网 上 获 得 若 要 查 找 在 本 产 品 发 布 后 增 加 的 重 要 产 品 或 文 档 信 息, 请 访

chp6.ppt

2 SGML, XML Document Traditional WYSIWYG Document Content Presentation Content Presentation Structure Structure? XML/SGML 3 2 SGML SGML Standard Gener

Microsoft PowerPoint - 05-Status-Codes-Chinese.ppt

概述

目 录 概 述 背 景 社 会 背 景 行 业 背 景 需 求 分 析..6 3 优 势 分 析 资 源 优 势 品 牌 优 势 技 术 优 势 用 户 体 验.....

EJB-Programming-4-cn.doc

1 1 大概思路 创建 WebAPI 创建 CrossMainController 并编写 Nuget 安装 microsoft.aspnet.webapi.cors 跨域设置路由 编写 Jquery EasyUI 界面 运行效果 2 创建 WebAPI 创建 WebAPI, 新建 -> 项目 ->

PIC_SERVER (11) SMTP ( ) ( ) PIC_SERVER (10) SMTP PIC_SERVER (event driven) PIC_SERVER SMTP 1. E-

跨領域學位學程

epub83-1

Java

59 1 CSpace 2 CSpace CSpace URL CSpace 1 CSpace URL 2 Lucene 3 ID 4 ID Web 1. 2 CSpace LireSolr 3 LireSolr 3 Web LireSolr ID

( Version 0.4 ) 1

KillTest 质量更高 服务更好 学习资料 半年免费更新服务

untitled

(Methods) Client Server Microsoft Winsock Control VB 1 VB Microsoft Winsock Control 6.0 Microsoft Winsock Control 6.0 1(a). 2

CAS CAS GY/Z GY/Z Extensible Markup Language (XML) 1.0 File Transfer Protocol, RFC959, RFC1123, RFC228, RFC2577, RFC

构建 Bluetooth 移动应用 主讲人 : 任凯 微信 :kaiser-tech 2016 年 5 月 6 日 3

JavaIO.PDF

2 WF 1 T I P WF WF WF WF WF WF WF WF 2.1 WF WF WF WF WF WF

云数据库 RDS SDK

關於本書 l 3 PhoneGap Appcelerator Titanium Sencha Touch (wrapper framework) Native App PhoneGap Build Native App Hybrid App Java Objective-C Android SDK

ARP ICMP

CC213

untitled

Microsoft Word - 第3章.doc

untitled

Microsoft Word - PHP7Ch01.docx

untitled

ASP 電子商務網頁設計

<4D F736F F D203120BBA5C1AACDF8BBF9B4A1B1EAD7BC2E646F63>

CHAPTER 1

Microsoft Word - 正文.doc

问 调 用 云 端 的 语 音 服 务 的 接 口 形 式, 对 规 范 语 音 识 别 服 务 提 供 方 式, 方 便 客 户 端 的 集 成 调 用, 从 而 促 进 语 音 交 互 应 用 的 推 广 发 展, 促 进 广 大 用 户 充 分 享 受 到 语 音 交 互 带 来 的 快 速

Partition Key: 字 符 串 类 型, 表 示 当 前 Entity 的 分 区 信 息 这 个 Property 对 于 Table Service 自 动 纵 向 和 横 向 扩 展 至 关 重 要 Row Key: 字 符 串 类 型, 在 给 定 Partition Key 的

PowerPoint 演示文稿

第 4 章 XMLHttpRequest 对象 AJAX AJAX 2 iframe AJAX iframe XMLHttpRequest JavaScript iframe AJAX XMLHttpRequest XMLHttpRequest Server Access Object Web XM

获取 Access Token 1 基础概念 access_token 是接口的全局唯一票据, 接入方调用各接口时都需使用 access_token 开发者需要妥善保存,access_token 的存储至少要保留 512 个字符空间 access_token 的有效期目前为 2 个小时, 需定时刷新

威 福 髮 藝 店 桃 園 市 蘆 竹 區 中 山 里 福 祿 一 街 48 號 地 下 一 樓 50,000 獨 資 李 依 純 105/04/06 府 經 登 字 第 號 宏 品 餐 飲 桃 園 市 桃 園 區 信 光 里 民




Java Access 5-1 Server Client Client Server Server Client 5-2 DataInputStream Class java.io.datainptstream (extends) FilterInputStream InputStream Obj

「人名權威檔」資料庫欄位建置表

ebook 86-15

雲端 Cloud Computing 技術指南 運算 應用 平台與架構 10/04/15 11:55:46 INFO 10/04/15 11:55:53 INFO 10/04/15 11:55:56 INFO 10/04/15 11:56:05 INFO 10/04/15 11:56:07 INFO

Java java.lang.math Java Java.util.Random : ArithmeticException int zero = 0; try { int i= 72 / zero ; }catch (ArithmeticException e ) { // } 0,

Socket Socket TcpClient Socket.Connect TcpClient.Connect Socket.Send / Receive NetworkStream 6-5

Simulator By SunLingxi 2003

untitled

(CIP) Web /,. :, ISBN X.W T P393.4 CIP (2004) Web ( ) ( / ) : * 787

Microsoft Word - 苹果脚本跟我学.doc

RUN_PC連載_8_.doc

<4D F736F F D BEC7A67EABD7B9B4A5CDB3E6BF57A9DBA5CDC2B2B3B B0EABBDA E646F63>

untitled

<4D F736F F D20BBF9D3DA416E64726F6964C6BDCCA8B5C4B5E7D7D3C5C4C2F4CFB5CDB32E646F63>

本章学习目标 小风 Java 实战系列教程 SpringMVC 简介 SpringMVC 的入门案例 SpringMVC 流程分析 配置注解映射器和适配器 注解的使用 使用不同方式的跳转页面 1. SpringMVC 简介 Spring web mvc

F515_CS_Book.book

Chapter #

Chapter 9: Objects and Classes

PowerPoint 演示文稿

詞 彙 表 編 號 詞 彙 描 述 1 預 約 人 資 料 中 文 姓 名 英 文 姓 名 身 份 證 字 號 預 約 人 電 話 性 別 2 付 款 資 料 信 用 卡 別 信 用 卡 號 信 用 卡 有 效 日 期 3 住 房 條 件 入 住 日 期 退 房 日 期 人 數 房 間 數 量 入

關於本書 Part 3 CSS XHTML Ajax Part 4 HTML 5 API JavaScript HTML 5 API Canvas API ( ) Video/Audio API ( ) Drag and Drop API ( ) Geolocation API ( ) Part 5

ebook

使用Cassandra和Spark 2.0实现Rest API服务

Microsoft Word - SDD.doc

TC35短信发送程序设计

1. 2. Flex Adobe 3.

weblogic

第1章 簡介

Important Notice SUNPLUS TECHNOLOGY CO. reserves the right to change this documentation without prior notice. Information provided by SUNPLUS TECHNOLO

Transcription:

魅族开放平台 PUSH 系统 JAVA 版本 SDK JavaPushSdk 发布 ( 请使用最新版本 ) 中央仓库获取 MVN Repository 或者 Central Repository 直接下载获取 Java Server SDK 更新日志 [2018-03-07]V1.2.7.20180307_release 增加 sdk 日志配置文件 [2017-11-23]V1.2.6.20171123_release 增加 pushid 开关关闭状态返回 [2017-11-20]V1.2.5.20171120_release 通知栏消息聚合功能 [2017-08-15]V1.2.4.20170815_release 推送 & 订阅域名解耦 [2017-07-18]V1.2.3.20170718_release 通知栏 pushid alias 增加消息回执功能 [2017-06-09]V1.2.2.20170609_release 开放统计 : 获取应用推送统计 ( 最长跨度 30 天 ) [2017-04-28]V1.2.1.20170428_release 开放别名 标签订阅服务开放通知栏 透传消息开关 [2017-03-21]V1.1.1.20170321_release fixed #12 [2017-02-16]V1.1.0.20170216_release 推送结果增加 msgid 通过 msgid 以及推送目标在推送平台查询具体的推送日志明细 [2016-12-18]V1.0.0.20161218_release 1/39

1.0.0 标准版 为优化 flyme 系统整体功耗, 推送平台决定本周五 (6 月 16 号 ) 起限制透传消息推送的使用, 不排除关闭透传推送 使用透传推送的业务请尽快切换到通知栏推送, 以避免消息推送失败 新接入的应用请使用通知栏推送受影响的及功能 : 1. pushid 透传消息推送 (pushmessage) 2. 别名透传消息推送 (pushmessagebyalias) 3. 获取 taskid 的透传推送 (gettaskid) 4. 全网透传推送 (pushtoapp) 5. 标签透传推送 (pushtotag) 6. 在平台上进行的透传推送 SDK 日志配置 本 SDK 是利用 JDK 中类 java.util.logging.logger 来记录日志, 如需 SDK 日志,classpath 中增加 flyme-pushlogger.properties 文件即可配置如下 handlers = java.util.logging.consolehandler,java.util.logging.filehandler java.util.logging.consolehandler.formatter = java.util.logging.simpleformatter java.util.logging.consolehandler.level = INFO java.util.logging.filehandler.pattern = c:/push.log%g.log java.util.logging.filehandler.formatter = java.util.logging.simpleformatter java.util.logging.filehandler.limit = 104857600 java.util.logging.filehandler.count = 3 java.util.logging.filehandler.append = true java.util.logging.filehandler.level = INFO LOGGER.level = FINEST 定义 推送服务 (IFlymePush) 调用该类实例的方法来推送消息, 构造函数如下 : 必填 appsecret String 是 null 注册应用 appsecret 2/39

usessl Boolean 否 false 是否使用 https 调用 :true 使用 https 连接,false 使用 http 连接 订阅服务 (IFlymePushSub) 调用该类实例的方法做别名 标签 推送开关订阅服务, 构造函数如下 : 必填 appid Long 是 null 注册应用 appid appsecret String 是 null 注册应用 appsecret usessl Boolean 否 false 是否使用 https 调用 :true 使用 https 连接,false 使用 http 连接 通知栏消息体 (Message) 推送消息实体 ( 抽象类 ) 子类 VarnishedMessage UnVarnishedMessage 通知栏消息体 透传消息体 通知栏消息 (VarnishedMessage) 必 填 appid Long 是 null 注册应用 appid title String 是 null 推送标题, 字数限制 1~32 content String 是 null 推送内容, 字数限制 1~100 noticebartype int 否 0 noticeexpandtype int 否 0 通知栏样式 (0, " 标准 "),(2, " 安卓原生 ") 非必填, 值为 0 展开方式 (0, " 标准 "),(1, " 文本 ") 非必填, 值为 0 noticeexpandcontent String 否 null 展开内容, noticeexpandtype 为文本时, 必填 clicktype int 否 0 url String 否 null 点击动作 (0," 打开应用 "),(1," 打开应用页面 "),(2," 打开 URI 页面 "),(3, " 应用客户端自定义 ") 非必填, 值为 0 URI 页面地址, clicktype 为打开 URI 页面时, 必填, 长度限制 1000byte parameters JSONObject 否 null 透传参数 JSON 格式, 非必填 3/39

activity String 否 null customattribute String 否 null isoffline Boolean 否 true validtime int 否 24 pushtimetype int 否 0 starttime Date 否 null 应用页面地址, clicktype 为打开应用页面时, 格式 pkg.activity eg: com.meizu.upspushdemo.testactivity 必填 应用客户端自定义内容, clicktype 为应用客户端自定义时, 必填, 长度限制 1000byte 是否进离线消息, (false 否 true 是 ) 非必填, 值为 true 有效时长 (1~72 小时内的正整数 ), isoffline 值为 true 时, 必填, 值的范围 1~72 定时推送 (0, " 即时 "),(1, " 定时 "), 只对全部用户推送生效 任务定时开始时间, 非必填,pushTimeType 为 True 必填 只对全部用户推送生效 isfixspeed Boolean 否 false 是否定速推送, 非必填, 值为 False fixspeedrate Long 否 0 定速速率, isfixspeed 为 true 时, 必填 issuspend Boolean 否 true isclearnoticebar Boolean 否 true 是否通知栏悬浮窗显示 (true 显示,false 不显示 ) 非必填, True 是否可清除通知栏 (true 可以,false 不可以 ), 非必填, true isfixdisplay Boolean 否 false 是否定时展示 非必填, false fixdisplaytime (Date,Date) 否 (null,null) vibrate Boolean 否 true lights Boolean 否 true sound Boolean 否 true notifykey String 否 null 定时展示开始, 结束时间 fixdisplay 为 true 时, 必填, 并且开始时间要晚于结束时间 震动 (false 关闭 true 开启 ), 非必填, true 闪光 (false 关闭 true 开启 ), 非必填, true 声音 (false 关闭 true 开启 ), 非必填, true 分组合并推送的 key, 凡是带有此 key 的通知栏消息只会显示最后到达的一条 由数字 ([0-9]), 大小写字母 ([a-za-z]), 下划线 (_) 和中划线 (-) 组成, 长度不大于 8 个字符 extra Map<String, String> 否 null 回执参数 (ExtraParam) 透传消息 (UnVarnishedMessage) 4/39

必 填 默 认 appid Long 是 null 注册应用 appid title String 否 null 推送标题, 任务推送建议填写, 方便数据查询, 字数限制 1~32 content String 是 null 推送内容, 必填, 字数限制 3800byte 以内 isoffline Boolean 否 true 是否进离线消息, 非必填, 为 true validtime int 否 24 有效时长 (1~72 小时内的正整数 ), isoffline 值为 true 时, 必填, 值的范围 1--72 pushtimetype int 否 0 定时推送 (0, " 即时 "),(1, " 定时 "), 只对全部用户推送生效 starttime Date 否 null 任务定时开始时间, pushtimetype 为 1 必填 只对全部用户推 送生效 isfixspeed Boolean 否 false 是否定速推送, 非必填, 值为 false fixspeedrate Long 否 0 定速速率 isfixspeed 为 true 时, 必填 (ResultPack) 方法名称 code() String 响应码 Comment() String 响应 value() T 响应内容 errorcode() Enum 响应异常枚举详见 ErrorCode 消息推送结果 (PushResult) 方法名称 getmsgid() String 推送消息 ID, 用于推送流程明细排查 getresptarget() Map 推送目标结果状态 (KEY: 推送响应码 VALUE: 响应码对应的目标用户 ) 响应码定义 (ErrorCode) 名称 Code Commen UNKNOWN_ERROR -1 未知错误 SUCCESS 200 成功 SYSTEM_ERROR 1001 系统错误 SYSTEM_BUSY 1003 服务器忙 5/39

PARAMETER_ERROR 1005 参数错误, 请参考 API 文档 INVALID_SIGN 1006 签名认证失败 INVALID_APPLICATION_ID 110000 appid 不合法 INVALID_APPLICATION_KEY 110001 appkey 不合法 UNSUBSCRIBE_PUSHID 110002 pushid 未注册 INVALID_PUSHID 110003 pushid 非法 PARAM_BLANK 110004 参数不能为空 APP_IN_BLACK_LIST 110009 应用被加入黑名单 APP_REQUEST_EXCEED_LIMIT 110010 应用请求频率过快 APP_PUSH_TIME_EXCEED_LIMIT 110051 超过该应用的次数限制 APP_REQUEST_PUSH_LIMIT 110019 超过该应用每天推送次数限制 INVALID_APPLICATION_PACKAGENAME 110031 packagename 不合法 INVALID_TASK_ID 110032 非法的 taskid INVALID_APPLICATION_SECRET 110033 非法的 appsecret DIRECT_OUT_LIMIT 110053 透传超过限制 推送响应码定义 (PushResponseCode) 名称 Code Commen RSP_NO_AUT 201 没有权限, 服务器主动拒绝 RSP_DB_ERROR 501 推送消息失败 (db_error) RSP_INTERNAL_ERROR 513 推送消息失败 RSP_SPEED_LIMIT 518 推送超过配置的速率 RSP_OVERFLOW 519 推送消息失败服务过载 RSP_REPEATED 520 消息折叠 (1 分钟内同一设备同一应用消息收到多 次, 5 次 ) RSP_UNSUBSCRIBE_PUSHID pushid 失效 (pushid 未订阅 ) RSP_INVALID_PUSHID 110003 pushid 非法 RSP_UNSUBSCRIBE_ALIAS 110005 别名未订阅 ( 包括推送开关关闭的设备 ) RSP_OFF_PUSHID 110010 pushid 失效 ( 消息开关关闭 ) 推送 (PushType) 6/39

枚举 STATUSBAR Enum 通知栏消息 DIRECT Enum 透传消息 推送标签集合 (ScopeType) 枚举 UNION Enum 并集 INTERSECTION Enum 交集 任务推送统计 (TaskStatistics) 名称 targetno Long 目标数 validno Long 有效数 pushedno Long 推送数 acceptno Long 接受数 displayno Long 展示数 clickno Long 点击数 任务推送统计 ( 天 )(DailyPushStatics) 名称 date Date 日期 targetno Long 目标数 validno Long 有效数 pushedno Long 推送数 acceptno Long 接受数 displayno Long 展示数 clickno Long 点击数 订阅别名信息 (AliasInfo) 名称 pushid String 订阅 pushid 7/39

alias String 订阅别名 订阅标签信息 (TagInfo) 名称 pushid String 订阅 pushid tags List 订阅标签 订阅开关状态 (SwitchStatusInfo) 名称 pushid String 订阅 pushid statusbarswitch boolean 通知栏开关状态 directswitch boolean 透传开关状态 回执 (CallBackType) 枚举 RECEIVE Enum 送达回执 CLICK Enum 点击回执 RECEIVE_CLICK Enum 送达与点击回执 回执参数 (ExtraParam) 枚举 CALLBACK Enum 回执 ( 第三方接收回执的 Http, 最大长度 128 字节 ) CALLBACK_PARAM Enum 回执参数 ( 第三方自定义回执参数, 最大长度 64 字节 ) CALLBACK_TYPE Enum 回执 ((1- 送达回执, 2- 点击回执, 3- 送达与点击回执 ), 3) 非任务推送 向指定的 pushid 推送消息 注 : 推送平台使用 pushid 来标识每个独立的用户, 每一台终端上每一个 app 拥有一个独立的 pushid 8/39

应用场景 场景 1: 查找手机业务需要远程定位位置, 可发送消息指令到对应的设备 场景 2: 社区用户回帖消息提醒, 用户对发表的帖子有最新回复时, 消息提醒发帖者 pushid 通知栏消息推送 (pushmessage) ResultPack<PushResult> pushmessage(varnishedmessage message, List<String> pushids) ResultPack<PushResult> pushmessage(varnishedmessage message, List<String> pushids, int retries) 推送通知栏 消息 推送通知栏 消息 参数 message VarnishedMessage 是 null 推送消息 pushids List 是 null 推送目标, 一批最多不能超过 1000 个 retries int 否 0 超时 or 异常重试次数 PushResult msgid; 推送消息 ID, 用于推送流程明细排查 resptarget; 推送目标结果状态 (key: 推送响应码 value: 响应码对应的目标用户 ) 注 : 只返回不合法 超速以及推送失败的目标用户, 业务一般对超速的 pushid 处理 /** * 通知栏消息推送 (pushmessage) * @throws Exception */ public void testvarnishedmessagepush() throws Exception { // 推送对象 IFlymePush push = new IFlymePush(APP_SECRET_KEY); 9/39

// 组装消息 VarnishedMessage message = new VarnishedMessage.Builder().appId(appId).title("Java SDK 推送标题 ").content("java SDK 推送内容 ").noticeexpandtype(1).noticeexpandcontent(" 展开文本内容 ").clicktype(2).url("http://www.baidu.com").parameters(json.parseobject(" {\"k1\":\"value1\",\"k2\":0,\"k3\":\"value3\"")).offline(true).validtime(12).suspend(true).clearnoticebar(true).vibrate(true).lights(true).sound(true).build(); // 目标用户 List<String> pushids = new ArrayList<String>(); pushids.add("pushid_1"); pushids.add("pushid_2"); // 1 调用推送服务 ResultPack<PushResult> result = push.pushmessage(message, pushids); if (result.issucceed()) { // 2 调用推送服务成功 ( 其中 map 为设备的具体推送结果, 一般业务针对超速的 code 做处理 ) PushResult pushresult = result.value(); String msgid = pushresult.getmsgid();// 推送消息 ID, 用于推送流程明细排查 Map<Integer, List<String>> targetresultmap = pushresult.getresptarget();// 推送结果, 全部推送成功, 则 map 为 empty System.out.println("push msgid:" + msgid); System.out.println("push targetresultmap:" + targetresultmap); if (targetresultmap!= null &&!targetresultmap.isempty()) { // 3 判断是否有获取超速的 target if (targetresultmap.containskey(pushresponsecode.rsp_speed_limit.getvalue())) { // 4 获取超速的 target List<String> ratelimittarget = targetresultmap.get(pushresponsecode.rsp_speed_limit.getvalue()); System.out.println("rateLimitTarget is :" + ratelimittarget); //TODO 5 业务处理, 重推... else { // 调用推送服务异常 eg: appid appkey 非法 推送消息非法... // result.code(); // 服务异常码 // result.comment();// 服务异常 // 全部超速 if (String.valueOf(ErrorCode.APP_REQUEST_EXCEED_LIMIT.getValue()).equals(result.co de())) { //TODO 5 业务处理, 重推... 10/39

System.out.println(String.format("pushMessage error code:%s comment:%s", result.code(), result.comment())); pushid 透传消息推送 (pushmessage) ResultPack<PushResult> pushmessage(unvarnishedmessage message, List<String> pushids) ResultPack<PushResult> pushmessage(unvarnishedmessage message, List<String> pushids, int retries) 推送透传 消息 推送透传 消息 参数 message UnVarnishedMessage 是 null 推送消息 pushids List 是 null 推送目标, 一批最多不能超过 1000 个 retries int 否 0 超时 or 异常重试次数 PushResult msgid; 推送消息 ID, 用于推送流程明细排查 resptarget; 推送目标结果状态 (key: 推送响应码 value: 响应码对应的目标用户 ) 注 : 只返回不合法 超速以及推送失败的目标用户, 业务一般对超速的 pushid 处理 /** * 透传消息推送 (pushmessage) * @throws Exception */ public void testunvarnishedmessagepush() throws Exception { // 推送对象 IFlymePush push = new IFlymePush(APP_SECRET_KEY); // 组装透传消息 UnVarnishedMessage message = new UnVarnishedMessage.Builder().appId(appId) 11/39

.title("java SDK 透传推送标题 ").content("java Sdk 透传推送内容 ").isoffline(true).validtime(10).build(); // 目标用户 List<String> pushids = new ArrayList<String>(); pushids.add("pushid_1"); pushids.add("pushid_2"); // 1 调用推送服务 ResultPack<PushResult> result = push.pushmessage(message, pushids); if (result.issucceed()) { // 2 调用推送服务成功 ( 其中 map 为设备的具体推送结果, 一般业务针对超速的 code 做处理 ) PushResult pushresult = result.value(); String msgid = pushresult.getmsgid();// 推送消息 ID, 用于推送流程明细排查 Map<Integer, List<String>> targetresultmap = pushresult.getresptarget();// 推送结果, 全部推送成功, 则 map 为 empty System.out.println("push msgid:" + msgid); System.out.println("push targetresultmap:" + targetresultmap); if (targetresultmap!= null &&!targetresultmap.isempty()) { // 3 判断是否有获取超速的 target if (targetresultmap.containskey(pushresponsecode.rsp_speed_limit.getvalue())) { // 4 获取超速的 target List<String> ratelimittarget = targetresultmap.get(pushresponsecode.rsp_speed_limit.getvalue()); System.out.println("rateLimitTarget is :" + ratelimittarget); //TODO 5 业务处理, 重推... else { // 调用推送服务异常 eg: appid appkey 非法 推送消息非法... // result.code(); // 服务异常码 // result.comment();// 服务异常 // 全部超速 if (String.valueOf(ErrorCode.APP_REQUEST_EXCEED_LIMIT.getValue()).equals(result.co de())) { //TODO 5 业务处理, 重推... System.out.println(String.format("pushMessage error code:%s comment:%s", result.code(), result.comment())); 12/39

别名通知栏消息推送 (pushmessagebyalias) ResultPack<PushResult> pushmessagebyalias(varnishedmessage message, List<String> alias) ResultPack<PushResult> pushmessagebyalias(varnishedmessage message, List<String> alias, int retries) 推送通知 栏消息 推送通知 栏消息 参数 message VarnishedMessage 是 null 推送消息 alias List 是 null 推送目标, 一批最多不能超过 1000 个 retries int 否 0 超时 or 异常重试次数 PushResult msgid; 推送消息 ID, 用于推送流程明细排查 resptarget; 推送目标结果状态 (key: 推送响应码 value: 响应码对应的目标用户 ) 注 : 只返回不合法 超速以及推送失败的目标用户 /** * 别名通知栏消息推送 (pushmessage) * * @throws Exception */ public void testvarnishedmessagepushbyalias() throws Exception { // 推送对象 IFlymePush push = new IFlymePush(APP_SECRET_KEY); // 组装消息 VarnishedMessage message = new VarnishedMessage.Builder().appId(appId).title("Java SDK 推送标题 ").content("java SDK 推送内容 ").noticeexpandtype(1).noticeexpandcontent(" 展开文本内容 ").clicktype(2).url("http://push.meizu.com").parameters(json.parseobject(" 13/39

{\"k1\":\"value1\",\"k2\":0,\"k3\":\"value3\"")).offline(true).validtime(12).isfixdisplay(true).fixdisplaytime(str2date("2017-10-01 12:00:00"), str2date("2017-10-01 12:30:00")).suspend(true).clearNoticeBar(true).vibrate(true).lights(true).sound(true).build(); // 目标用户 List<String> alias = new ArrayList<String>(); alias.add("android"); alias.add("alias2"); // 1 调用推送服务 ResultPack<PushResult> result = push.pushmessagebyalias(message, alias); if (result.issucceed()) { // 2 调用推送服务成功 ( 其中 map 为设备的具体推送结果, 一般业务针对超速的 code 做处理 ) PushResult pushresult = result.value(); String msgid = pushresult.getmsgid();// 推送消息 ID, 用于推送流程明细排查 Map<Integer, List<String>> targetresultmap = pushresult.getresptarget();// 推送结果, 全部推送成功, 则 map 为 empty System.out.println("push msgid:" + msgid); System.out.println("push targetresultmap:" + targetresultmap); if (targetresultmap!= null &&!targetresultmap.isempty()) { // 3 判断是否有获取超速的 target if (targetresultmap.containskey(pushresponsecode.rsp_speed_limit.getvalue())) { // 4 获取超速的 target List<String> ratelimittarget = targetresultmap.get(pushresponsecode.rsp_speed_limit.getvalue()); System.out.println("rateLimitTarget is :" + ratelimittarget); //TODO 5 业务处理, 重推... else { // 调用推送服务异常 eg: appid appkey 非法 推送消息非法... // result.code(); // 服务异常码 // result.comment();// 服务异常 // 全部超速 if (String.valueOf(ErrorCode.APP_REQUEST_EXCEED_LIMIT.getValue()).equals(result.co de())) { //TODO 5 业务处理, 重推... System.out.println(String.format("pushMessage error code:%s comment:%s", result.code(), result.comment())); 14/39

别名透传消息推送 (pushmessagebyalias) ResultPack<PushResult> pushmessagebyalias(unvarnishedmessage message, List<String> alias) ResultPack<PushResult> pushmessagebyalias(unvarnishedmessage message, List<String> alias, int retries) 推送透传 消息 推送透传 消息 参数 message UnVarnishedMessage 是 null 推送消息 alias List 是 null 推送目标, 一批最多不能超过 1000 个 retries int 否 0 超时 or 异常重试次数 PushResult msgid; 推送消息 ID, 用于推送流程明细排查 resptarget; 推送目标结果状态 (key: 推送响应码 value: 响应码对应的目标用户 ) 注 : 只返回不合法 超速以及推送失败的目标用户 /** * 别名透传推送 * * @throws Exception */ public void testunvarnishedmessagepushbyalias() throws Exception { // 推送对象 IFlymePush push = new IFlymePush(APP_SECRET_KEY); // 组装透传消息 UnVarnishedMessage message = new UnVarnishedMessage.Builder().appId(appId).title("Java SDK 透传推送标题 ").content("java Sdk 透传推送内容 ").build(); 15/39

// 目标用户 List<String> alias = new ArrayList<String>(); alias.add("alias"); alias.add("alias2"); // 1 调用推送服务 ResultPack<PushResult> result = push.pushmessagebyalias(message, alias); if (result.issucceed()) { // 2 调用推送服务成功 ( 其中 map 为设备的具体推送结果, 一般业务针对超速的 code 做处理 ) PushResult pushresult = result.value(); String msgid = pushresult.getmsgid();// 推送消息 ID, 用于推送流程明细排查 Map<Integer, List<String>> targetresultmap = pushresult.getresptarget();// 推送结果, 全部推送成功, 则 map 为 empty System.out.println("push msgid:" + msgid); System.out.println("push targetresultmap:" + targetresultmap); if (targetresultmap!= null &&!targetresultmap.isempty()) { // 3 判断是否有获取超速的 target if (targetresultmap.containskey(pushresponsecode.rsp_speed_limit.getvalue())) { // 4 获取超速的 target List<String> ratelimittarget = targetresultmap.get(pushresponsecode.rsp_speed_limit.getvalue()); System.out.println("rateLimitTarget is :" + ratelimittarget); //TODO 5 业务处理, 重推... else { // 调用推送服务异常 eg: appid appkey 非法 推送消息非法... // result.code(); // 服务异常码 // result.comment();// 服务异常 // 全部超速 if (String.valueOf(ErrorCode.APP_REQUEST_EXCEED_LIMIT.getValue()).equals(result.co de())) { //TODO 5 业务处理, 重推... System.out.println(String.format("pushMessage error code:%s comment:%s", result.code(), result.comment())); 任务推送 16/39

首先获取推送的 taskid, 然后通过 taskid 向指定的 pushid 推送消息 应用场景 浏览器对指定的某一大批量 pushid 用户推送活动或者新闻消息, 通过先获取 taskid, 然后通过 taskid 批量 推送, 推送过程中可以根据 taskid 时时获取推送统计结果 获取推送 taskid(gettaskid) ResultPack gettaskid(pushtype pushtype, Message message) 获取推送 taskid 参数 pushtype PushType 是 null 消息 message Message 是 null 消息体 Long 任务 ID /** * 获取通知栏推送 taskid(gettaskid) * @throws Exception */ public void testgetvarnishedmessagetaskid() throws Exception { // 推送对象 IFlymePush push = new IFlymePush(APP_SECRET_KEY); // 组装消息 VarnishedMessage message = new VarnishedMessage.Builder().appId(appId).title("java Sdk 推送标题 ").content("java Sdk 推送内容 ").noticeexpandtype(1).noticeexpandcontent(" 展开文本内容 ").clicktype(2).url("http://www.baidu.com").parameters(json.parseobject(" {\"k1\":\"value1\",\"k2\":0,\"k3\":\"value3\"")) 17/39

.offline(true).validtime(12).suspend(true).clearnoticebar(true).vibrate(false).lights(false).sound(false).fixspeed(true).fixspeedrate(20).build(); ResultPack<Long> result = push.gettaskid(pushtype.statusbar, message); System.out.println(result); /** * 获取透传推送 taskid(gettaskid) * @throws Exception */ public void testgetunvarnishedmessagetaskid() throws Exception { // 推送对象 IFlymePush push = new IFlymePush(APP_SECRET_KEY); // 组装消息 UnVarnishedMessage message = new UnVarnishedMessage.Builder().appId(appId).title("java sdk 推送标题 ").content("java sdk 推送内容 ").build(); ResultPack<Long> result = push.gettaskid(pushtype.direct, message); System.out.println(result); pushid 消息推送 (pushmessagebytaskid) ResultPack<PushResult> pushmessagebytaskid(pushtype pushtype, long appid, long taskid, List<String> pushids) ResultPack<PushResult> pushmessagebytaskid(pushtype pushtype, long appid, long taskid, List<String> pushids, int retries) 任务消 息推送 任务消 息推送 参数 pushtype PushType 是 null 消息 appid Long 是 null 推送应用 ID 18/39

taskid Long 是 null 推送任务 ID pushids List 是 null 推送目标, 一批最多不能超过 1000 个 retries int 否 0 超时 or 异常重试次数 PushResult msgid; 推送消息 ID, 用于推送流程明细排查 resptarget; 推送目标结果状态 (key: 推送响应码 value: 响应码对应的目标用户 ) 注 : 只返回不合法 超速以及推送失败的目标用户, 业务一般对超速的 pushid 对处理 /** * 任务消息推送 (pushmessagebytaskid) * @throws IOException */ public void testpushpytaskid() throws IOException { // 推送对象 IFlymePush push = new IFlymePush(APP_SECRET_KEY); // 目标用户 List<String> pushids = new ArrayList<String>(); pushids.add("pushid_1"); pushids.add("pushid_2"); // 通知栏任务消息推送 Long taskid = 123l; // 1 调用推送服务 ResultPack<PushResult> result = push.pushmessagebytaskid(pushtype.statusbar, appid, taskid, pushids, 0); if (result.issucceed()) { // 2 调用推送服务成功 ( 其中 map 为设备的具体推送结果, 一般业务针对超速的 code 做处理 ) PushResult pushresult = result.value(); String msgid = pushresult.getmsgid();// 推送消息 ID, 用于推送流程明细排查 Map<Integer, List<String>> targetresultmap = pushresult.getresptarget();// 推送结果, 全部推送成功, 则 map 为 empty System.out.println("push msgid:" + msgid); System.out.println("push targetresultmap:" + targetresultmap); if (targetresultmap!= null &&!targetresultmap.isempty()) { // 3 判断是否有获取超速的 target if 19/39

(targetresultmap.containskey(pushresponsecode.rsp_speed_limit.getvalue())) { // 4 获取超速的 target List<String> ratelimittarget = targetresultmap.get(pushresponsecode.rsp_speed_limit.getvalue()); System.out.println("rateLimitTarget is :" + ratelimittarget); //TODO 5 业务处理, 重推... else { // 调用推送服务异常 eg: appid appkey 非法 推送消息非法... // result.code(); // 服务异常码 // result.comment();// 服务异常 System.out.println(String.format("pushMessage error code:%s comment:%s", result.code(), result.comment())); // 透传消息任务推送 taskid = 123l; // 1 调用推送服务 result = push.pushmessagebytaskid(pushtype.direct, appid, taskid, pushids, 0); if (result.issucceed()) { // 2 调用推送服务成功 ( 其中 map 为设备的具体推送结果, 一般业务针对超速的 code 做处理 ) PushResult pushresult = result.value(); String msgid = pushresult.getmsgid();// 推送消息 ID, 用于推送流程明细排查 Map<Integer, List<String>> targetresultmap = pushresult.getresptarget();// 推送结果, 全部推送成功, 则 map 为 empty System.out.println("push msgid:" + msgid); System.out.println("push targetresultmap:" + targetresultmap); if (targetresultmap!= null &&!targetresultmap.isempty()) { // 3 判断是否有获取超速的 target if (targetresultmap.containskey(pushresponsecode.rsp_speed_limit.getvalue())) { // 4 获取超速的 target List<String> ratelimittarget = targetresultmap.get(pushresponsecode.rsp_speed_limit.getvalue()); System.out.println("rateLimitTarget is :" + ratelimittarget); //TODO 5 业务处理, 重推... else { // 调用推送服务异常 eg: appid appkey 非法 推送消息非法... // result.code(); // 服务异常码 // result.comment();// 服务异常 // 全部超速 if (String.valueOf(ErrorCode.APP_REQUEST_EXCEED_LIMIT.getValue()).equals(result.co 20/39

de())) { //TODO 5 业务处理, 重推... System.out.println(String.format("pushMessage error code:%s comment:%s", result.code(), result.comment())); 别名消息推送 (pushaliasmessagebytaskid) ResultPack<PushResult> pushaliasmessagebytaskid(pushtype pushtype, long appid, long taskid, List<String> alias) ResultPack<PushResult> pushaliasmessagebytaskid(pushtype pushtype, long appid, long taskid, List<String> alias, int retries) 任务消 息推送 任务消 息推送 参数 pushtype PushType 是 null 消息 appid Long 是 null 推送应用 ID taskid Long 是 null 推送任务 ID alias List 是 null 推送目标别名, 一批最多不能超过 1000 个 retries int 否 0 超时 or 异常重试次数 PushResult msgid; 推送消息 ID, 用于推送流程明细排查 resptarget; 推送目标结果状态 (key: 推送响应码 value: 响应码对应的目标用户 ) 注 : 只返回不合法 超速以及推送失败的目标用户, 业务一般对超速的 pushid 对处理 ** * 别名任务消息推送 * * @throws IOException 21/39

*/ public void testpushaliaspytaskid() throws IOException { // 推送对象 IFlymePush push = new IFlymePush(APP_SECRET_KEY); // 目标用户 List<String> alias = new ArrayList<String>(); alias.add("alias123"); alias.add("android654"); // 通知栏任务消息推送 Long taskid = 45361L; // 1 调用推送服务 ResultPack<PushResult> result = push.pushaliasmessagebytaskid(pushtype.statusbar, appid, taskid, alias); if (result.issucceed()) { // 2 调用推送服务成功 ( 其中 map 为设备的具体推送结果, 一般业务针对超速的 code 做处理 ) PushResult pushresult = result.value(); String msgid = pushresult.getmsgid();// 推送消息 ID, 用于推送流程明细排查 Map<Integer, List<String>> targetresultmap = pushresult.getresptarget();// 推送结果, 全部推送成功, 则 map 为 empty System.out.println("push msgid:" + msgid); System.out.println("push targetresultmap:" + targetresultmap); if (targetresultmap!= null &&!targetresultmap.isempty()) { // 3 判断是否有获取超速的 target if (targetresultmap.containskey(pushresponsecode.rsp_speed_limit.getvalue())) { // 4 获取超速的 target List<String> ratelimittarget = targetresultmap.get(pushresponsecode.rsp_speed_limit.getvalue()); System.out.println("rateLimitTarget is :" + ratelimittarget); //TODO 5 业务处理, 重推... else { // 调用推送服务异常 eg: appid appkey 非法 推送消息非法... // result.code(); // 服务异常码 // result.comment();// 服务异常 // 全部超速 if (String.valueOf(ErrorCode.APP_REQUEST_EXCEED_LIMIT.getValue()).equals(result.co de())) { //TODO 5 业务处理, 重推... System.out.println(String.format("pushMessage error code:%s comment:%s", result.code(), result.comment())); 22/39

// 透传消息任务推送 taskid = 45407L; // 1 调用推送服务 result = push.pushaliasmessagebytaskid(pushtype.direct, appid, taskid, alias); if (result.issucceed()) { // 2 调用推送服务成功 ( 其中 map 为设备的具体推送结果, 一般业务针对超速的 code 做处理 ) PushResult pushresult = result.value(); String msgid = pushresult.getmsgid();// 推送消息 ID, 用于推送流程明细排查 Map<Integer, List<String>> targetresultmap = pushresult.getresptarget();// 推送结果, 全部推送成功, 则 map 为 empty System.out.println("push msgid:" + msgid); System.out.println("push targetresultmap:" + targetresultmap); if (targetresultmap!= null &&!targetresultmap.isempty()) { // 3 判断是否有获取超速的 target if (targetresultmap.containskey(pushresponsecode.rsp_speed_limit.getvalue())) { // 4 获取超速的 target List<String> ratelimittarget = targetresultmap.get(pushresponsecode.rsp_speed_limit.getvalue()); System.out.println("rateLimitTarget is :" + ratelimittarget); //TODO 5 业务处理, 重推... else { // 调用推送服务异常 eg: appid appkey 非法 推送消息非法... // result.code(); // 服务异常码 // result.comment();// 服务异常 // 全部超速 if (String.valueOf(ErrorCode.APP_REQUEST_EXCEED_LIMIT.getValue()).equals(result.co de())) { //TODO 5 业务处理, 重推... System.out.println(String.format("pushMessage error code:%s comment:%s", result.code(), result.comment())); 应用全部推送 (pushtoapp) 23/39

ResultPack<Long> pushtoapp(pushtype pushtype, Message message) 应用全部推送 参数 pushtype PushType 是 null 消息 message Message 是 null 消息体 Long 任务 ID /** * 应用全部推送 (pushtoapp) * @throws IOException */ public void testpushtoapp() throws IOException { // 推送对象 IFlymePush push = new IFlymePush(APP_SECRET_KEY); // 通知栏全部消息推送 VarnishedMessage message = new VarnishedMessage.Builder().appId(appId).title("java Sdk 全部推送标题 ").content("java Sdk 全部推送内容 ").noticeexpandtype(1).noticeexpandcontent(" 展开文本内容 ").clicktype(2).url("http://www.baidu.com").parameters(json.parseobject(" {\"k1\":\"value1\",\"k2\":0,\"k3\":\"value3\"")).offline(true).validtime(12).suspend(true).clearnoticebar(true).vibrate(false).lights(false).sound(false).fixspeed(true).fixspeedrate(30).pushtimetype(1).starttime(new Date()).build(); ResultPack<Long> result = push.pushtoapp(pushtype.statusbar, message); System.out.println(result); // 透传全部推送 UnVarnishedMessage message2 = new UnVarnishedMessage.Builder().appId(appId).title("Java SDK 全部推送标题 ").content("java Sdk 全部推送内容 ").isoffline(true) 24/39

.validtime(10).pushtimetype(1).starttime(new Date()).build(); result = push.pushtoapp(pushtype.direct, message2); System.out.println(result); 应用标签推送 (pushtotag) ResultPack<Long> pushtotag(pushtype pushtype, Message message, List<String> tagname, ScopeType scopetype) 应用标 签推送 参数 pushtype PushType 是 null 消息 message Message 是 null 消息体 tagname List 是 null 推送标签 scopetype ScopeType 是 null 标签集合 Long 任务 ID /** * 标签推送 (pushtotag) * * @throws IOException */ public void testpushtotag() throws IOException { // 推送对象 IFlymePush push = new IFlymePush(APP_SECRET_KEY); // 推送标签 List<String> tagname = new ArrayList<String>(); tagname.add("news"); 25/39

tagname.add("tech"); // 通知栏标签推送 VarnishedMessage varnishedmessage = new VarnishedMessage.Builder().appId(appId).title("java Sdk 标签推送标题 ").content("java Sdk 标签推送内容 ").noticeexpandtype(1).noticeexpandcontent(" 展开文本内容 ").offline(true).validtime(12).suspend(true).clearnoticebar(true).vibrate(false).lights(false).sound(false).fixspeed(true).fixspeedrate(30).pushtimetype(1).starttime(new Date()).build(); ResultPack<Long> result = push.pushtotag(pushtype.statusbar, varnishedmessage, tagname, ScopeType.INTERSECTION); System.out.println(result); // 透传标签推送 UnVarnishedMessage unvarnishedmessage = new UnVarnishedMessage.Builder().appId(appId).title("Java SDK 标签推送标题 ").content("java Sdk 标签推送内容 ").isoffline(true).validtime(10).pushtimetype(1).starttime(new Date()).build(); result = push.pushtotag(pushtype.direct, unvarnishedmessage, tagname, ScopeType.UNION); System.out.println(result); 取消推送任务 (canceltaskpush) ResultPack<Boolean> canceltaskpush(pushtype pushtype, long appid, long taskid) 只针对全部用户推送以及标签推送且推送状 态为待推送或者推送中的任务取消 参数 pushtype PushType 是 null 消息 appid Long 是 null 应用 ID 26/39

taskid Long 是 null 任务 ID Boolean true: 成功 false: 失败 /** * 取消推送任务 (canceltaskpush) 只针对全网推送生效 * @throws IOException */ public void testcanceltaskpush() throws IOException { // 推送对象 IFlymePush push = new IFlymePush(APP_SECRET_KEY); long taskid = 123l; ResultPack resultpack = push.canceltaskpush(pushtype.statusbar, appid, taskid); System.out.println(resultPack); 推送统计 获取任务推送统计 (gettaskstatistics) public ResultPack<TaskStatistics> gettaskstatistics(long appid, long taskid) 获取推送统 计 参数 appid Long 是 null 应用 ID taskid Long 是 null 任务 ID TaskStatistics 27/39

/** * 获取任务统计结果 * * @throws IOException */ public void testgettaskstatistics() throws IOException { // 推送对象 IFlymePush push = new IFlymePush(APP_SECRET_KEY); long taskid = 44760L; ResultPack<TaskStatistics> resultpack = push.gettaskstatistics(appid, taskid); System.out.println(resultPack); 获取应用推送统计 (dailypushstatics) public ResultPack<List<DailyPushStatics>> dailypushstatics(long appid, Date starttime, Date endtime) 获取应用推 送统计 参数 appid Long 是 null 应用 ID starttime Date 是 null 开始日期 endtime Date 是 null 结束日期 List<DailyPushStatics> /** * 获取任务统计结果 * * @throws IOException 28/39

*/ public void testdailypushstatics() throws IOException { // 推送对象 IFlymePush push = new IFlymePush(APP_SECRET_KEY); Date starttime = DateUtils.str2Date("2017-06-03", "yyyy-mm-dd"); Date endtime = DateUtils.str2Date("2017-06-10", "yyyy-mm-dd"); ResultPack<List<DailyPushStatics>> resultpack = push.dailypushstatics(appid, starttime, endtime); System.out.println(resultPack); 高级功能 消息送达与回执支持回执 pushid 通知栏消息推送 (pushmessage) 别名通知栏消息推送 (pushmessagebyalias) 开发者通过设置通知栏消息 extra 来指定消息的送达和点击回执规则回执地址请登录推送平台 配置管理 -> 回执管理 注册回执地址 key value 含义 callback 回执 ( 第三方接收回执的 Http, 最大长度 128 字节 ) callback.param 回执参数 ( 第三方自定义回执参数, 最大长度 64 字节 ) callback.type 回执 ((1- 送达回执, 2- 点击回执, 3- 送达与点击回执 ), 3) 魅族推送服务器每隔 1s 将已送达或已点击的消息 ID 和对应设备的 pushid 或 alias 通过调用开发者 http 传给开发者 ( 每次调用后, 魅族推送服务器会清空这些数据, 下次传给业务方将是新一拨数据 ) 注 : 消息的送达回执只支持向 pushid 或 alias 发送的消息 单个应用注册不同回执地址累计上限不能超过 100 个 回执响应内容 key value cb 回执明细内容如下所述 (Json 数据 ) 29/39

access_token 回执访问令牌 ( 推送平台设置回执地址令牌 ) 回执明细格式 : 外层 key 代表相应的消息 id 和回执 (msgid-type), value 是一个 JSONObject, 包含了下面的参数值 param: 业务上传的自定义参数值 type: callback targets: 一批 alias 或者 pushid 集合 { "msgid2-1": { "param": "param2", "type": 1, "targets": [ "pushid3", "pushid2", "pushid1" ], "msgid1-2": { "param": "param1", "type": 2, "targets": [ "alias2", "alias", "alias1" ] 抓包 Hypertext Transfer Protocol POST /callbackurl/callback HTTP/1.1\r\n [Expert Info (Chat/Sequence): POST /callbackurl/callback HTTP/1.1\r\n] Request Method: POST Request URI: /callbackurl/callback Request Version: HTTP/1.1 Content-Length: 32\r\n [Content length: 32] Content-Type: application/x-www-form-urlencoded; charset=utf-8\r\n Host: xxx.xxx.xxx\r\n Connection: Keep-Alive\r\n 30/39

User-Agent: Apache-HttpClient/4.3.4 (java 1.5)\r\n Accept-Encoding: gzip,deflate\r\n \r\n [Full request URI: http://xxx.xxx.xxx/callbackurl/callback] [HTTP request 1/1] [Response in frame: 7253] File Data: 32 bytes HTML Form URL Encoded: application/x-www-form-urlencoded Form item: "access_token" = "token" Key: access_token Value: token Form item: "cb" = "json value" Key: cb Value: json value public void testpushidcallback() throws Exception { // 推送对象 IFlymePush push = new IFlymePush(APP_SECRET_KEY); // 组装消息 VarnishedMessage message = new VarnishedMessage.Builder().appId(appId).title("Java SDK 推送标题 ").content("java SDK 推送内容 ").extra(extraparam.callback.getkey(), callbackurl).extra(extraparam.callback_param.getkey(), "param").extra(extraparam.callback_type.getkey(), CallBackType.RECEIVE.getKey()).build(); // 目标用户 List<String> pushids = new ArrayList<String>(); pushids.add("pushid_1"); pushids.add("pushid_2"); // 1 调用推送服务 ResultPack<PushResult> result = push.pushmessage(message, pushids); handleresult(result); public void testaliascallback() throws Exception { // 推送对象 IFlymePush push = new IFlymePush(APP_SECRET_KEY); // 组装消息 VarnishedMessage message = new VarnishedMessage.Builder().appId(appId).title("Java SDK 推送标题 ").content("java SDK 推送内容 ") 31/39

.extra(extraparam.callback.getkey(), callbackurl).extra(extraparam.callback_param.getkey(), "param").extra(extraparam.callback_type.getkey(), CallBackType.RECEIVE.getKey()).build(); alias); // 目标用户 List<String> alias = new ArrayList<String>(); alias.add("alias_1"); alias.add("alias_2"); // 1 调用推送服务 ResultPack<PushResult> result = push.pushmessagebyalias(message, handleresult(result); 订阅服务 修改通知栏订阅开关状态 (updatestatusbarswitch) ResultPack<SwitchStatusInfo> updatestatusbarswitch(string pushid, Boolean subswitch) 修改通知栏订阅开 关状态 参数 pushid String 是 null 订阅 pushid subswitch Boolean 是 null 开关状态 true: 打开 false: 关闭 SwitchStatusInfo public void updatestatusbarswitch() throws Exception { ResultPack<SwitchStatusInfo> resultpack = sub.updatestatusbarswitch(pushid, true); System.out.println("updateStatusbarSwitch:" + resultpack); 32/39

修改透传订阅开关状态 (updatedirectswitch) ResultPack<SwitchStatusInfo> updatedirectswitch(string pushid, Boolean subswitch) 修改透传订阅开关 状态 参数 pushid String 是 null 订阅 pushid subswitch Boolean 是 null 开关状态 true: 打开 false: 关闭 SwitchStatusInfo public void updatedirectswitch() throws Exception { ResultPack<SwitchStatusInfo> resultpack = sub.updatedirectswitch(pushid, false); System.out.println("updateDirectSwitch:" + resultpack); 同步修改所有开关状态 (updateallswitch) ResultPack<SwitchStatusInfo> updateallswitch(string pushid, Boolean subswitch) 同步修改所有开关 状态 参数 pushid String 是 null 订阅 pushid 33/39

subswitch Boolean 是 null 开关状态 true: 打开 false: 关闭 SwitchStatusInfo public void updateallswitch() throws Exception { ResultPack<SwitchStatusInfo> resultpack = sub.updateallswitch(pushid, true); System.out.println("updateAllSwitch:" + resultpack); 获取订阅开关状态 (updateallswitch) ResultPack<SwitchStatusInfo> getregisterswitch(string pushid) 获取订阅开关状态 参数 pushid String 是 null 订阅 pushid SwitchStatusInfo public void getregisterswitch() throws Exception { ResultPack<SwitchStatusInfo> resultpack = sub.getregisterswitch(pushid); System.out.println("getRegisterSwitch:" + resultpack); 34/39

别名订阅 (subscribealias) ResultPack<AliasInfo> subscribealias(string pushid, String alias) 别名订阅 参数 pushid String 是 null 订阅 pushid alias String 是 null 订阅别名 60 字符限制 AliasInfo public void subscribealias() throws Exception { ResultPack<AliasInfo> resultpack = sub.subscribealias(pushid, "flyme"); System.out.println("subscribeAlias:" + resultpack); 取消别名订阅 (unsubscribealias) ResultPack<AliasInfo> unsubscribealias(string pushid) 取消别名订阅 参数 pushid String 是 null 订阅 pushid AliasInfo 35/39

public void unsubscribealias() throws Exception { ResultPack<AliasInfo> resultpack = sub.unsubscribealias(pushid); System.out.println("unSubscribeAlias:" + resultpack); 获取订阅别名 (getsubalias) ResultPack<AliasInfo> getsubalias(string pushid) 获取订阅别名 参数 pushid String 是 null 订阅 pushid AliasInfo public void getsubalias() throws Exception { ResultPack<AliasInfo> resultpack = sub.getsubalias(pushid); System.out.println("getSubAlias:" + resultpack); 标签订阅 (subscribetags) ResultPack<TagInfo> subscribetags(string pushid, List<String> tags) 标签订阅 参数 36/39

pushid String 是 null 订阅 pushid tags List 是 null 订阅标签 ( 单个标签 20 个字符限制,100 个标签数量限制 ) TagInfo public void subscribetags() throws Exception { List<String> tags = new ArrayList<String>(2); tags.add("tag1"); tags.add("tag2"); ResultPack<TagInfo> resultpack = sub.subscribetags(pushid, tags); System.out.println("subscribeTags:" + resultpack); 取消标签订阅 (unsubscribetags) ResultPack<TagInfo> unsubscribetags(string pushid, List<String> tags) 取消标签订阅 参数 pushid String 是 null 订阅 pushid tags List 是 null 订阅标签 ( 单个标签 20 个字符限制,100 个标签数量限制 ) TagInfo public void unsubscribetags() throws Exception { 37/39

List<String> tags = new ArrayList<String>(2); tags.add("tag1"); tags.add("tag2"); ResultPack<TagInfo> resultpack = sub.unsubscribetags(pushid, tags); System.out.println("unSubscribeTags:" + resultpack); 获取订阅标签 (getsubtags) ResultPack<TagInfo> getsubtags(string pushid) 获取订阅标签 参数 pushid String 是 null 订阅 pushid TagInfo public void getsubtags() throws Exception { ResultPack<TagInfo> resultpack = sub.getsubtags(pushid); System.out.println("getSubTags:" + resultpack); 取消订阅所有标签 (unsuballtags) ResultPack<Boolean> unsuballtags(string pushid) 取消订阅所有标签 参数 pushid String 是 null 订阅 pushid 38/39

Boolean public void unsuballtags() throws Exception { ResultPack<Boolean> resultpack = sub.unsuballtags(pushid); System.out.println("unSubAllTags:" + resultpack); 39/39