我成功创建了一个通行证,它在我的 MacBook Safari 浏览器上正常打开,但是,当我尝试在我的物理 iPhone 或模拟器上打开它时,看起来 safari 无法识别通行证文件。
在 Mac Safari 上它显示如下: 当我在 Mac Safari 上下载通行证时的外观快照
在 iPhone 或 Simulator Safari 上,它显示: Sanpshot of it look on iPhone or Simulator Safari
我检查了捆绑包中是否包含所有图像资产,并使用了正确的 mime 类型(application/vnd.apple.pkpass),我什至将其添加到了我的服务器 mime.types conf 文件中。
为了解决这个奇怪的问题,还有其他需要检查的东西。
请求和响应标头:
URL: http://hayak.localhost/api/request/pass?locale=en-us&uuid=eb5b16db-2a33-4bc8-b3e6-b5dcc5240dfd
Request GET /api/request/pass HTTP/1.1
Accept: */*
Accept-Encoding: gzip, deflate
Accept-Language: en-us
Host: hayak.localhost
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_6) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/14.0.2 Safari/605.1.15 Connection: keep-alive Referer: http://hayak.localhost/request/vw
Response HTTP/1.1 200 OK
Content-Type: application/vnd.apple.pkpass
Keep-Alive: timeout=5, max=100
Pragma: no-cache
Content-Disposition: attachment; filename=CP_3_731585792.pkpass
Last-Modified: Tue, 02 Feb 2021 16:00:53 GMT
Cache-Control: public
Date: Wed, 03 Feb 2021 15:18:46 GMT
Content-Length: 302319
Connection: Keep-Alive
Accept-Ranges: bytes
Vary: Authorization
X-Powered-By: PHP/7.4.12 Server: Apache/2.4.46 (Unix) OpenSSL/1.0.2u PHP/7.4.12 mod_wsgi/3.5 Python/2.7.13 mod_fastcgi/mod_fastcgi-SNAP-0910052141 mod_perl/2.0.11 Perl/v5.30.1 Content-Transfer-Encoding: binary X-RateLimit-Limit: 60 X-RateLimit-Remaining: 52 Content-Description: File Transfer
JS(Vue)代码:
methods:
{
forceFileDownload(response){
const url = window.URL.createObjectURL(new Blob([response.data]))
const link = document.createElement('a')
link.href = url
link.setAttribute('download', 'pass.pkpass') //or any other extension
document.body.appendChild(link)
link.click()
},
downloadWithAxios(){
axios({
method: 'get',
url: '/request/pass',
params: {locale: this.$i18n.locale, uuid: this.$store.state.app.request.uuid},
responseType: 'arraybuffer'
})
.then(response => {
this.forceFileDownload(response)
})
.catch(() => console.log('error occured'))
}
}
PHP代码:
$path = storage_path().'/passgenerator/'.$pass_identifier.'.pkpass';
return response()->download($path, $pass_identifier.'.pkpass',
[
'Content-Transfer-Encoding' => 'binary',
'Content-Description' => 'File Transfer',
'Content-Disposition' => 'attachment; filename=pass.pkpass',
'Content-length' => strlen($pkpass),
'Content-Type' => PassGenerator::getPassMimeType(),
'Pragma' => 'no-cache',
]);