APP相比較于WAP和WEB纪吮,最大的區(qū)別就是沒(méi)有服務(wù)端的同步回應(yīng)了锡垄,因?yàn)槭窃贏PP上付的,所有同步回應(yīng)是在APP上的客戶(hù)端的餐曼,這樣就意味著不能在本機(jī)做測(cè)試,只有部署在線上的服務(wù)才行(WEB方式的話同步的return是通過(guò)瀏覽器的redirect實(shí)現(xiàn)的鲜漩,于是可以寫(xiě)自己的本機(jī)IP源譬,瀏覽器跳轉(zhuǎn)就是我本地的服務(wù)了,這樣測(cè)試起來(lái)很簡(jiǎn)單)孕似。那格式什么的我就只能參考文檔了踩娘。文檔上是這么寫(xiě)的。
http://notify.java.jpxx.org/index.jsp?discount=0.00&payment_type=1&subject=測(cè)試&trade_no=2013082244524842&buyer_email=dlwdgl@gmail.com&gmt_create=2013-08-22 14:45:23?ify_type=trade_status_sync&quantity=1&out_trade_no=082215222612710&seller_id=2088501624816263?ify_time=2013-08-22 14:45:24&body=測(cè)試測(cè)試&trade_status=TRADE_SUCCESS&is_total_fee_adjust=N&total_fee=1.00&gmt_payment=2013-08-22 14:45:24&seller_email=xxx@alipay.com&price=1.00&buyer_id=2088602315385429?ify_id=64ce1b6ab92d00ede0ee56ade98fdf2f4c&use_coupon=N&sign_type=RSA&sign=1glihU9DPWee+UJ82u3+mw3Bdnr9u01at0M/xJnPsGuHh+JA5bk3zbWaoWhU6GmLab3dIM4JNdktTcEUI9/FBGhgfLO39BKX/eBCFQ3bXAmIZn4l26fiwoO613BptT44GTEtnPiQ6+tnLsGlVSrFZaLB9FVhrGfipH2SWJcnwYs=
URL參數(shù)喉祭,恩养渴。POST請(qǐng)求,恩泛烙。等等理卑,sign里面有+號(hào)!!+號(hào)!! 沒(méi)有URL Encode!! 我一邊咒罵支付寶傻逼,一邊寫(xiě)把等號(hào)替換為+的代碼... ...然后去上線運(yùn)行打log的時(shí)候我發(fā)現(xiàn)...次奧 有Encode的呀.... ....有Encode的呀... ...你這和文檔不一樣啊蔽氨。藐唠。帆疟。文檔明明這么寫(xiě)的啊。宇立。踪宠。
突然覺(jué)得自己傻逼了.... ....而且我感覺(jué)這個(gè)放在URL參數(shù)里導(dǎo)致文檔和實(shí)際不一樣,那干脆不如放在requestBody里好了泄伪,避免框架自己做encode decode殴蓬,多方便...
移動(dòng)端行為不一致
后來(lái)我覺(jué)得用異步不是很靠譜,于是讓移動(dòng)端把同步回應(yīng)的結(jié)果也發(fā)過(guò)來(lái)蟋滴,因?yàn)槲铱吹轿臋n上是這么寫(xiě)的:
ResultStatus={9000};memo={};result={partner="2088101568358171"&seller_id="xxx@alipay.com"&out_trade_no="0819145412-6177"&subject="測(cè)試"&body="測(cè)試測(cè)試"&total_fee="0.01"?ify_url="http://notify.msp.hk/notify.htm"&service="mobile.securitypay.pay"&payment_type="1"&_input_charset="utf-8"&it_b_pay="30m"&success="true"&sign_type="RSA"&sign="hkFZr+zE9499nuqDNLZEF7W75RFFPsly876QuRSeN8WMaUgcdR00IKy5ZyBJ4eldhoJ/2zghqrD4E2G2mNjs3aE+HCLiBXrPDNdLKCZgSOIqmv46TfPTEqopYfhs+o5fZzXxt34fwdrzN4mX6S13cr3UwmEV4L3Ffir/02RBVtU="}
(iOS和android類(lèi)似所以貼一份)
那個(gè)result里面包含的信息也可以給服務(wù)端進(jìn)行驗(yàn)簽染厅、更新表單等操作。
然后我后端實(shí)現(xiàn)好了津函,讓安卓和iOS傳回來(lái)肖粮,安卓一切正常,iOS驗(yàn)簽死活通不過(guò)尔苦,我就讓iOS把他在console里打印出來(lái)的內(nèi)容給我涩馆,我自己調(diào)試。發(fā)現(xiàn)還是不行允坚,我就懷疑是不是支付寶返回來(lái)的東西本身就是驗(yàn)簽驗(yàn)不過(guò)的啊... ...然后和iOS的同事調(diào)試了好久... ...最后一個(gè)一個(gè)字符和安卓的回應(yīng)比較過(guò)去.... ....發(fā)現(xiàn)
notify_time=2015-10-19+16:01:20
這個(gè)時(shí)間中間為毛是個(gè)+魂那,自己手動(dòng)改成空格之后就過(guò)了......是個(gè)+號(hào),說(shuō)明空格被encode了...但這是他console打出來(lái)和watch的時(shí)候就有的... ...我不知道是支付寶那邊弄的稠项,還是xcode的問(wèn)題涯雅,因?yàn)榘沧渴呛玫?.. ...iOS這邊的空格被encode了.... ....
以為這么就好了嘛?? 安卓試了有支付寶和沒(méi)支付寶APP的情況,返回內(nèi)容都是一樣的展运。很好活逆,測(cè)試通過(guò)。
然后iOS....在沒(méi)有支付寶APP的情況拗胜,使用支付寶SDK內(nèi)嵌的支付的情況...上面的返回?cái)?shù)據(jù)result是空的U岷颉!只有格ResultStatus埂软。讓iOS反復(fù)檢查锈遥,后來(lái)在網(wǎng)上找了下發(fā)現(xiàn) http://blog.sina.com.cn/s/blog_702e40a80101knln.html,
我的媽阿勘畔,對(duì)返回值作了改變迷殿,為啥文檔又沒(méi)說(shuō)明,讓我等苦逼的程序猿白白折磨了一兩天咖杂,情何以堪呢∥梅颍客氣的將我的想法提了給支付寶的技術(shù)支持诉字,回復(fù)說(shuō):不要太相信demo。
還是一樣的問(wèn)題,文檔沒(méi)說(shuō)壤圃!
文檔坑爹陵霉,demo坑爹,剩下的就是自己debug伍绳,看日志踊挠,做處理了。
哎冲杀,寫(xiě)文檔什么的還是得走心啊效床。
如果直接使用ios客戶(hù)端簽名無(wú)任何問(wèn)題,可以直接支付权谁,但是如果將需要簽名的字符串通過(guò)接口請(qǐng)求傳給java簽名就會(huì)出一個(gè)問(wèn)題剩檀,請(qǐng)求服務(wù)端簽名時(shí),我們可以直接將客戶(hù)端的order轉(zhuǎn)換成字符串傳過(guò)去旺芽,這樣在服務(wù)端就只需要調(diào)用一個(gè)簽名方法即可沪猴,下面我來(lái)說(shuō)下報(bào)的這個(gè)錯(cuò)-->ALI40247,網(wǎng)上找了關(guān)于這個(gè)錯(cuò)的原因, 對(duì)比了發(fā)現(xiàn)并不是這些原因?qū)е碌牟烧拢蟀l(fā)現(xiàn)是-->java的簽名與objective-c的簽名結(jié)果不一樣运嗜,都是使用的相同的加密串官方demo簽名方法,為什么出現(xiàn)簽名不一樣,最后發(fā)現(xiàn)雖然oc和java的簽名結(jié)果不一樣,但是有一個(gè)規(guī)律-->java中簽名的"/"符號(hào)在oc簽名中是用"%"號(hào)代替,然后java的rsa簽名結(jié)果都有一個(gè)"=",但是在ios中這個(gè)"="等于 "%3D"悯舟,開(kāi)始我說(shuō)了直接用ios 客戶(hù)端簽名是可以直接支付的担租,那么只要java返回的簽名與ios一樣就行了,雖然他們簽名結(jié)果不一樣图谷,但是現(xiàn)在發(fā)現(xiàn)一個(gè)固定的規(guī)律翩活,所以只需要將java服務(wù)端返回的簽名中的特殊符號(hào)替換成ios簽名中的特殊符號(hào)就行了