转自:http://blog.csdn.net/shenjie12345678/article/details/41120637php
第一部分ios
首先第一步固然是介绍一下苹果的推送机制(APNS)咯(ps:其实每一篇教程都有),先来看一张苹果官方对其推送作出解释的概要图。json
Provider是给你手机应用发出推送消息的服务器,而APNS(Apple Push Notification Service)则是苹果消息推送服务器。你本地的服务器当须要给应用推送一条消息的时候,先要将消息发出到苹果推送服务器,而后再由苹果推送服务器将消息发到安装了该应用的手机。xcode
接下来再看一张解释图:安全
根据上图的逻辑我来给你们解释一下:服务器
1.你的IOS应用须要去注册APNS消息推送功能。app
2.当苹果APNS推送服收到来自你应用的注册消息就会返回一串device token给你(很重要)iphone
3.将应用收到的device Token传给你本地的Push服务器。socket
4.当你须要为应用推送消息的时候,你本地的推送服务器会将消息,以及Device Token打包发送到苹果的APNS服ide
5.APNS再将消息推送给目的iphone
第二部分
1.从证书颁发机构颁发证书
打开你mac的钥匙串访问: 而后点击钥匙串访问
随后它会弹出一个窗口 用户电子邮件信息
就填写你苹果开发者帐号的名称便可(应该是一个邮件名称),点击保存到磁盘的选项,点击继续,显示以下
点击存储,文件名为:CertificateSigningRequest.certSigningRequest 随后将他放在一个文件夹中咱们取名push吧!
第三部分
访问苹果开发者网址:https://developer.apple.com/
选中MemberCenter选项,进入登录页面,用你的苹果开发者帐号登录,过一会网页就会自动跳转到下图。
点击红色所选部分
内容进行下一步的操做。
选择Certificates选项,设置证书,如图所示先解释一下
Development选项的做用顾名思义就是用来做为开发使用的证书,Production选项则
是用来发布产品使用的,名称很陌生是否是,以前的开发者网页是没有这一选项的,多是苹果把他修改了,用这个名称更加能让人
理解吧(字面上解释就是产品么)。两个选项生成证书的步骤是同样的,如今咱们使用开发者的选项进行证书的制做,步骤以下:
选择Development选项
点击上面的加号选项,
选择APNS选项(开发么固然是在沙盒环境下了,模拟真实状况),而后Continue
这个AppID咱们在下一部分讲如何生成,如今我用的是已经生成好的一个应用ID,继续Continue
这边就要选择在钥匙串访问环节下载下来的CertificateSigningRequest.certSigningRequest文件了,选择并生成
点击下载,获得aps_development .cer,保存到push文件中去。
第四部分
新建一个AppID,选择网页上的AppIDs,而后点击右上角的 “加号”
App的取名只要按照苹果要求的就能够了
而后BundleID是比较重要的,在提交审核以及测试(苹果的TestFlight)和付费环节都须要用到,也只需按照苹果要求来写就行了。
接下来就是对你的应用须要使用苹果的哪些服务进行选择就好了,例如广告,游戏中心,推送,付费等等状况。
最后选择“Submit”选项,在下一个界面中选择“done”选项,这样咱们设置AppID的步骤咱们就完成了。
第五部分:生成Provisioning Profiles
这个配置概要文件分为两种,一种是为开发使用的,还有一种则是为发布到appStore上面。
建立发布版的ProvisioningProfile与开发版的流程相同,点击Development而后点击右上角的加号
会进入选择何种配置概要文件的界面
咱们如今时测试,因此选择“IOS App Development”的选项,在下面的Distribution发布选项中有两个选择,“App Store”以及“Ad hoc”,你能够根据下面的描述
选择你发布所需的选项。点击Continue进入下一步。
选择你上一步建立的AppID,点击Continue 进行下一步
选择你的开发者帐号,Continue进行下一步
在这一步上选择你的设备(你只有在这一步上勾选了你的设备,你才能在设备上用这个签名进行调试)。关于如何将你的设备号添加进去也是很是
简单的,选择左侧的"Devices",而后点击右上角的加号,在随后出来的页面上添加你设备的UUID(在XCode中能够查看到)以及name( 能够随便取,本身看的懂就行)
而后Register一下,照着流程走到最后一步就完成了。
好咋们继续回到上面的Provisioning Profile配置环节,当你选好了你的设备后点击“Continue”进入下一页,
输入一个文件名(最好是起的能看懂是干吗的,固然也能够随便起),点击“Generate”进入下一个页面,在这个页面中就会有一个下载按钮让你下载这个文件,
咱们把它下载下来放在Push文件夹中。
第六部分
好了,前期的准备工做都已经作完了,如今让咱们开始推送吧!(吼吼)
首先双击咱们生成的 “aps_development .cer” 文件,进入钥匙串访问,找到咱们的专用秘钥(根据在第二部分中从证书机构颁发证书操做中填写的经常使用名)
我在第二部分填写的是“silicon”,因为换了一台mac以前安装的没有了,以前没有截图,因此随便找了个图给你们看一下,凭你们的聪明才智应该不难理解吧。
而后右击导出,会弹出以下所示的图。
将他存储到push文件夹中,命名为“push.p12”,在这一步中导出会让你输入密码并验证,你能够自定义一个密码,例如abc123。
如今push文件夹中应该有几个文件“aps_development .cer” ,"push.p12",“CertificateSigningRequest.certSigningRequest”以及刚才下下来的配置概要文件。
接下来咱们打开终端将他们生成.pem文件
1.把aps_development .cer文件生成.pcm文件,cd到push文件夹下
2.把push.p12文件生成为.pem文件
上边输入的密码则是你导出证书所设的密码,即abc123.接着还会让你输入.pem文件的密码,仍是使用abc123好了,防止混淆。
这样咱们在push文件夹中就又获得了两个文件,PushChatCert.pem和PushChatKey.pem。
3.把PushChatCert.pem和PushChatKey.pem合并为一个pem文件,
在push文件夹中又多了一个ck.pem文件,以上咱们把须要使用的文件都准备好了
接下来就要测试一下啦,是否是很激动~
为了测试证书工做的情况,咱们可使用“telnet gateway.sandbox.push.apple.com 2195”来检测一下,若是显示
则表示成功了。
而后,咱们使用咱们生成的证书和私钥来设置一个安全的连接去连接苹果服务器
在终端输入以下命令:openssl s_client -connect gateway.sandbox.push.apple.com:2195 -cert PushChatCert.pem -key PushChatKey.pem
须要输入密码(abc123 咱们刚才所设置的)。
而后他会返回一系列的数据,这里我就粘贴一部分啦:
CONNECTED(00000003)
depth=1 /C=US/O=Entrust, Inc./OU=www.entrust.net/rpa is incorporated by reference/OU=(c) 2009 Entrust, Inc./CN=Entrust Certification Authority - L1C
verify error:num=20:unable to get local issuer certificate
verify return:0
---
Certificate chain
。。。。。(省略)
。。。。。(省略)
。。。。。(省略)
Start Time: 1416389389
Timeout : 300 (sec)
Verify return code: 0 (ok)
---
测试就到这里啦。。。
第七部分
1.创建推送项目
在appdelegate.m中加入以上代码,
因为ios8的推送跟ios7及如下的不同,因此须要加判断来注册消息推送。
函数:
会接收来自苹果服务器给你返回的deviceToken,而后你须要将它添加到你本地的推送服务器上。(很重要,决定你的设备能不能接收到推送消息)。
这个函数则是当设备接收到来自苹果推送服务器的消息时触发的,用来显示推送消息。
当注册失败时,触发此函数。
2.PHP服务端
将simplepush.php这个推送脚本也放在push文件夹中
deviceToken填写你接收到的token,passPhrase则填写你的ck.pem设置的密码。
此刻就是见证奇迹的时候了
使用终端进入到push文件夹,在终端输入 php simplepush.php
若显示以上提示则表示推送成功了。
附上一张成功图。
推送就到这边吧!
感谢这篇博客的指导:http://blog.csdn.net/showhilllee/article/details/8631734