我正在使用 mac 开发移动应用程序,但它连接到我在 linux 上运行的测试服务器,我想使用开发人员证书在此服务器上启用 APN,问题是,是否可以安装它我的测试服务器上的证书还是我必须在我的 linux 机器上设置测试服务器?
为了更清楚一点:
我的开发机器:Mac。测试服务器:一台运行 liferay 6.0.6 的 linux 机器
我想在测试服务器上安装开发证书,以便测试推送通知。
非常感谢!
我正在使用 mac 开发移动应用程序,但它连接到我在 linux 上运行的测试服务器,我想使用开发人员证书在此服务器上启用 APN,问题是,是否可以安装它我的测试服务器上的证书还是我必须在我的 linux 机器上设置测试服务器?
为了更清楚一点:
我的开发机器:Mac。测试服务器:一台运行 liferay 6.0.6 的 linux 机器
我想在测试服务器上安装开发证书,以便测试推送通知。
非常感谢!
我对“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
我想回答我自己的问题,因为它可能对某人有所帮助,首先,我在需要生成的证书和如何获取设备令牌之间存在严重的混淆。
这些是我完成这项工作的步骤:
这是一个示例片段,显示了证书适合的位置:
ApnsService service =
APNS.newService()
.withCert("/path/to/certificate.p12", "MyCertPassword")
.withSandboxDestination()
.build();
该方法的第二个参数是钥匙串访问让您设置的 p12 文件的密码。
最后,为了粘合,我使用[UIApplication sharedApplication]
实例注册接收推送通知,并通过在 AppDelegate 上实现一个方法,我得到了我需要的 NSData 格式的令牌,所以你需要转换成一个十六进制字符串(有示例代码在这个网站上的许多网站和问题中)。
就是这样,这就是过程。
希望这可以帮助!!