为什么一些 Apple Wallet 生成的 QR 码包含这么多额外的垃圾?

Why do some Apple Wallet generated QR codes contain so much additional junk?

我正在尝试为 SMART 健康卡二维码创建 Apple 钱包通行证。

QR 码的内容类似于以下虚拟数据,它似乎是用中等纠错级别生成的:

shc:/567629095243206034602924374044603122295953265460346029254077280433602870286471674522280928613331456437653141590640220306450459085643550341424541364037063665417137241236380304375622046737407532323925433443326057360106452931531270742428395038692212766728666731266342087422573776302062041022437658685343255820002167287607585708105505622752282407670809680507692361773323356634342439664440596761410443377667202663224433674530596175400038397052612140292974753658337372662132066669047253044469405210524536242721550377673434280323045475690310233670562227414567090555653507636250537239522776211205312561442568282012726838630039087127042463716936535535602928393065580072763158437500341209546904210458383257586630101033123422114008776058732325243477645920113037325929083272452732223707055550412927584543582550667760036577724025621136525340592771740903663844771261692077697211447057562509437029626707254539002011763240720310114260256672645965627243654061066553770056003044082967606162724306592273682223412466107335331229606157521057357572327529693965670332063208596309543400076452696835713027450728663529345234666377297208583525543653527774072234735706452828641140633528387577054371703966706421520708254156041170353656054471407636552612616834377244090406554327122559623453686207006139712936404138601156656945315611255669116044703333731263580306106975715411702932060511012768634011703371553353213365032550756476005853005224547339310064671161682376335069647622323339523133724171327531702738363650063527592633763908656123314363227707566731311074

使用大多数标准 QR 代码生成器,这将给出以下(正确的,预期的)QR 代码。

在我的 pass.json 文件中,我有以下二维码片段:

*snip* "barcode":{"message":"shc:\/567629095243206034602924374044603122295953265460346029254077280433602870286471674522280928613331456437653141590640220306450459085643550341424541364037063665417137241236380304375622046737407532323925433443326057360106452931531270742428395038692212766728666731266342087422573776302062041022437658685343255820002167287607585708105505622752282407670809680507692361773323356634342439664440596761410443377667202663224433674530596175400038397052612140292974753658337372662132066669047253044469405210524536242721550377673434280323045475690310233670562227414567090555653507636250537239522776211205312561442568282012726838630039087127042463716936535535602928393065580072763158437500341209546904210458383257586630101033123422114008776058732325243477645920113037325929083272452732223707055550412927584543582550667760036577724025621136525340592771740903663844771261692077697211447057562509437029626707254539002011763240720310114260256672645965627243654061066553770056003044082967606162724306592273682223412466107335331229606157521057357572327529693965670332063208596309543400076452696835713027450728663529345234666377297208583525543653527774072234735706452828641140633528387577054371703966706421520708254156041170353656054471407636552612616834377244090406554327122559623453686207006139712936404138601156656945315611255669116044703333731263580306106975715411702932060511012768634011703371553353213365032550756476005853005224547339310064671161682376335069647622323339523133724171327531702738363650063527592633763908656123314363227707566731311074","format":"PKBarcodeFormatQR","messageEncoding":"iso-8859-1"} *snip*

将此通行证添加到 Apple Wallet 后,我​​会在 Wallet 应用程序中看到以下二维码:

从技术上讲,这似乎确实对相同的数据进行了编码。然而,由于 Apple Wallet pass 中的二维码非常小,而且代码非常密集,充满了不必要的垃圾,我没有多少运气让任何二维码阅读器从我的设备屏幕上实际读取它,就像 Passbook pass 一样通常会被使用。

我没有找到任何方法来设置Passbook中的纠错级别,但是当我尝试使用不同的纠错级别生成QR码进行检查时,即使是最高的纠错级别也不会生成QR码就像我的 Apple Wallet 制作的那个。考虑到第二个代码右侧 2/3 的重复性,我的猜测是它是空填充,但我不确定。

这是怎么回事,我该如何解决才能使我的通行证包含第一个示例中的 QR 码,而没有所有其他垃圾?如果无法修复,有没有办法让我在通行证上嵌入正确的二维码图像,但显示得足够大以便扫描?

========

更新:仅删除 shc:/ header 似乎生成了一个看起来更接近预期的二维码;虽然这个 header 是必要的,所以这不是解决方案,但我猜这意味着钱包很难有效地对其进行编码。

Apple Wallet 中的代码看起来非常不同,因为它使用低效的方法对相关数据进行编码。

Apple Wallet (PassKit) 可能使用 CIQRCodeGenerator Core Image 过滤器来生成二维码。过滤器根据给定的数据自动选择最合适的编码模式,在本例中它选择了binary/bytes模式。因为绝大多数 SMART Health Cards 数据都是用数字表示的(每个数字只携带 ~3.3 位信息),所以将其编码为 binary 模式(8 bits/character)效率很低。这就是为什么二维码看起来更密集但重复的原因。

当您删除 shc:/ 时,生成的 QR 码似乎更“正确”,因为过滤器随后能够以纯 数字 模式进行编码。有趣的是,如果您将 shc:/ 更改为全部大写,过滤器将以 alphanumeric 模式编码,这仍然比 binary 更有效此数据的模式。

其他一些 QR 码生成器可以更好地处理这个问题,因为它们能够分段数据以获得最大效率。事实上,框架协议 described as muchbinary mode for shc:/ and the optional chunk prefix, then numeric mode for剩下的

不幸的是,似乎没有办法在 Apple Wallet 中解决这个问题,至少从 iOS14 开始是这样。Core Image 过滤器不够灵活,无法使用多种模式对数据进行编码,并且 PassKit 本身还有很多不足之处。

iOS 15.0+ 已修复此问题。对于 shc:/ content 它具有较低级别的纠错:M 现在。

我希望 Apple 将其移植到 iOS 14 或 13。