Passbook详解与开发案例

转自关东升的博客

Passbook是iOS 6的新功能,只能在iPhone和iPod touch设备中使用。它可以帮助我们管理商家发放的电子会员卡、积分卡、优惠券等。这将对未来电子商务产生深远的影响。商家通过发放会员卡、积分卡、优惠券等,提高与消费者的互动,吸引人们更多消费。Passbook的诞生,正是为了将所有这些“卡”和“券”电子化,存放在iPhone或iPod touch里。

 
Passbook与Pass
 
iOS 6中的Passbook能够帮助我们集中管理电子“卡”和“券”,这些电子“卡”和“券”就是Pass,Passbook是这些Pass集合管理应用。Passbook与Pass关系,Passbook是我们的“卡包”,而Pass是里面的“卡”和“券”。
 
 
当我们选择其中一个卡片后,卡片会滑出来,点击右下角“i”按钮会翻转到背面。在点击左上角的垃圾桶按钮可以删除,弹出一个具有金属质感的“碎纸机”样式的确认框,当点击“删除”按钮后,“碎纸机”会将卡片粉碎,还有动画效果。每次用到这个功能的时候我都很惊叹,苹果对于细节的设计无可挑剔。
 
Pass的5种风格
 
iOS 6目前提供了5种风格的Pass,它们分别是:
 
Boarding passes(登机牌)。虽然从字面翻译为“登机牌”,但是它包括了登机牌、火车票和船票等种类的票证,在Pass上面有起点和终点,时间和登机口等信息。
 
Coupons(优惠券)。或者打折卡,描述商品的优惠或打折信息的电子凭证。一般上面会有商家的logo,打折比例,使用期限等信息。
 
Store cards(购物卡)。描述了用户在商场或俱乐部中的账号余额电子凭证。一般上面会有用户级别等信息。
 
Event tickets(入场券)。描述了体育比赛、演唱会、音乐会等入场券的电子凭证。一般上面会有一个大的背景图片,这个图片背模糊化了,还可以有清楚的缩图。
 
Generic(通用卡)。如果上面的4种不能满足,我们可以使用这一种,它可以是自定义上面的内容。一个通用卡类型的会员卡。
Pass的内部结构
 
每一个Pass是一个ZIP格式的压缩文件,这文件文件的后缀名是pkpass,它通过一些特殊的方式发给用户使用,这些特殊的方式我们会在后面介绍。如果我们把pkpass文件使用解压缩软件打开,会看到如下内容:
 
Pass
 
├── icon.png
 
├── icon@2x.png
 
├── logo.png
 
├── logo@2x.png
 
├── thumbnail.png
 
├── thumbnail@2x.png
 
├── background.png
 
├── background@2x.png
 
├── strip.png
 
├── strip@2x.png
 
├── manifest.json
 
├── fr.lproj
 
│   └── pass.strings
 
├── de.lproj
 
│   └── pass.strings
 
├── pass.json
 
└── signature
 
pass.json文件是Pass的核心,它描述了这个Pass正面和背面的所有信息。我们提供了这个Pass需要显示的所有图片。最后需要一个清单文件manifest.json,它包含了所有这些文件的SHA1校验值,和一个分离的签名文件signature, 这样Passbook能够验证这个Pass在创建之后没有被修改过。
 
 Pass Kit编程:实例:MyPass实例设计与说明
 
下面我们通过一个实例(MyPass)介绍一下Pass Kit的编程过程,MyPass实例设计原型草图。MyPass启动的时候,首页是表视图画面,它查询本地设备上的Passbook中特定一些Pass,然后然后显示的表视图画面中。用户点击“+”按钮,如果登机牌Pass存在则替换,否则添加登机牌Pass到Passbook,登机牌Pass是从iosbook3.com服务器请求下载的。如果在表视图画面点击其中的单元格,则画面跳转到Pass的详细画面,在详细画面中可以点击导航栏右上角的“Remove”按钮把当前Pass从Passbook中删除。
 
开始Passbook
 
 
1、创建App ID
 
任何一个iOS应用都需要创建App ID的,在Description项目中输入“Pass Kit Dev”,Bundle Seed ID (App ID Prefix)项目中选择“Use Team ID”。 Bundle Identifier (App ID Suffix)项目中输入“com.51work6.MyPass”。
 
创建成功获得App ID页面,在App ID列表中会发现我们刚刚创建的Pass Kit Dev
 
2、配置Pass可用
 
默认情况下创建的应用是不可以访问Passbook的,我们需要点击Configure超链接进入应用配置页面,勾选“Enable for Passes”开启Pass可用。
 
配置完成点击右下角的“Done”按钮,保存配置并回到App ID的列表页面,这时候再回来看一下我们刚刚配置的应用,它的Pass状态变为了绿色可用状态了。
 
3、创建配置概要文件
 
为了能够编写在设备上应用,我们还需要创建配置概要文件。创建成功之后下载配置概要文件到本地。
 
4、创建Pass类型ID
 
创建Pass类型ID也是重要的一个环节,我们需要设置的Pass类型ID是“pass.com.51work6.boarding-pass”。
 
5、配置Xcode工程代码签名
 
前面的工作完成之后,我们需要创建和配置Xcode工程,创建工程名“MyPass”应用,然后进行配置Xcode工程代码签名。这个签名需要使用第3个步骤创建配置概要文件。
 
