0

我正在使用 mac 开发移动应用程序,但它连接到我在 linux 上运行的测试服务器,我想使用开发人员证书在此服务器上启用 APN,问题是,是否可以安装它我的测试服务器上的证书还是我必须在我的 linux 机器上设置测试服务器?

为了更清楚一点:

我的开发机器:Mac。测试服务器:一台运行 liferay 6.0.6 的 linux 机器

我想在测试服务器上安装开发证书,以便测试推送通知。

非常感谢!

4

2 回答 2

0

我对“liferay”一无所知,但这就是我使用证书设置 APN 连接(在 Rails 服务器上)的方式。请注意,您需要将证书转换为 .pem 文件(使用 'openssl pkcs12 -in myfile.p12 -out myfile.pem'):

  @@apn_cert       = nil
  APN_SSL_KEY_FILE = 'lib/SSLCert_Private_Key.pem'
  APN_SSL_HOST     = 'gateway.sandbox.push.apple.com'
  #  APN_SSL_HOST     = 'gateway.push.apple.com'
  APN_SSL_PORT     = 2195
  APN_SSL_PASSWORD = '<password>'

  def configure_apn_cert
    puts "APN Service: Configuring APN cert"
    @@apn_cert         = File.read(File.join(RAILS_ROOT, APN_SSL_KEY_FILE))
    @@apn_context      = OpenSSL::SSL::SSLContext.new
    @@apn_context.key  = OpenSSL::PKey::RSA.new(@@apn_cert, APN_SSL_PASSWORD)
    @@apn_context.cert = OpenSSL::X509::Certificate.new(@@apn_cert)
  end

  def create_and_configure_apn_server
    configure_apn_cert if not @@apn_cert
    puts "APN Service: Configuring APN SOCKET and SSL connection"
    @apn_socket       = TCPSocket.new(APN_SSL_HOST, APN_SSL_PORT)
    @apn_ssl          = OpenSSL::SSL::SSLSocket.new(@apn_socket, @@apn_context)
    @apn_ssl.sync     = true
    @apn_ssl.connect
  end

  def close_apn_server
    @apn_ssl.close
    @apn_socket.close
  end

  def package_build_for_apn( token, content )
    "\0\0 #{token}\0#{content.length.chr}#{content}"
  end

  def package_send_to_apn( package )
    puts "APN Service: Sending #{package}"
    bytes_written = @apn_ssl.write( package )

    if bytes_written != package.length then
      puts "APN Service: SSL write failed"
      package_to_apn_show_write( bytes_written, package)
    end
  end

  def apn_deliver_payload( token, payload )
    # Convert the device string back into a byte string
    tokenBinary = Base64.decode64( token )

    # Transform the payload into an APN byte string
    apn_content      = payload.to_hash.to_json
    apn_content_len  = apn_content.length

    # Build the apn_package per APN specification
    apn_package = "\0\0 #{tokenBinary}\0#{apn_content_len.chr}#{apn_content}"

    # Actually send it.
    package_send_to_apn( apn_package )
  end

  def package_to_apn_show_write( bytes, package)
    puts "Wrote: #{bytes_written}/ Tried: #{package.length}"
    puts "Package: '#{package}'"
  end

  def package_to_apn_debug( token, content, package )
    puts "Token(#{token.length}): #{token}"
    puts "Content(#{content.length}): #{content}"
    puts "Package(#{package.length}): #{package}"
  end
于 2012-04-27T14:53:22.837 回答
0

我想回答我自己的问题,因为它可能对某人有所帮助,首先,我在需要生成的证书和如何获取设备令牌之间存在严重的混淆。

这些是我完成这项工作的步骤:

  • 创建了一个应用程序 ID。
  • 使用“钥匙串访问”创建了一个证书签名请求,并获得了我再次使用钥匙串访问安装​​的推送通知的开发证书。
  • 将证书导出为 .p12 文件。
  • 使用 notnoop java 库(位于中央 maven 存储库)发送推送通知。

这是一个示例片段,显示了证书适合的位置:

ApnsService service =
    APNS.newService()
    .withCert("/path/to/certificate.p12", "MyCertPassword")
    .withSandboxDestination()
    .build(); 

该方法的第二个参数是钥匙串访问让您设置的 p12 文件的密码。

最后,为了粘合,我使用[UIApplication sharedApplication]实例注册接收推送通知,并通过在 AppDelegate 上实现一个方法,我得到了我需要的 NSData 格式的令牌,所以你需要转换成一个十六进制字符串(有示例代码在这个网站上的许多网站和问题中)。

就是这样,这就是过程。

希望这可以帮助!!

于 2012-05-07T03:02:38.417 回答