ios学习路线—推送通知

来源:互联网 发布:highcharts zh cn.js 编辑:程序博客网 时间:2024/05/16 14:30

理解Apple推送通知的机制
这里写图片描述
从上面的流程图中,可以看到一个能接收推送通知的App,需要3个东西:
1.App ID(唯一标识一个App程序)
2.Provisioning Profile(App程序的发布需要它,所以推送通知只能在真机上测试)
3.Device Token(设备标识,这个是推送通知功能中特有的)

而能推送通知的服务器端则要2个东西:
1.SSL Certificate
2.Private Key

值得注意的是APNS(ApplePush Notification Service) Server,完成发送Device Token和通知内容的功能,而且这2个动作都是被动的,即第一个动作是由App发起的,第二个则是推送通知的服务器发起的。

创建App ID
这里写图片描述
Description的内容可以任意,Bundle Identifier (App ID Suffix)必须和创建App工程时的Bundle Identifier,如下:
这里写图片描述
点击“Submit”后,点击左侧导航中的“App IDs”,找到刚才新创建的App ID,如下:
这里写图片描述
点击“Configure”后,如下:
这里写图片描述
勾选“Enable for Apple Push Notification service”,然后点击红色的“Configure”按钮,这里暂时只针对Development取得证书。弹出一个对话框,如下:
这里写图片描述
点击“Continue”后,要我们上传一个CSR文件,如下:
这里写图片描述
下面使用钥匙串访问(KeychainAccess)应用程序创建上面需要的CSR文件(.certSigningRequest文件)

创建CSR文件
Keychain Access位于/Applications/Utilities目录中,打开它如下
这里写图片描述
然后弹出窗口如下
这里写图片描述
UserEmail Address随意写就可以,Common Name也是一样,注意勾选“Save to disks”,然后点击“Continue”。很快就生成好了所需文件,去找到它。
这里写图片描述
回到下面的网页中,上传刚才用KeychainAccess产生的HelloRemoteNotification.certSigningRequest文件。
这里写图片描述
很快需要的证书就OK了,如下
这里写图片描述
点击“Continue”,然后点击“Done”。
这里写图片描述
发现上面的Status是Enabled,而且多了“Download”按钮,点击它,下载了一个名为“aps_development.cer”的文件。双击打开它
这里写图片描述
找到上图中“Keys”栏中名为“HelloRemoteNotification”的private key(注意是private key,而不是public key),右击它,选择“Export “HelloRemoteNotification”…”,这样会导出一个.p12文件(需要输入密码),如下(目前共有3个文件)
这里写图片描述

创建ProvisioningProfile文件
这里写图片描述
在上图中,点击“New Profile”按钮后,如下
这里写图片描述
填写“Profile Name”;勾选“Certificate”;“App ID”选择正确的、之前我们创建的ID,即PushNotification;最后关联需要测试真机设备。点击“Submit”,如下
这里写图片描述
可以看到多了一个Provisioning Profile文件,点击“Download”按钮下载它,这时我们一共产生4个文件,如下
这里写图片描述
双击“PushNotification.mobileprovision”文件,或把它拖入到Xcode中
这里写图片描述
在Xcode中,找到Code Signing项,如上图,将Debug一项配置成刚才拖入Provisioning Profile对应的iPhone Developer。

Xcode工程中取得Device Token
这里写图片描述
在application:didFinishLaunchingWithOptions:方法里,注册使用远程通知
这里写图片描述
添加2个方法,application: didRegisterForRemoteNotificationsWithDeviceToken:和application:didFailToRegisterForRemoteNotificationsWithError:,用于取得Device Token和打印错误。运行我们建的HelloRemoteNotification工程,如果以上步骤都正确,应该打印出Device Token,如下
这里写图片描述

创建.pem文件
1.将已有的.cer文件转成.pem文件
2.将已有的.p12文件转成.pem文件(需要输入密码)
3.最后将上面2个.pem文件合并成1个.pem文件(需要输入新密码)
这里写图片描述
aps_development.cer->HelloRemoteNotification.pem(下面改名为HelloRemoteNotificationCert.pem)
HelloRemoteNotification.p12-> HelloRemoteNotificationKey.pem
这里写图片描述
HelloRemoteNotification.pem +HelloRemoteNotificationKey.pem合并成ck2.pem

0 0
原创粉丝点击