iOS 添加 .pkpass 到 Wallet, 与测试代码

这个是老的方式,最新的方式 iOS Wallet 开发,省去了一大堆的签名工作。

在手机内的 ** Wallet ** app 能够收集各种卡券,在开始创建pkpass文件之前可以先看一下:

  • 苹果的官方文档:Wallet Developer Guide 里面介绍了怎样使用Wallet,而且还有一些模版文件
  • Raywenderlich: Passbook Tutorial 教程,里面一步一步的介绍了怎样生成一个pkpass 文件

** pkpass 的文件内主要包含:**

pass.json,  
manifest.json, 
signature  
还有各种png 图片

** 卡券分为五种:**

•Coupon
•Boarding pass
•Store card
•Event ticket
•Generic
 
1. 准备
  • 下载 wallet 内的 Example Passes and Sample Code 里面有一个 ** SamplePasses ** 文件夹, 里面有目前所需的各种文件包括 pass.json 和 icon.png, logo.png 等 比如在 ** Coupon.pass ** 文件夹内就包含:
icon.png
[email protected]
logo.png
[email protected]
pass.json

点击 ** Coupon.pkpass ** 可看到一张这样的卡券

iOS 添加 .pkpass 到 Wallet, 与测试代码_第1张图片
  • 创建 ** Pass Type ID ** , 苹果文档里有介绍,一步步按照文档来,最终会创建一个类似于如图的 ** Pass Type ID ** ,


    iOS 添加 .pkpass 到 Wallet, 与测试代码_第2张图片

    把该 ** Pass Type ID ** 下载,然后双击,它会导入到 keychain 里


    iOS 添加 .pkpass 到 Wallet, 与测试代码_第3张图片
2. 创建pass.json (这里以苹果的下载资源为例)

新建一个文件夹,命名为 pastest.pass (也可以随便),把它放在你好找的地方。在Xcode 创建一个空白的empty 文件,

iOS 添加 .pkpass 到 Wallet, 与测试代码_第4张图片

命名为 pass.json
iOS 添加 .pkpass 到 Wallet, 与测试代码_第5张图片

记得把pass.json文件移动到创建的pastest.pass文件夹内。在刚刚创建的 pass.json 内直接把苹果的 coupon 内的pass.json 的内容拷贝替换进来

{
  "formatVersion" : 1,
  "passTypeIdentifier" : "pass.com.apple.devpubs.example",
  "serialNumber" : "E5982H-I2",
  "teamIdentifier" : "A93A5CM278",
  "webServiceURL" : "https://example.com/passes/",
  "authenticationToken" : "vxwxd7J8AlNNFPS8k0a0FfUFtq0ewzFdc",
  "barcode" : {
    "message" : "123456789",
    "format" : "PKBarcodeFormatPDF417",
    "messageEncoding" : "iso-8859-1"
  },
  "locations" : [
    {
      "longitude" : -122.3748889,
      "latitude" : 37.6189722
    },
    {
      "longitude" : -122.03118,
      "latitude" : 37.33182
    }
  ],
  "organizationName" : "Paw Planet",
  "description" : "Paw Planet Coupon",
  "logoText" : "Paw Planet",
  "foregroundColor" : "rgb(255, 255, 255)",
  "backgroundColor" : "rgb(206, 140, 53)",
  "coupon" : {
    "primaryFields" : [
      {
        "key" : "offer",
        "label" : "Any premium dog food",
        "value" : "20% off"
      }
    ],
    "auxiliaryFields" : [
      {
        "key" : "expires",
        "label" : "EXPIRES",
        "value" : "2013-04-24T10:00-05:00",
        "isRelative" : true,
        "dateStyle" : "PKDateStyleShort"
      }
    ]
  }
}

里面的内容就是一大串的 key: value 了,在例子中,目前只需要替换 passTypeIdentifierteamIdentifier,比如我刚刚生成的 passTypeIdentifier 为 ** pass.come.deng.wulala ** 替换成这样

  "passTypeIdentifier" : "pass.come.deng.wulala",

就好了
** teamIdentifier ** 同理,到自己开发者账号内拷贝过来替换就好了,比如:

  "teamIdentifier" : "X5NZ3Y8346",

到此 pass.json 文件就算OK了

3. 创建 manifest.json

同样的,用Xcode 创建一个empty 文件, 命名为 manifest.json ,由于例子是一个 coupon 的 pkpass 文件, 所以只需要

icon.png
[email protected]
logo.png
[email protected]
pass.json

manifest.json 内的内容格式:

