IOS消息推送。

2024-09-03 06:18
文章标签 推送 ios 消息

本文主要是介绍IOS消息推送。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ios消息推送


本来ios开发工程师说要使用个推,但是我们是做金融的,可能需要给用户推送订单状态等等。这样的话用起来就会很不方便,于是在网上找了找资料自己动手写了一个。就是简易基础的,希望大家看了能够有用。

原理就是将消息发给苹果服务器,然后服务器根据设备的序列号将消息推送给每个iphone手机,这也就是有些app判断是否是同一个设备登陆的。


需要引入几个jar包:
import com.notnoop.apns.APNS;
import com.notnoop.apns.ApnsService;
import com.notnoop.apns.ApnsServiceBuilder;
import com.notnoop.apns.PayloadBuilder;
import com.notnoop.exceptions.NetworkIOException;

jar包之前在github上下载的,过段时间再补上。

需要ios给你生成一份p12的文件然后你放到本地的文件夹中,地址需要传给推送的类。

我写了一个push.properties文件,方便以后进行拓展,

iosCertPath=D:/apache7/apnscert.p12
iosCertPassword=123456
badgeNum=1
pushSoundName=default


推送的消息实体类:

public abstract class Message {//推送消息的properties文件名字public static final String PUSH_MESSAGE_PROPERTIES_NAME = "messagepusher.properties";//    推送的证书文件地址protected static String iosCertPath = "";//    推送的证书密码protected static String iosCertPassword = "";//    推送消息的提示数字  app上面的红色小圆点protected static int badgeNum;//    推送消息的音乐名字protected static String pushSoundName = "";/*** app推送消息*/public abstract void pushMessage(MessagePusherVO messagePusherVO);

推送消息的实体类:

public class IosPushMessage extends Message {protected final Log logger = LogFactory.getLog(getClass());static {//    推送的证书文件地址iosCertPath = PropertiesUtil.loadProperties(PUSH_MESSAGE_PROPERTIES_NAME).getProperty("iosCertPath");//    推送的证书密码iosCertPassword = PropertiesUtil.loadProperties(PUSH_MESSAGE_PROPERTIES_NAME).getProperty("iosCertPassword");//    推送消息的提示数字  app上面的红色小圆点badgeNum = Integer.parseInt(PropertiesUtil.loadProperties(PUSH_MESSAGE_PROPERTIES_NAME).getProperty("badgeNum"));//    推送消息的音乐名字pushSoundName = PropertiesUtil.loadProperties(PUSH_MESSAGE_PROPERTIES_NAME).getProperty("pushSoundName");//    添加推送类型的id 例如推送新闻 根据新闻id跳转到哪个新闻}@Overridepublic void pushMessage(MessagePusherVO messagePusherVO) {/**APNS推送需要的证书、密码、和设备的Token**/// 创建和苹果APNS服务器的连接connection对象ApnsServiceBuilder serviceBuilder = APNS.newService();// 通过类加载器加载ios证书serviceBuilder.withCert(iosCertPath, iosCertPassword);// 设定为推送正式产品环境
//        serviceBuilder.withProductionDestination();/*沙河测试************************************/serviceBuilder.withSandboxDestination();/*沙河测试************************************/// 从builder到service对象ApnsService service = serviceBuilder.build();PayloadBuilder payloadBuilder = APNS.newPayload();payloadBuilder.badge(badgeNum);payloadBuilder.sound(pushSoundName);
//       要推送的消息类型payloadBuilder.customField("type", "需要推送的消息类型");//  ****添加推送类型的id 例如推送新闻 根据新闻id跳转到哪个新闻//  ****payloadBuilder.customField("typeId", "推送的消息id");try {String payload = payloadBuilder.alertBody("消息内容").build();
//          推送消息service.push("推送的设备号", payload);System.out.println("推送信息已发送" +"推送的设备号");} catch (NetworkIOException e) {logger.error("推送消息到苹果APNS服务器遇到网络异常", e);System.err.println("推送消息到苹果APNS服务器遇到网络异常");} catch (Exception ex) {logger.error("推送消息到苹果APNS服务器错误", ex);System.err.println("推送消息到苹果APNS服务器错误");} finally {}service.stop();}

其中IOS和Objective-c的交互
参考博文:

这篇关于IOS消息推送。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1132263

相关文章

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

解读Redis秒杀优化方案(阻塞队列+基于Stream流的消息队列)

《解读Redis秒杀优化方案(阻塞队列+基于Stream流的消息队列)》该文章介绍了使用Redis的阻塞队列和Stream流的消息队列来优化秒杀系统的方案,通过将秒杀流程拆分为两条流水线,使用Redi... 目录Redis秒杀优化方案(阻塞队列+Stream流的消息队列)什么是消息队列?消费者组的工作方式每

使用C/C++调用libcurl调试消息的方式

《使用C/C++调用libcurl调试消息的方式》在使用C/C++调用libcurl进行HTTP请求时,有时我们需要查看请求的/应答消息的内容(包括请求头和请求体)以方便调试,libcurl提供了多种... 目录1. libcurl 调试工具简介2. 输出请求消息使用 CURLOPT_VERBOSE使用 C

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

SpringBoot 自定义消息转换器使用详解

《SpringBoot自定义消息转换器使用详解》本文详细介绍了SpringBoot消息转换器的知识,并通过案例操作演示了如何进行自定义消息转换器的定制开发和使用,感兴趣的朋友一起看看吧... 目录一、前言二、SpringBoot 内容协商介绍2.1 什么是内容协商2.2 内容协商机制深入理解2.2.1 内容

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

【iOS】MVC模式

MVC模式 MVC模式MVC模式demo MVC模式 MVC模式全称为model(模型)view(视图)controller(控制器),他分为三个不同的层分别负责不同的职责。 View:该层用于存放视图,该层中我们可以对页面及控件进行布局。Model:模型一般都拥有很好的可复用性,在该层中,我们可以统一管理一些数据。Controlller:该层充当一个CPU的功能,即该应用程序

ActiveMQ—消息特性(延迟和定时消息投递)

ActiveMQ消息特性:延迟和定时消息投递(Delay and Schedule Message Delivery) 转自:http://blog.csdn.net/kimmking/article/details/8443872 有时候我们不希望消息马上被broker投递出去,而是想要消息60秒以后发给消费者,或者我们想让消息没隔一定时间投递一次,一共投递指定的次数。。。 类似

Java消息队列:RabbitMQ与Kafka的集成与应用

Java消息队列:RabbitMQ与Kafka的集成与应用 大家好,我是微赚淘客返利系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿! 在现代的分布式系统中,消息队列是实现系统间通信、解耦和提高可扩展性的重要组件。RabbitMQ和Kafka是两个广泛使用的消息队列系统,它们各有特点和优势。本文将介绍如何在Java应用中集成RabbitMQ和Kafka,并展示它们的应用场景。 消息队

Kafka 分布式消息系统详细介绍

Kafka 分布式消息系统 一、Kafka 概述1.1 Kafka 定义1.2 Kafka 设计目标1.3 Kafka 特点 二、Kafka 架构设计2.1 基本架构2.2 Topic 和 Partition2.3 消费者和消费者组2.4 Replica 副本 三、Kafka 分布式集群搭建3.1 下载解压3.1.1 上传解压 3.2 修改 Kafka 配置文件3.2.1 修改zookeep