APNs苹果推送使用的是pushy框架+.p8证书(java后台)(附上与.p12的不同)

本文档详细介绍了如何在Java后台使用Pushy框架,结合.p8证书实现APNs苹果推送。区别于常见的.p12证书,文中提供了.p8证书的配置步骤,并强调了设备Token的正确获取与使用,以及生产环境与沙盒环境的区别。同时,参照Pushy最佳实践,给出了多线程调用客户端的示例。
摘要由CSDN通过智能技术生成

因为被这个困扰了好久,所以记录一下…
网上大部分都是关于.p12的代码,没有看到有.p8的。
先上github:https://github.com/relayrides/pushy(如果有不懂,可以再来这里看)

在Java端使用Pushy进行APNs消息推送

1 首先先加入这两个包

<!-- ios推送  pushy框架-->
        <dependency>
            <groupId>com.turo</groupId>
            <artifactId>pushy</artifactId>
            <version>0.13.7</version>
        </dependency>

        <dependency>
            <groupId>io.netty</groupId>
            <artifactId>netty-tcnative-boringssl-static</artifactId>
            <version>2.0.20.Final</version>
            <scope>runtime</scope>
        </dependency>

2 身份认证
苹果APNs提供了两种认证的方式:基于JWT的身份信息token认证和基于证书的身份认证。Pushy也同样支持这两种认证方式。(待会会有区别)
如何获取苹果APNs身份认证证书可以查考官方文档。

3 Pushy使用
这是.p8的:

package com.imagedt.message.util;
import java.io.File;

import com.turo.pushy.apns.auth.ApnsSigningKey;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.turo.pushy.apns.ApnsClient;
import com.turo.pushy.apns.ApnsClientBuilder;

import io.netty.channel.EventLoopGroup;
import io.netty.channel.nio.NioEventLoopGroup;

public class APNSConnect {

    private static final Logger logger = LoggerFactory.getLogger(APNSConnect.class);

    private static ApnsClient apnsClient = null;

    public static ApnsClient getAPNSConnect() {

        if (apnsClient == null) {
            try {
                EventLoopGroup eventLoopGroup = new NioEventLoopGroup(4);
                apnsClient = new ApnsClientBuilder().setApnsServer(ApnsClientBuilder.DEVELOPMENT_APNS_HOST)
                        .setSigningKey(ApnsSigningKey.loadFromPkcs8File(new File("path/你的放置.p8证书的路径"),
                                "你的teamid", "你的keyid"))
                        .setConcurrentConnections(4).setEventLoopGroup(eventLoopGroup).build();
            } catch (Exception e) {
                logger.error("ios get pushy apns client failed!");
                e.printStackTrace();
            }
        }
        return apnsClient;

    }

}

还有个较好的,把文件放到resource下(建议)
路径可以写到application中。获取就是了

if (apnsClient == null) {
            try {
                EventLoopGroup eventLoopGroup = new NioEventLoopGroup(4);
//                apnsClient = new ApnsClientBuilder().setApnsServer(ApnsClientBuilder.DEVELOPMENT_APNS_HOST)
//                        .setSigningKey(ApnsSigningKey.loadFromPkcs8File(new File(jpushConfig.getPath()),//"C:/Users/user/Desktop/AuthKey_XNQ237XNW7
  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
苹果推送通知服务(APNS使用SSL/TLS协议进行加密通信,因此在使用APNS时需要准备证书文件。以下是一些制作苹果生产环境证书文件的步骤: 1. 登录到苹果开发者帐户并创建一个APNS证书。如果您还没有苹果开发者帐户,请先注册一个。 2. 打开“钥匙串访问”应用程序并选择“证书助理”>“从证书颁发机构请求证书”。 3. 在证书请求信息中,填写证书名称和电子邮件地址,并选择“保存到磁盘”。 4. 在苹果开发者中心上传证书请求文件(CSR)并下载证书文件(CER)。 5. 双击下载的证书文件并将其添加到“钥匙串访问”中。 6. 导出证书文件(CER)和密钥文件(.p12)。 7. 将密钥文件(.p12)转换为Java可用的格式,例如PKCS12格式。 现在您已经准备好使用Java发送APNS通知了。在代码中,您需要指定证书文件的路径和密码。例如: ```java String certificatePath = "/path/to/Certificate.p12"; String certificatePassword = "password"; ApnsService service = APNS.newService() .withCert(certificatePath, certificatePassword) .withProductionDestination() .build(); ``` 注意,在生产环境中,您需要使用APNS的生产服务器地址。在代码中,您需要指定生产服务器的地址和端口号。例如: ```java ApnsService service = APNS.newService() .withCert(certificatePath, certificatePassword) .withProductionDestination() .build(); ``` 希望这些步骤和示例代码能帮助您制作苹果生产环境证书文件并使用Java发送APNS通知。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值