//聯(lián)系人:石虎QQ: 1224614774昵稱:嗡嘛呢叭咪哄
·內(nèi)置模式
·服務(wù)器模式
內(nèi)置模式的流程:
app從app store 獲取產(chǎn)品信息
用戶選擇需要購買的產(chǎn)品
app發(fā)送支付請求到AppStore
AppStore處理支付請求,返回transaction信息
app將購買的內(nèi)容展示給用戶
服務(wù)器模式的流程:
app從服務(wù)器獲取產(chǎn)品標(biāo)識列表
app從app store 獲取產(chǎn)品信息
用戶選擇需要購買的產(chǎn)品
app 發(fā)送支付請求到AppStore
AppStore處理支付請求,返回transaction信息
app將 transaction receipt 發(fā)送到服務(wù)器
服務(wù)器收到收據(jù)后發(fā)送到app stroe驗(yàn)證收據(jù)的有效性
app store 返回收據(jù)的驗(yàn)證結(jié)果
根據(jù)app store 返回的結(jié)果決定用戶是否購買成功
上述兩種模式的不同之處主要在于:交易的收據(jù)驗(yàn)證,內(nèi)建模式?jīng)]有專門去驗(yàn)證交易收據(jù)嫂用,而服務(wù)器模式會(huì)使用獨(dú)立的服務(wù)器去驗(yàn)證交易收據(jù)。內(nèi)建模式簡單快捷吨枉,但容易被破解。服務(wù)器模式流程相對復(fù)雜晤揣,但相對安全
開發(fā)之初刀森,蘋果官方就很負(fù)責(zé)的告知:我們的服務(wù)器不穩(wěn)定。真正開發(fā)之后俏讹,發(fā)現(xiàn)蘋果方果然是很負(fù)責(zé)的,不僅是不穩(wěn)定畜吊,而且足夠慢泽疆。app store server驗(yàn)證一個(gè)收據(jù)需要3-6s時(shí)間
用戶能否忍受3-6s的等待時(shí)間
如果app store server 宕機(jī),如何確保成功付費(fèi)的用戶能夠得到正常服務(wù)玲献。
對于第一個(gè)問題殉疼,我們有理由相信用戶完全無法忍受,所以采用異步驗(yàn)證的方式捌年,服務(wù)器收到客戶端的請求后瓢娜,就將請求放到MCQ中去處理。
對于第二個(gè)問題延窜,由于蘋果人員很負(fù)責(zé)人的告知:我們的服務(wù)器不穩(wěn)定恋腕,所以不排除收據(jù)驗(yàn)證超時(shí)的情況。對于驗(yàn)證超時(shí)的收據(jù)逆瑞,保存到數(shù)據(jù)庫中并標(biāo)記為驗(yàn)證超時(shí)荠藤,定時(shí)任務(wù)每隔一定的時(shí)間去app store驗(yàn)證,確保能夠獲取收據(jù)的驗(yàn)證結(jié)果获高。
在開發(fā)過程中哈肖,需要測試應(yīng)用是否能夠正常的進(jìn)行支付,但是又不能進(jìn)行實(shí)際的支付念秧,因此需要使用蘋果提供的sandbox Store測試淤井。Store Kit不能在iOS模擬器中使用,測試Store必須在真機(jī)上進(jìn)行
在sandbox中驗(yàn)證receipt:
https://sandbox.itunes.apple.com/verifyReceipt
在生產(chǎn)環(huán)境中驗(yàn)證receipt:
https://buy.itunes.apple.com/verifyReceipt
在實(shí)際開發(fā)過程中摊趾,服務(wù)器端通過issandbox字段標(biāo)識客戶端傳遞的收據(jù)是沙盒環(huán)境中的收據(jù)還是生產(chǎn)環(huán)境中的收據(jù)币狠。在提交蘋果審核前,沙盒測試均無問題砾层。提交蘋果審核后漩绵,被告知購買失敗,審核未通過肛炮。通過查詢?nèi)罩景l(fā)現(xiàn)止吐,客戶端發(fā)送的交易收據(jù)為沙盒收據(jù),但是issandbox字段卻標(biāo)識為生產(chǎn)環(huán)境侨糟。
結(jié)論:
蘋果審核app時(shí)碍扔,仍然在沙盒環(huán)境下測試。但是客戶端同事在app提交蘋果審核時(shí)秕重,將issandbox字段寫死不同,設(shè)置為生產(chǎn)環(huán)境。這樣就導(dǎo)致沙盒收據(jù)發(fā)送到https://buy.itunes.apple.com/verifyReceipt去驗(yàn)證溶耘。
那么如何自動(dòng)的識別收據(jù)是否是sandbox receipt呢套鹅?
識別沙盒環(huán)境下收據(jù)的方法有兩種:
1.根據(jù)收據(jù)字段 environment = sandbox。
2.根據(jù)收據(jù)驗(yàn)證接口返回的狀態(tài)碼,如果status=21007汰具,則表示當(dāng)前的收據(jù)為沙盒環(huán)境下收據(jù)進(jìn)行驗(yàn)證卓鹿。
蘋果反饋的狀態(tài)碼
·21000App Store無法讀取你提供的JSON數(shù)據(jù)
·21002 收據(jù)數(shù)據(jù)不符合格式
·21003 收據(jù)無法被驗(yàn)證
·21004 你提供的共享密鑰和賬戶的共享密鑰不一致
·21005 收據(jù)服務(wù)器當(dāng)前不可用
·21006 收據(jù)是有效的,但訂閱服務(wù)已經(jīng)過期留荔。當(dāng)收到這個(gè)信息時(shí)吟孙,解碼后的收據(jù)信息也包含在返回內(nèi)容中
·21007 收據(jù)信息是測試用(sandbox),但卻被發(fā)送到產(chǎn)品環(huán)境中驗(yàn)證
·21008 收據(jù)信息是產(chǎn)品環(huán)境中使用聚蝶,但卻被發(fā)送到測試環(huán)境中驗(yàn)證
先生產(chǎn)驗(yàn)證后測試驗(yàn)證杰妓,可以避免來回切換接口的麻煩。測試驗(yàn)證只要用你自己申請的測試appid的時(shí)候才會(huì)用到碘勉,用戶不會(huì)擁有測試appid巷挥,所以不會(huì)走到測試驗(yàn)證這一步。即使生產(chǎn)驗(yàn)證出錯(cuò)验靡,應(yīng)該也不回返回21007狀態(tài)嗎倍宾。測試驗(yàn)證通過的用戶名雏节,和充值金額最好用數(shù)據(jù)庫記錄下來,方便公司資金核對高职。