iOS 內(nèi)購(gòu)支付兩種模式

·內(nèi)置模式
·服務(wù)器模式

內(nèi)置模式的流程:

  1. app從app store 獲取產(chǎn)品信息
  2. 用戶選擇需要購(gòu)買的產(chǎn)品
  3. app發(fā)送支付請(qǐng)求到AppStore
  4. AppStore處理支付請(qǐng)求,返回transaction信息
  5. app將購(gòu)買的內(nèi)容展示給用戶

服務(wù)器模式的流程:

  1. app從服務(wù)器獲取產(chǎn)品標(biāo)識(shí)列表
  2. app從app store 獲取產(chǎn)品信息
  3. 用戶選擇需要購(gòu)買的產(chǎn)品
  4. app 發(fā)送支付請(qǐng)求到AppStore
  5. AppStore處理支付請(qǐng)求,返回transaction信息
  6. app將 transaction receipt 發(fā)送到服務(wù)器
  7. 服務(wù)器收到收據(jù)后發(fā)送到app stroe驗(yàn)證收據(jù)的有效性
  8. app store 返回收據(jù)的驗(yàn)證結(jié)果
  9. 根據(jù)app store 返回的結(jié)果決定用戶是否購(gòu)買成功

上述兩種模式的不同之處主要在于:交易的收據(jù)驗(yàn)證拘领,內(nèi)建模式?jīng)]有專門去驗(yàn)證交易收據(jù)樱调,而服務(wù)器模式會(huì)使用獨(dú)立的服務(wù)器去驗(yàn)證交易收據(jù)本涕。內(nèi)建模式簡(jiǎn)單快捷,但容易被破解菩颖。服務(wù)器模式流程相對(duì)復(fù)雜晦闰,但相對(duì)安全

開發(fā)之初,蘋果官方就很負(fù)責(zé)的告知:我們的服務(wù)器不穩(wěn)定呻右。真正開發(fā)之后,發(fā)現(xiàn)蘋果方果然是很負(fù)責(zé)的眉撵,不僅是不穩(wěn)定落塑,而且足夠慢。app store server驗(yàn)證一個(gè)收據(jù)需要3-6s時(shí)間

  1. 用戶能否忍受3-6s的等待時(shí)間
  2. 如果app store server 宕機(jī)污朽,如何確保成功付費(fèi)的用戶能夠得到正常服務(wù)龙考。

對(duì)于第一個(gè)問(wèn)題炎功,我們有理由相信用戶完全無(wú)法忍受,所以采用異步驗(yàn)證的方式蛇损,服務(wù)器收到客戶端的請(qǐng)求后,就將請(qǐng)求放到MCQ中去處理。
對(duì)于第二個(gè)問(wèn)題,由于蘋果人員很負(fù)責(zé)人的告知:我們的服務(wù)器不穩(wěn)定贫堰,所以不排除收據(jù)驗(yàn)證超時(shí)的情況缨该。對(duì)于驗(yàn)證超時(shí)的收據(jù)贰拿,保存到數(shù)據(jù)庫(kù)中并標(biāo)記為驗(yàn)證超時(shí),定時(shí)任務(wù)每隔一定的時(shí)間去app store驗(yàn)證妙真,確保能夠獲取收據(jù)的驗(yàn)證結(jié)果荚守。

在開發(fā)過(guò)程中,需要測(cè)試應(yīng)用是否能夠正常的進(jìn)行支付锈候,但是又不能進(jìn)行實(shí)際的支付缩功,因此需要使用蘋果提供的sandbox Store測(cè)試都办。Store Kit不能在iOS模擬器中使用虑稼,測(cè)試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ā)過(guò)程中蛛倦,服務(wù)器端通過(guò)issandbox字段標(biāo)識(shí)客戶端傳遞的收據(jù)是沙盒環(huán)境中的收據(jù)還是生產(chǎn)環(huán)境中的收據(jù)啦桌。在提交蘋果審核前,沙盒測(cè)試均無(wú)問(wèn)題且改。提交蘋果審核后板驳,被告知購(gòu)買失敗,審核未通過(guò)慨蓝。通過(guò)查詢?nèi)罩景l(fā)現(xiàn)端幼,客戶端發(fā)送的交易收據(jù)為沙盒收據(jù),但是issandbox字段卻標(biāo)識(shí)為生產(chǎn)環(huán)境此熬。