选择TAGETS→MyPass→Code Signing Identity,在后面选择Pass Kit Dev Profile。
 
设置完成之后可以开始编码工作了。
 
6、配置Xcode工程配置授权信息
 
配置授权信息与iCloud应用类似,选择TAGETS→MyPass→Summary→Entitlements,我们可以在这里配置授权信息。
 
授权信息项目说明如下:
 
Entitlements :勾选Use Entitlements File,指定一个授权文件,这个文件没有会在你的工程目录中自己创建,它记录下面的授权详细配置信息的;
 
Pass:是选择Pass类型标识,先选择Use selected pass type identifier,然后勾选pass.com.51work6.boarding-pass;
 
到此为止,编程的前期准备过程就完成了,下面我们介绍实例的编写过程。
 
访问Passbook
 
对于Pass的操作是通过PKPassLibrary类完成的,PKPassLibrary类不是单例设计的,获得实例对象时候使用下面代码:
 
PKPassLibrary* passLib = [[PKPassLibrary alloc] init];
 
在PKPassLibrary类中与访问Passbook相关的方法有:
 
passes  获得Passbook中全部授权文件指定的Pass,我们在授权文件中指定的Pass类型ID是pass.com.51work6.boarding-pass,因此该方法取得的是Pass类型ID为pass.com.51work6.boarding-pass的所有Pass。
 
passWithPassTypeIdentifier:serialNumber:  通过指定的Pass类型ID和序列号获得Pass对象。
 
下面我们看看相关的程序代码,ViewController.h代码如下:
  1. #import <UIKit/UIKit.h> 
  2.  
  3. #import ”ASIHTTPRequest.h” 
  4.  
  5. #import ”PassKit/PassKit.h” 
  6.  
  7. #import ”DetailViewController.h” 
  8.  
  9. #define SerialNumber @”gT6zrHkaW” 
  10.  
  11. @interface ViewController : 
  12.  
  13. UITableViewController <PKAddPassesViewControllerDelegate> 
  14.  
  15. @property (strong, nonatomic) NSArray* passes; 
  16.  
  17. - (IBAction)add:(id)sender; 
  18.  
  19. @end 
ViewController.m相关代码如下:
  1. - (void)viewDidLoad 
  2.  
  3.  
  4. [super viewDidLoad]; 
  5.  
  6. //判断Passbook是否可用 
  7.  
  8. if (![PKPassLibrary isPassLibraryAvailable]) 
  9.  
  10.  
  11. NSLog(@”Passbook不可用。”); 
  12.  
  13. else { 
  14.  
  15. [[NSNotificationCenter defaultCenter] addObserver:self 
  16.  
  17. selector:@selector(handleLibraryChange:) 
  18.  
  19. name:PKPassLibraryDidChangeNotification object:nil]; 
  20.  
  21.  
  22.  
  23. -(void)viewWillAppear:(BOOL)animated 
  24.  
  25.  
  26. [super viewWillAppear:YES]; 
  27.  
  28. //刷新画面 
  29.  
  30. [self handleLibraryChange:nil]; 
  31.  
  32.  
  33.   
  34.  
  35. #pragma mark - 处理Passbook变化通知 
  36.  
  37. -(void)handleLibraryChange:(NSNotification*) not ④ 
  38.  
  39.  
  40. PKPassLibrary* passLib = [[PKPassLibrary alloc] init]; 
  41.  
  42. //排序 
  43.  
  44. NSSortDescriptor *byName = [NSSortDescriptor 
  45.  
  46. sortDescriptorWithKey:@"localizedName" ascending:YES]; 
  47.  
  48. _passes = [[passLib passes] sortedArrayUsingDescriptors:@[byName]]; 
  49.  
  50. [self.tableView reloadData]; 
  51.  
  52.  
  53. - (void)didReceiveMemoryWarning 
  54.  
  55.  
  56. [super didReceiveMemoryWarning]; 
  57.  
  58. [[NSNotificationCenter defaultCenter] removeAllObjects]; 
  59.  
发布Pass
 
Pass签名和压缩成功之后,如何把pkpass文件发布给用户使用呢?对于提供给普通用户pkpass文件,我们有3种发布方式:Email发布、Web网站发布和应用程序内发布。
 
Email发布
 
这种发布方式是pkpass文件作为Email附件发送给用户,用户最好在他的iPhone或iPod touch设备上打开邮箱读取Email。Email附件中的Pass,附件中的图标是在Pass中的logo.png文件。
 
当点击这个附件“Store Card”后页面会跳转,点击导航栏右边的“Add”按钮,会将这个Pass添加到Passbook中。
 
 
如果用户没有在它的iPhone或iPod touch中接收Email,可以在Mac OS X 10.8.2以上系统中,使用邮件应用程序接收这个邮件。
 
点击邮件中的“查看凭证…”按钮,会弹出添加Pass的对话框。
 
 
如果这个Pass没有添加到Passbook,右下角的按钮为“添加到Passbook”,如果已经添加到Passbook则这个按钮是“完成”或“更新”。
 
Passbook就到这里!更多Passbook内容可以参考我的新书《iOS网络编程与云端应用最佳实践》。
posted @ 2013-06-03 18:48  周宏伟  阅读(2863)  评论(0编辑  收藏  举报