文档详情

iOS实现从后台向手机客户端推送消息的代码.doc

发布:2017-01-31约8.28千字共11页下载文档
文本预览下载声明
iOS实现从后台向手机客户端推送消息的代码 iOS客户端消息推送其实是一个有点复杂的方法,这里介绍了一个PHP做服务端,向iOS客户端推送消息的步骤和代码。 1. deviceToken 是从ios 中得到 - (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)pToken { NSLog(@regisger success:%@, pToken); //注册成功,将deviceToken保存到应用服务器数据库中 } 2. 步骤 1. 登录 iPhone Developer Connection Portal(/iphone/manage/overview/index.action ) 然后点击 App IDs 2. 创建一个 Apple ID 。通配符 ID 不能用于推送通知服务。如, com.itotem.iphone 3. 点击Apple ID旁的“Configure”,根据“向导” 的步骤生成一个签名上传,然后下载生成的许可证。 4. 双击.cer文件将你的 aps_developer_identity.cer 导入Keychain中。 5. 在Mac上启动 Keychain助手,然后在login keychain中选择 Certificates分类。看到一个可扩展选项“Apple Development Push Services” 6. 扩展此选项然后右击“Apple Development Push Services” Export “Apple Development Push Services ID123”。保存为 apns-dev-cert.p12 文件。(这里要注意的是在Certificates分类中) 7. 扩展“Apple Development Push Services” 对“Private Key”做同样操作,保存为 apns-dev-key.p12 文件。 8. 通过终端命令将这些文件转换为PEM格式:openssl pkcs12 -clcerts -nokeys -out apns-dev-cert.pem -in apns-dev-cert.p12 openssl pkcs12 -nocerts -out apns-dev-key.pem -in apns-dev-key.p12 9. 最后,你需要将键和许可文件合成为apns-dev.pem文件,此文件在连接到APNS时需要使用: cat apns-dev-cert.pem apns-dev-key-noenc.pem apns-dev.pem 3. php调用 ?php $deviceToken= 2bf6e8f97942b07e3dd790d70f52x18a4d50338b5bb00f6f14d8bb6f775a6d98; //没有空格 $body = array(aps = array(alert = message,badge = 2,sound=default)); //推送方式,包含内容和声音 $ctx = stream_context_create(); //如果在Windows的服务器上,寻找pem路径会有问题,路径修改成这样的方法: //$pem = dirname(__FILE__) . / . apns-dev.pem; //linux 的服务器直接写pem的路径即可 stream_context_set_option($ctx,ssl,local_cert,apns-dev.pem); $pass = xxxxxx; stream_context_set_option($ctx, ssl, passphrase, $pass); //此处有两个服务器需要选择,如果是开发测试用,选择第二名sandbox的服务器并使用Dev的pem证书,如果是正是发布,使用Product的pem并选用正式的服务器 $fp = stream_socket_client(ssl://:2195, $err, $errstr, 60, STREAM_CLIENT_CONNECT, $ctx); $fp = stream_socket_client(ssl://:2195, $err, $errstr, 60, STREAM_CLIENT_CONNECT, $ctx); if (!$fp) { echo Failed to connect $err $errstrn; retu
显示全部
相似文档