結(jié)論:
蘋果審核app時(shí)滑进,仍然在沙盒環(huán)境下測(cè)試。但是客戶端同事在app提交蘋果審核時(shí)峡碉,將issandbox字段寫死驮审,設(shè)置為生產(chǎn)環(huán)境。這樣就導(dǎo)致沙盒收據(jù)發(fā)送到https://buy.itunes.apple.com/verifyReceipt去驗(yàn)證地来。
那么如何自動(dòng)的識(shí)別收據(jù)是否是sandbox receipt呢熙掺?

識(shí)別沙盒環(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無(wú)法讀取你提供的JSON數(shù)據(jù)
·21002 收據(jù)數(shù)據(jù)不符合格式
·21003 收據(jù)無(wú)法被驗(yàn)證
·21004 你提供的共享密鑰和賬戶的共享密鑰不一致
·21005 收據(jù)服務(wù)器當(dāng)前不可用
·21006 收據(jù)是有效的试浙,但訂閱服務(wù)已經(jīng)過(guò)期寞蚌。當(dāng)收到這個(gè)信息時(shí),解碼后的收據(jù)信息也包含在返回內(nèi)容中
·21007 收據(jù)信息是測(cè)試用(sandbox)壹哺,但卻被發(fā)送到產(chǎn)品環(huán)境中驗(yàn)證
·21008 收據(jù)信息是產(chǎn)品環(huán)境中使用艘刚,但卻被發(fā)送到測(cè)試環(huán)境中驗(yàn)證

先生產(chǎn)驗(yàn)證后測(cè)試驗(yàn)證昔脯,可以避免來(lái)回切換接口的麻煩。測(cè)試驗(yàn)證只要用你自己申請(qǐng)的測(cè)試appid的時(shí)候才會(huì)用到隧饼,用戶不會(huì)擁有測(cè)試appid静陈,所以不會(huì)走到測(cè)試驗(yàn)證這一步。即使生產(chǎn)驗(yàn)證出錯(cuò)鲸拥,應(yīng)該也不回返回21007狀態(tài)嗎刑赶。測(cè)試驗(yàn)證通過(guò)的用戶名,和充值金額最好用數(shù)據(jù)庫(kù)記錄下來(lái)金踪,方便公司資金核對(duì)牵敷。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末枷餐,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌屋剑,老刑警劉巖惊暴,帶你破解...
    沈念sama閱讀 211,561評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件辽话,死亡現(xiàn)場(chǎng)離奇詭異卫病,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)益咬,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,218評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門幽告,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)裆甩,“玉大人,你說(shuō)我怎么就攤上這事冻河≤运В” “怎么了?”我有些...
    開封第一講書人閱讀 157,162評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵擂错,是天一觀的道長(zhǎng)樱蛤。 經(jīng)常有香客問(wèn)我刹悴,道長(zhǎng),這世上最難降的妖魔是什么土匀? 我笑而不...
    開封第一講書人閱讀 56,470評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮证杭,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘镇饺。我一直安慰自己送讲,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,550評(píng)論 6 385
  • 文/花漫 我一把揭開白布监右。 她就那樣靜靜地躺著异希,像睡著了一般。 火紅的嫁衣襯著肌膚如雪称簿。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,806評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音券册,去河邊找鬼。 笑死航邢,一個(gè)胖子當(dāng)著我的面吹牛骄蝇,可吹牛的內(nèi)容都是我干的九火。 我是一名探鬼主播,決...
    沈念sama閱讀 38,951評(píng)論 3 407
  • 文/蒼蘭香墨 我猛地睜開眼勒极,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼虑鼎!你這毒婦竟也來(lái)了键痛?” 一聲冷哼從身側(cè)響起匾七,我...
    開封第一講書人閱讀 37,712評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤昨忆,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后席里,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體痢缎,經(jīng)...
    沈念sama閱讀 44,166評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡独旷,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,510評(píng)論 2 327
  • 正文 我和宋清朗相戀三年寥裂,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片麻养。...
    茶點(diǎn)故事閱讀 38,643評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡鳖昌,死狀恐怖低飒,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情糕档,我是刑警寧澤拌喉,帶...
    沈念sama閱讀 34,306評(píng)論 4 330
  • 正文 年R本政府宣布尿背,位于F島的核電站,受9級(jí)特大地震影響田藐,放射性物質(zhì)發(fā)生泄漏售躁。R本人自食惡果不足惜茴晋,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,930評(píng)論 3 313
  • 文/蒙蒙 一陪捷、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧诺擅,春花似錦市袖、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,745評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至撮执,卻和暖如春微峰,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背抒钱。 一陣腳步聲響...
    開封第一講書人閱讀 31,983評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工蜓肆, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人仗扬。 一個(gè)月前我還...
    沈念sama閱讀 46,351評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像蕾额,于是被迫代替她去往敵國(guó)和親早芭。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,509評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容