最近两天在研究ios的消息推送机制。研究这个东西,还是充满兴趣的。 Push的原理: Push 的工作机制可以简单的概括为下图 ![](https://i-blog.csdnimg.cn/blog_migrate/5ffba14aa98eda29f8333ea131a77b78.jpeg) 图中,Provider是指某个iPhone软件的Push服务器,这篇文章我将使用.net作为Provider。 APNS 是Apple Push Notification Service(Apple Push服务器)的缩写,是苹果的服务器。 上图可以分为三个阶段。 第一阶段:.net应用程序把要发送的消息、目的iPhone的标识打包,发给APNS。 第二阶段:APNS在自身的已注册Push服务的iPhone列表中,查找有相应标识的iPhone,并把消息发到iPhone。 第三阶段:iPhone把发来的消息传递给相应的应用程序, 并且按照设定弹出Push通知。 ![](https://i-blog.csdnimg.cn/blog_migrate/b8675b864440d1b66bc5eedeb7bd8cfe.jpeg) 从上图我们可以看到。 1、首先是应用程序注册消息推送。 2、 IOS跟APNS Server要deviceToken。应用程序接受deviceToken。 3、应用程序将deviceToken发送给PUSH服务端程序。 4、 服务端程序向APNS服务发送消息。 5、APNS服务将消息发送给iPhone应用程序。 无论是iPhone客户端跟APNS,还是Provider和APNS都需要通过证书进行连接的。下面我介绍一下几种用到的证书。 几种证书: 一、*.certSigningRequest文件 1、生成Certificate Signing Request (CSR): ![](https://i-blog.csdnimg.cn/blog_migrate/20fea5c5fa0f1253ed0503123109ea02.jpeg) 2、填写你的邮箱和Common Name,这里填写为PushChat。选择保存到硬盘。 ![](https://i-blog.csdnimg.cn/blog_migrate/bb7a6aa1039ba1201be0f9ae7645f878.jpeg) 这样就在本地生成了一个PushChat.certSigningRequest文件。 二、生成*.p12文件 1、导出密钥,并输入你的密码。 ![](https://i-blog.csdnimg.cn/blog_migrate/5e7e28ff42c8ed54f69b8f089cfb62ed.jpeg) 输入你的密码: ![](https://i-blog.csdnimg.cn/blog_migrate/dcff809412d24ddf7aef14abeba1a9b7.jpeg) 这样就生成了一个PushChatKey.p12文件。 三、新建一个App ID 和SSL certificate文件 1、用你的付过费的apple帐号登录到iOS Provisioning Portal。新建一个App ID。 Description:中输入PushChat Bundle Seed ID:默认选择Generate New Bundle Identifier:输入com.mysoft.PushChat 点击提交 ![](https://i-blog.csdnimg.cn/blog_migrate/e4c425e49dbce425a01971fa4d556ae5.jpeg) 这样就会生成下面这条记录: ![](https://i-blog.csdnimg.cn/blog_migrate/27495478e506d11322ae8b8650116593.png) 点击配置: ![](https://i-blog.csdnimg.cn/blog_migrate/7321c4c0c600edc22ec50a01171ca37d.jpeg) 出现下面界面,点击继续: ![](https://i-blog.csdnimg.cn/blog_migrate/803cbabae8c329b590911c000f77237a.png) 这里我们选择前面生成好的PushChat.certSigningRequest文件,点击生成。 ![](https://i-blog.csdnimg.cn/blog_migrate/c50fd005971a7f42878b587166021a34.jpeg) 正在生成 ![](https://i-blog.csdnimg.cn/blog_migrate/1973efce7bdf2ba9fe33b1512765f64c.jpeg) 生成完毕,我们把它下载下来。命名为aps_developer_identity.cer。 ![](https://i-blog.csdnimg.cn/blog_migrate/27996dfb187508f74032ed43cea91615.jpeg) 点击完成,你会发现状态变成Enabled。 ![](https://i-blog.csdnimg.cn/blog_migrate/879abe09911d2a1a1d6c387e16c65cad.jpeg) 到现在为止,我们已经生成了3个文件。 1、PushChat.certSigningRequest 2、PushChatKey.p12 3、aps_developer_identity.cer 现在我们创建一个简单的iPhone应用程序。 1、打开Xcode,选择创建一个View-based Application。命名如下图: ![](https://i-blog.csdnimg.cn/blog_migrate/f46cb50b9b01d38d66def7d686ee25c6.png) 2、在PushChatAppDelegate中的didFinishLaunchingWithOptions方法中加入下面代码:
-(BOOL)application:(UIApplication *)application
didFinishLaunchingWithOptions:(NSDictionary
*)launchOptions
{
self.window.rootViewController =
self.viewController;
[self.window makeKeyAndVisible];
//
Let the device know we want to receive push
notifications
[[UIApplication sharedApplication]
registerForRemoteNotificationTypes:
UIRemoteNotificationTypeBadge |
UIRemoteNotificationTypeSound |
UIRemoteNotificationTypeAlert)];
return
YES;
}
通过registerForRemoteNotificationTypes方法,告诉应用程序,能接受push来的通知。 3、在xcode中运行,会弹出下面的提示框: ![](https://i-blog.csdnimg.cn/blog_migrate/c60878ed2920cdfed5e75599258e1718.jpeg) 选择OK。表示此应用程序开启消息通知服务。 在 PushChatAppDelegate.m代码中添加下面方法获取deviceToken :
- (
void
)application:(UIApplication*)application
didRegisterForRemoteNotificationsWithDeviceToken:(NSData*)deviceToken
{
NSLog(
@"My
token is: %@"
,
deviceToken);
}
- (
void
)application:(UIApplication*)application
didFailToRegisterForRemoteNotificationsWithError:(NSError*)error
{
NSLog(
@"Failed
to get token, error: %@"
,
error);
}
获取到的deviceToken,我们可以通过webservice服务提交给.net应用程序,这里我简单处理,直接打印出来,拷贝到.net应用环境中使用。 发送通知的.net应用程序出来需要知道deviceToken之外,还需要一个与APNS连接的证书。 这个证书可以通过我们前面生成的两个文件中得到。 使用OpenSSL 1、将aps_developer_identity.cer转换成 aps_developer_identity.pem格式。 openssl x509 -in aps_developer_identity.cer -inform DER -out aps_developer_identity.pem -outform PEM 2、将p12格式的私钥转换成pem,需要设置4次密码,密码都设置为:abc123。 openssl pkcs12 -nocerts -out PushChat_Noenc.pem -in PushChat.p12 3、用certificate和the key 创建PKCS#12格式的文件。 openssl pkcs12 -export -in aps_developer_identity.pem -inkey PushChat_Noenc.pem -certfile PushChat.certSigningRequest -name "aps_developer_identity" -out aps_developer_identity.p12 这样我们就得到了在.net应用程序中使用的证书文件:aps_developer_identity.p12。 在.net应用程序中发送通知。 有个开源的类库:apns-sharp。 地址是:http://code.google.com/p/apns-sharp/。 我们下载源代码,对里面的JdSoft.Apple.Apns.Notifications做相应的调整就能用了。 我们根据DeviceToken和p12File对JdSoft.Apple.Apns.Notifications.Test做相应的调整,如下图。 ![](https://i-blog.csdnimg.cn/blog_migrate/caac665a2ee47b803988e3ebef4904b6.png) 这样就OK了。 效果: 通知的代码:
for
(
int
i =
1
; i <= count; i++) {
//Create a new notification to send
Notification alertNotification =
new
Notification(testDeviceToken); alertNotification.Payload.Alert.Body =
string
.Format(
"Testing {0}..."
, i); alertNotification.Payload.Sound =
"default"
; alertNotification.Payload.Badge = i;
//Queue the notification to be sent
if
(service.QueueNotification(alertNotification)) Console.WriteLine(
"Notification Queued!"
);
else
Console.WriteLine(
"Notification Failed to be Queued!"
);
//Sleep in between each message
if
(i < count) { Console.WriteLine(
"Sleeping "
+ sleepBetweenNotifications +
" milliseconds before next Notification..."
); System.Threading.Thread.Sleep(sleepBetweenNotifications); } }
用手机拍的ipad上面的显示: ![](https://i-blog.csdnimg.cn/blog_migrate/4e259c202bff31ebc3356415e48de92a.jpeg) ![](https://i-blog.csdnimg.cn/blog_migrate/2349f840c32db433779a0e90a64b72f5.jpeg) 总结:这篇文章主要是详细的讲述了ios消息推送机制的实现,如何通过.net应用程序发送消息给ios应用程序。 |