{
"icon.png":"ba47a8021c8d74d2146d7244c8a0566be37df43b",
"[email protected]":"bd5442b4b08aa4dde333ec9ef0269e7fd93140b3",
"logo.png":"780540b3a324bf66aeaee2d352283371356e9502",
"[email protected]":"a718ffd4e611e404dd3eb701454bcaefdabbe311",
"pass.json":"98dc0ced131d6a62311fc16a84ec29dec4fc52b6"
}

在里面 "icon.png":"ba47a8021c8d74d2146d7244c8a0566be37df43b", ** ba47a8021c8d74d2146d7244c8a0566be37df43b ** 为 icon.png 的 SHA1 生成值
生成 icon.png logo.png pass.json 的 SHA1 方式为 打开命令行 cd 到你存放文件的文件夹 pastest.pass 内然后 对于 icon.png 图片在当前目录的命令行内 输入

openssl sha1 icon.png 

把输出的值在manifest 内 替换为你自己图片的值 以此类推,直到把所以的图片都OK,然后pass.json 文件也一样

openssl sha1 pass.json

然后值替换,这样manifest.pass 文件也OK了. **(注意生成 pass.json 的 SHA1 后就不要更改 pass.json内的内容了,否则 pass.json 的 SHA1 需要重新生成 ) **

iOS 添加 .pkpass 到 Wallet, 与测试代码_第6张图片
4. 签名加密

至此,两个重要的 json 文件就OK了,接下来是一大堆的签名工作了。

  • ** 导出 Pass Type ID 证书**

首先在keychain 找到你刚刚生成的 Pass Type ID,

iOS 添加 .pkpass 到 Wallet, 与测试代码_第7张图片

右键,点击 ** 导出"xxxxxxxx" , 在弹出窗口输入: Certificates.p12 **

iOS 添加 .pkpass 到 Wallet, 与测试代码_第8张图片

点击 ** 存储 ** 在提示输入密码的时候

iOS 添加 .pkpass 到 Wallet, 与测试代码_第9张图片
直接点击 ** 好 ,不输入密码。记得把证书 ** Certificates.p12 存放在文件夹 pastest.pass 内。

  • ** 生成 passcertificate.pem **

cd 到 pastest.pass 文件夹, 然后在命令行输入:

openssl pkcs12 -inCertificates.p12 -clcerts -nokeys -outpasscertificate.pem -passin pass:

它会在文件夹 pastest.pass 内生成一个 passcertificate.pem。

  • ** 生成 pastest.pass **

继续在文件夹 pastest.pass 命令行目录内输入:

openssl pkcs12 -inCertificates.p12 -nocerts -outpasskey.pem -passin pass: -passout pass:12345

它会在文件夹 pastest.pass 内生成一个 passkey.pem

  • ** 导出 Apple Worldwide Developer Relations Certification Authority 证书 **

在 keychain 内 找到苹果的证书 Apple Worldwide Developer Relations Certification Authority, 如果找不到就到开发者账号下一个。

和生成 证书 Certificates.p12 一样,** 右键 ** -> ** 导出 Apple Worldwide Developer Relations Certification Authority **
在弹出窗口中命名为:** WWDR.pem **

iOS 添加 .pkpass 到 Wallet, 与测试代码_第10张图片

记得 ** 文件格式** 选为 ** 增强保密邮件(.pem)** , 点击 ** 存储 ** 把生成的 WWDR.pem 存放在文件夹 pastest.pass 内,

  • ** 生成pkpass**

在文件夹 pastest.pass 命令行目录内输入:

openssl smime -binary -sign -certfile WWDR.pem -signer passcertificate.pem -inkey passkey.pem -inmanifest.json -outsignature -outform DER -passin pass:12345

成功以后看输入内容可知会生成一个** signature ** 文件,待会生成 pkpass 的时候会需要。继续输入:

zip -r freehugcoupon.pkpass manifest.json pass.json signature [email protected] [email protected]

至此一个命名为 ** freehugcoupon.pkpass ** .pkpass文件就生成了,当然名字可以自定义

5. .pkpass 成功

在文件夹内点击刚刚生成的 ** freehugcoupon.pkpass ** 会看到结果为

iOS 添加 .pkpass 到 Wallet, 与测试代码_第11张图片

哈哈大功告成

** 你可查看本文生成的. pkpass 所有文件 和 使用下载的苹果 passes 资源 在Xcode Project 中的 代码示例 **

( 1: 如果点击 freehugcoupon.pkpass 无结果不能打开,表明有的步骤错了,看看是哪一步有问题; 2: 如果用的是Raywenderlich 的 pass.json 文件可能会有错误,我试了几次都打不开,文件签名之类的也都OK,后来直接用苹果的coupon 内的 pass.json 才行的)

你可能感兴趣的:(iOS 添加 .pkpass 到 Wallet, 与测试代码)