`
cppmule
  • 浏览: 448718 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类

iPhone消息推送机制实现与探讨

    博客分类:
  • iOS
 
阅读更多

iPhone消息推送机制实现与探讨

 

最近两天在研究ios的消息推送机制。研究这个东西,还是充满兴趣的。

Push的原理:

Push 的工作机制可以简单的概括为下图

图中,Provider是指某个iPhone软件的Push服务器,这篇文章我将使用.net作为Provider。 
APNS 是Apple Push Notification Service(Apple Push服务器)的缩写,是苹果的服务器。

上图可以分为三个阶段。

第一阶段:.net应用程序把要发送的消息、目的iPhone的标识打包,发给APNS。 
第二阶段:APNS在自身的已注册Push服务的iPhone列表中,查找有相应标识的iPhone,并把消息发到iPhone。 
第三阶段:iPhone把发来的消息传递给相应的应用程序, 并且按照设定弹出Push通知。

 

    从上图我们可以看到。

   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):

2、填写你的邮箱和Common Name,这里填写为PushChat。选择保存到硬盘。

这样就在本地生成了一个PushChat.certSigningRequest文件。

二、生成*.p12文件

1、导出密钥,并输入你的密码。

输入你的密码:

这样就生成了一个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

    点击提交

这样就会生成下面这条记录:

点击配置:

出现下面界面,点击继续:

这里我们选择前面生成好的PushChat.certSigningRequest文件,点击生成。

正在生成

生成完毕,我们把它下载下来。命名为aps_developer_identity.cer

点击完成,你会发现状态变成Enabled。

到现在为止,我们已经生成了3个文件。

1、PushChat.certSigningRequest

2、PushChatKey.p12

3、aps_developer_identity.cer

现在我们创建一个简单的iPhone应用程序。

1、打开Xcode,选择创建一个View-based Application。命名如下图:

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中运行,会弹出下面的提示框:

选择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生成.net和APNS通信的证书文件。

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代码做相应的调整,如下图。

这样就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上面的显示:

 

 

 

 

总结:这篇文章主要是详细的讲述了ios消息推送机制的实现,如何通过.net应用程序发送消息给ios应用程序。

分享到:
评论

相关推荐

    Android推送实现方案探讨

    ### Android推送实现方案探讨 #### 背景与概述 随着移动互联网的迅速发展,智能手机已成为人们日常生活中不可或缺的一部分。在此背景下,推送技术作为一种能够实时向用户传递信息的关键技术,在移动应用开发中扮演...

    .net推送消息到iphone

    标题中的".net推送消息到iphone"指的是使用.NET框架向iOS设备发送远程通知的过程。这个过程主要涉及Apple Push Notification Service(APNS),这是苹果公司提供的一个服务,允许开发者将实时信息推送到用户的iPhone...

    Iphone开发系列源码——实现类似 iOS 5 推送通知效果的代码

    这个"Iphone开发系列源码——实现类似 iOS 5 推送通知效果的代码"是针对苹果设备上开发应用程序时如何模拟iOS 5系统中的推送通知效果的一个示例项目。下面我们将深入探讨这个主题,了解如何在iOS应用中实现这一功能...

    ios 推送通知(转载)

    iOS 推送通知是苹果设备上一种重要的用户互动机制,它允许应用程序在后台向用户发送消息,即使应用未运行。这种服务由Apple Push Notification service (APNs) 提供,用于实时地将服务器端的消息传递到用户的iOS设备...

    基于Java的 iOS 推送通知

    本文主要探讨了如何基于Java实现iOS的推送通知。首先,我们需要理解iOS推送通知的基本原理。 **iOS推送通知原理** 1. **消息流**:推送通知的流程主要包括三个步骤。提供商(即APP服务端)将通知发送至Apple Push ...

    iphone apns C#

    在本项目中,我们将探讨如何使用C#语言来实现iPhone的APNs推送。C#是一种广泛使用的面向对象的编程语言,尤其在Windows应用开发和服务器端服务开发中非常流行。 首先,我们需要理解APNs的工作原理。APNs通过安全的...

    apns iphone源码下载

    "apns_iphone" 源码可能是实现APNs客户端和服务端的代码库,可能包括了连接到APNs服务器、构建推送消息、处理响应等功能。在使用源码时,开发者需要了解其结构和接口,根据自己的需求进行适当的修改,如调整消息...

    iphone 聊天应用程序

    - **性能优化**:使用长连接避免频繁的连接断开与重建,同时考虑使用推送通知服务(如APNs)来提高离线消息的送达率。 5. **扩展功能**: - **群聊与私聊**:除了基本的单人聊天,还可以扩展至群聊功能,需要设计...

    iPhone开发实战.pdf

    - 消息推送:利用苹果的推送服务(APNs)实现实时消息通知。 - 数据同步:通过网络API与后端服务器进行交互,保持数据的一致性。 #### 3.2 游戏应用开发 对于游戏应用而言,除了基本的UI设计和交互逻辑外,还需要考虑...

    ios应用源码之第一个iphone小程序(实现聊天功能) chat-1 2018128

    为了实现实时聊天,开发者可能会采用WebSocket或者推送通知服务(Push Notifications)来实现消息的即时传递。WebSocket提供双向通信,使得服务器和客户端可以实时交换数据,适合于需要实时交互的应用。而推送通知则...

    iphone开发常用知识点大集合

    总的来说,“iPhone开发常用知识点大集合”涵盖的内容广泛且深入,包括编程语言、UI设计、数据管理、网络通信、多线程、动画、推送通知等多个方面。只有全面掌握这些知识点,才能有效地进行iPhone应用的开发和优化,...

    面向iPhone开发者开发windows Phone 指南

    - 解释WP7推送通知的工作原理和技术架构,以及如何在应用程序内部实现消息接收和处理。 - 对比iOS和WP7的通知体系,帮助开发者理解两者的触发机制和用户交互方式。 综上所述,面向iPhone开发者开发Windows Phone的...

Global site tag (gtag.js) - Google Analytics