博客
关于我
极光推送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 Binlog 日志监听与 Spring 集成实战
查看>>
MySQL binlog三种模式
查看>>
multi-angle cosine and sines
查看>>
Mysql Can't connect to MySQL server
查看>>
mysql case when 乱码_Mysql CASE WHEN 用法
查看>>
Multicast1
查看>>
mysql client library_MySQL数据库之zabbix3.x安装出现“configure: error: Not found mysqlclient library”的解决办法...
查看>>
MySQL Cluster 7.0.36 发布
查看>>
Multimodal Unsupervised Image-to-Image Translation多通道无监督图像翻译
查看>>
MySQL Cluster与MGR集群实战
查看>>
multipart/form-data与application/octet-stream的区别、application/x-www-form-urlencoded
查看>>
mysql cmake 报错,MySQL云服务器应用及cmake报错解决办法
查看>>
Multiple websites on single instance of IIS
查看>>
mysql CONCAT()函数拼接有NULL
查看>>
multiprocessing.Manager 嵌套共享对象不适用于队列
查看>>
multiprocessing.pool.map 和带有两个参数的函数
查看>>
MYSQL CONCAT函数
查看>>
multiprocessing.Pool:map_async 和 imap 有什么区别?
查看>>
MySQL Connector/Net 句柄泄露
查看>>
multiprocessor(中)
查看>>