博客
关于我
极光推送Springboot微服务搭建教程
阅读量:667 次
发布时间:2019-03-15

本文共 4253 字,大约阅读时间需要 14 分钟。

极光推送服务配置与使用指南

前言

本文将详细介绍如何在Spring Boot项目中集成极光(JPush)推送服务,并提供三种推送方式的实现方案。

服务端配置文件

在项目中添加极光推送的相关配置,安装完成后即可正常使用。

application.properties 配置

application.properties文件中添加以下配置项:

jpush.appKey=12340856031dc012a7d456jpush.masterSecret=123493e8a9be718f023023jpush.liveTime=300000

##Spring Boot配置

添加依赖

在项目的POM文件中添加JPush客户端依赖:

cn.jpush.api
jpush-client
3.3.4

配置文件处理

通过Spring注入配置信息,基本无需修改即可使用。配置示例如下:

import org.springframework.beans.factory.annotation.Value;import org.springframework.stereotype.Component;@Component("jpushConfig")public class JpushConfig {    @Value("${jpush.appKey}")    private String appkey;    @Value("${jpush.masterSecret}")    private String masterSecret;    @Value("${jpush.liveTime}")    private String liveTime;    public String getAppkey() { return appkey; }    public String getMasterSecret() { return masterSecret; }}

推送服务类封装

宽布包推送

提供多种推送方式的封装实现,确保推送过程高效且可靠。

推送方式

服务端控制推送内容方式

public PushResult sendPush(String title, String content, Map
extrasMap, String... alias) { ClientConfig clientConfig = ClientConfig.getInstance(); clientConfig.setTimeToLive(Long.valueOf(jpushConfig.getLiveTime())); JPushClient jpushClient = new JPushClient(jpushConfig.getMasterSecret(), jpushConfig.getAppkey(), null, clientConfig); PushPayload payload = buildPushPayload(title, content, extrasMap, alias); try { return jpushClient.sendPush(payload); } catch (APIConnectionException e) { LOG.error("极光推送连接错误,请稍后重试", e); } catch (APIRequestException e) { LOG.error("极光服务器响应出错,请修复!", e); LOG.info("HTTP Status: %d", e.getStatus()); LOG.info("Error Code: %d", e.getErrorCode()); LOG.info("Error Message: %s", e.getErrorMessage()); }}

服务端控制推送方式(带返回值)

public PushResult sendPushWithCallback(String title, String content, Map
extrasMap, String... alias) { ClientConfig clientConfig = ClientConfig.getInstance(); clientConfig.setTimeToLive(Long.valueOf(jpushConfig.getLiveTime())); String host = (String) clientConfig.get(ClientConfig.PUSH_HOST_NAME); NettyHttpClient client = new NettyHttpClient(ServiceHelper.getBasicAuthorization(jpushConfig.getAppkey(), jpushConfig.getMasterSecret()), null, clientConfig); try { URI uri = new URI(host + clientConfig.get(ClientConfig.PUSH_PATH)); PushPayload payload = buildPushPayload(title, content, extrasMap, alias); client.sendRequest(HttpMethod.POST, payload.toString(), uri, new NettyHttpClient.BaseCallback() { @Override public void onSucceed(ResponseWrapper responseWrapper) { if (200 == responseWrapper.responseCode) { LOG.info("极光推送成功"); } else { LOG.info("极光推送失败,返回结果: %s", responseWrapper.responseContent); } } }); } catch (URISyntaxException e) { e.printStackTrace(); } finally { client.close(); }}

客户端自定义显示推送方式

public PushResult sendCustomPush(String title, String content, Map
extrasMap, String... alias) { ClientConfig clientConfig = ClientConfig.getInstance(); clientConfig.setTimeToLive(Long.valueOf(jpushConfig.getLiveTime())); JPushClient jpushClient = new JPushClient(jpushConfig.getMasterSecret(), jpushConfig.getAppkey(), null, clientConfig); PushPayload payload = buildCustomPushPayload(title, content, extrasMap, alias); try { return jpushClient.sendPush(payload); } catch (APIConnectionException e) { LOG.error("极光推送连接错误,请稍后重试", e); } catch (APIRequestException e) { LOG.error("极光服务器响应出错,请修复!", e); LOG.info("HTTP Status: %d", e.getStatus()); LOG.info("Error Code: %d", e.getErrorCode()); LOG.info("Error Message: %s", e.getErrorMessage()); }}

使用方法

一键启动

通过简单配置即可快速集成极光推送服务。

推送示例

@AutowiredJpushService jpushService;String title = "推送标题";String content = "推送内容";Map
extrasMap = new HashMap<>();extrasMap.put("extraKey", "extraValue");// 使用方式一:默认推送jpushService.sendPush(title, content, extrasMap);// 使用方式二:带返回值jpushService.sendPushWithCallback(title, content, extrasMap);

应用场景

  • 系统消息推送
  • 行程通知
  • этим等其他需要及时通知的场景

注意事项

  • 确保极光官网申请的密钥有效
  • 推送内容保持在22字以内以便展示
  • 调用前确保依赖库已加入项目
  • 高并发场景时需考量推送背压

如有疑问,请到极光官网或社区求助。

转载地址:http://xmfqz.baihongyu.com/

你可能感兴趣的文章
Mysql 提示:Communication link failure
查看>>
mysql 插入是否成功_PDO mysql:如何知道插入是否成功
查看>>
Mysql 数据库InnoDB存储引擎中主要组件的刷新清理条件:脏页、RedoLog重做日志、Insert Buffer或ChangeBuffer、Undo Log
查看>>
mysql 数据库中 count(*),count(1),count(列名)区别和效率问题
查看>>
mysql 数据库备份及ibdata1的瘦身
查看>>
MySQL 数据库备份种类以及常用备份工具汇总
查看>>
mysql 数据库存储引擎怎么选择?快来看看性能测试吧
查看>>
MySQL 数据库操作指南:学习如何使用 Python 进行增删改查操作
查看>>
MySQL 数据库的高可用性分析
查看>>
MySQL 数据库设计总结
查看>>
Mysql 数据库重置ID排序
查看>>
Mysql 数据类型一日期
查看>>
MySQL 数据类型和属性
查看>>
mysql 敲错命令 想取消怎么办?
查看>>
Mysql 整形列的字节与存储范围
查看>>
mysql 断电数据损坏,无法启动
查看>>
MySQL 日期时间类型的选择
查看>>
Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
查看>>
MySQL 是如何加锁的?
查看>>
MySQL 是怎样运行的 - InnoDB数据页结构
查看>>