perl - 无法使用 perl IO::Socket::SSL 完成与 gateway.push.apple.com 的 SSL 握手

标签 perl sockets ssl apple-push-notifications

我对这类事情很陌生,不确定我做错了什么。

在 Mojolicious 应用程序中,我正在努力连接到 Apple 推送通知 SSL 套接字。我想向应用程序发送推送通知。

调试信息:

DEBUG: .../IO/Socket/SSL.pm:2700: new ctx 138351632
DEBUG: .../IO/Socket/SSL.pm:612: socket not yet connected
DEBUG: .../IO/Socket/SSL.pm:614: socket connected
DEBUG: .../IO/Socket/SSL.pm:636: ssl handshake not started
DEBUG: .../IO/Socket/SSL.pm:669: using SNI with hostname gateway.push.apple.com
DEBUG: .../IO/Socket/SSL.pm:704: request OCSP stapling
DEBUG: .../IO/Socket/SSL.pm:736: call Net::SSLeay::connect
DEBUG: .../IO/Socket/SSL.pm:2601: did not get stapled OCSP response
DEBUG: .../IO/Socket/SSL.pm:2554: ok=0 [1] /O=Entrust.net/OU=www.entrust.net/CPS_2048 incorp. by ref. (limits liab.)/OU=(c) 1999 Entrust.net Limited/CN=Entrust.net Certification     Authority (2048)/C=US/O=Entrust, Inc./OU=www.entrust.net/rpa is incorporated by reference/OU=(c) 2009 Entrust, Inc./CN=Entrust Certification Authority - L1C
DEBUG: .../IO/Socket/SSL.pm:739: done Net::SSLeay::connect -> -1
DEBUG: .../IO/Socket/SSL.pm:742: SSL connect attempt failed
DEBUG: .../IO/Socket/SSL.pm:742: local error: SSL connect attempt failed error:14090086:SSL routines:SSL3_GET_SERVER_CERTIFICATE:certificate verify failed
DEBUG: .../IO/Socket/SSL.pm:745: fatal SSL error: SSL connect attempt failed error:14090086:SSL routines:SSL3_GET_SERVER_CERTIFICATE:certificate verify failed
DEBUG: ...5.18/IO/Socket.pm:48: ignoring less severe local error 'IO::Socket::IP configuration failed', keep 'SSL connect attempt failed error:14090086:SSL     routines:SSL3_GET_SERVER_CERTIFICATE:certificate verify failed'
DEBUG: .../IO/Socket/SSL.pm:2733: free ctx 138351632 open=138351632
DEBUG: .../IO/Socket/SSL.pm:2738: free ctx 138351632 callback
DEBUG: .../IO/Socket/SSL.pm:2745: OK free ctx 138351632

代码片段:

use IO::Socket::SSL qw(debug3);

my $cl = IO::Socket::SSL->new(
  PeerHost => 'gateway.push.apple.com',
  # PeerHost => 'gateway.sandbox.push.apple.com',
  PeerPort => '2195',
  SSL_verify_mode => SSL_VERIFY_PEER,
  SSL_ca_file => '/var/www/foo/bar/cert/ck.pem',
);

我不确定从这里去哪里或做什么?

最佳答案

我想通了:我使用的密码不正确!我能够实现更简单的 perl 模块 Net::APNS

use Net::APNS;

my %settings = (
  cert   => "$Cert_file",
  key    => "$Cert_key_file",
  passwd => "$passphrase",
);

if(my $Notifier = Net::APNS->new->notify(\%settings)) {
  $Notifier->write({
    devicetoken => "$device_token",
    message     => "$message",
    sound       => 'default',
    badge       => 1
  });

  return 1 if defined($Notifier) and ref($Notifier) eq "Net::APNS::Notification";
}

感谢您的参与!

关于perl - 无法使用 perl IO::Socket::SSL 完成与 gateway.push.apple.com 的 SSL 握手,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36397542/

相关文章:

ios - 安装在同一局域网内不同设备上的 iOS 应用程序之间的通信

sockets - Node.js 端口同时监听和读取标准输入

ssl - 为 Jetty 配置 SSL 密码套件

php - 对站点的 cURL 请求返​​回空文档

email - SSL 签名如何以及在何处应用于电子邮件?

Perl,LWP "certificate verify failed"与 paypal.com

arrays - Perl 从数组中输出连续的字符串

xml - 如何提取 XML 并将其转换为 Perl 数据结构

c - 如何判断一个socket被另一个线程shutdown()?

linux - 如何在 Perl 中确定文件