apns libcurl

6. BadDeviceToken错误

ios中,证书——apns服务器——app,同时有开发版和产品版两类

证书与apns服务器类型不匹配,则返回BadCertificateEnvironment错误

apns服务器与app类型不匹配,则返回BadDeviceToken错误

简单来说,当证书是产品版,推送的目的地为apns产品服务器(api.push.apple.com),但手机token对应的app却为开发版时,推送失败且返回BadDeviceToken错误。



5. BadCertificateEnvironment错误

The client certificate was for the wrong environment.

apns有两类服务器:

开发服务器

Development server: api.development.push.apple.com:443

产品服务器

Production server: api.push.apple.com:443

如果拿产品证书连接开发服务器,apns即返回BadCertificateEnvironment错误



4. curl

要求curl版本在7.46之上

4.1 查看



4.2 升级

① 编译安装

a. 官网下载最新版curl-7.50.3.tar.gz

b. 放到/usr/local/src,并解压,进入目录

c. ./configure --with-nghttp2=/usr/local --with-ssl=/usr/local/ssl,配置成功显示

d. make      e. make install

② 清空hash

hash -r

③ 查看


④ 验证

curl --http2 -I nghttp2.org




3. autoconf

编译nghhtp2要求autoconf版本在2.64之上

查看


升级

官网下载最新版,wget ftp://ftp.gnu.org/gnu/autoconf/autoconf-2.69.tar.gz

放到/usr/local/src,并解压,进入目录

./configure --prefix=/usr/

make 

make install



2. nghttp2

为使用http2,要求安装nghttp2(HTTP/2 C Library)

编译安装

a. 官网下载最新nghttp2-1.15.0.tar.bz2

b. 放到/usr/local/src,并解压,进入目录

c. autoreconf -i        d. automake        e. autoconf

f. ./configure           g. make              h. make install



1. openssl

要求openssl版本在1.0.2之上

1.1 查看



1.2 升级

① 编译安装新版本

a. 官网下载最新openssl-1.0.2j.tar.gz

b. 放到/usr/local/src,并解压,进入目录

c. ./config shared zlib

d. make        e. make install

② 保存老版本

mv /usr/bin/openssl /usr/bin/openssl.old

mv /usr/include/openssl /usr/include/openssl.old

③ 启用新版本

刚刚安装的OpenSSL默认安装在/usr/local/ssl

ln -s /usr/local/ssl/bin/openssl /usr/bin/openssl

ln -s /usr/local/ssl/include/openssl /usr/include/openssl

更新动态链接库数据

echo "/usr/local/ssl/lib" >> /etc/ld.so.conf

ldconfid

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用[1],TNetHttpClient是Delphi中的一个HTTP客户端组件,而APNS是Apple Push Notification Service的缩写,是苹果公司提供的推送服务。因此,TNetHttpClient APNS是使用Delphi中的TNetHttpClient组件来与APNS进行通信。 使用TNetHttpClient APNS的步骤如下: 1.创建TNetHttpClient对象,并设置请求的URL和请求方法为POST。 2.设置请求头部信息,包括Content-Type、Authorization和apns-topic等信息。 3.设置请求体信息,包括设备的token、推送的payload等信息。 4.发送请求并获取响应结果。 以下是一个使用TNetHttpClient APNS发送推送通知的示例代码: ```delphi uses System.Net.HttpClient, System.Net.HttpClientComponent; procedure SendAPNSNotification; var HttpClient: TNetHttpClient; Request: TNetHTTPRequest; Response: IHTTPResponse; APNSUrl: string; APNSPayload: string; APNSToken: string; APNSAuth: string; APNSTopic: string; begin HttpClient := TNetHttpClient.Create(nil); Request := TNetHTTPRequest.Create(nil); try APNSUrl := 'https://api.push.apple.com/3/device/'; APNSPayload := '{"aps":{"alert":"Hello World!"}}'; APNSToken := 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'; APNSAuth := 'Bearer xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'; APNSTopic := 'com.example.app'; Request.MethodString := 'POST'; Request.URL := APNSUrl + APNSToken; Request.ContentType := 'application/json'; Request.CustomHeaders['Authorization'] := APNSAuth; Request.CustomHeaders['apns-topic'] := APNSTopic; Request.Source := TStringStream.Create(APNSPayload, TEncoding.UTF8); Response := HttpClient.Execute(Request); if Response.StatusCode = 200 then ShowMessage('Push notification sent successfully.') else ShowMessage('Failed to send push notification.'); finally Request.Free; HttpClient.Free; end; end; ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值