国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統(tǒng) > iOS > 正文

微信支付開發(fā)IOS圖文教程案例

2020-07-26 03:23:21
字體:
供稿:網(wǎng)友

前言:下面介紹微信支付的開發(fā)流程的細(xì)節(jié),圖文并茂,你可以按照我的隨筆流程過一遍代碼。包你也學(xué)會(huì)了微信支付。而且支付也是面試常問的內(nèi)容。

    

正文:

1、首先在開始使用微信支付之前,有一些東西是開發(fā)者必須要知道的,打開下面鏈接:

  https://pay.weixin.qq.com/wiki/doc/api/app.php?chapter=3_1  

  然后可以看到下面的頁面,這個(gè)就是微信支付商戶平臺(tái)的開發(fā)文檔,很多東西是可以查閱和了解的,在開發(fā)使用微信SDK支付功能的時(shí)候,遇到了問題也可以到這找找相關(guān)須知信息:

  然后,還要告訴讀者,點(diǎn)擊這個(gè)開發(fā)文檔中的" 支付賬戶>支付賬戶 ",然后滾動(dòng)當(dāng)前頁面到最下面可以看到關(guān)于APPID:

  注意:這個(gè)APPID是開發(fā)中使用微信支付必須要用的東西,而這個(gè)APPID也只有商戶通過在該微信支付平臺(tái)注冊(cè),花個(gè)300元,填寫很多相關(guān)重要信息,還要上傳營業(yè)執(zhí)照等必要手續(xù),才能獲取的APPID。

  而商業(yè)app應(yīng)用程序,在客戶使用app微信消費(fèi),程序會(huì)根據(jù)這個(gè)唯一的APPID,查找到商戶,然后把消費(fèi)者的金額數(shù)傳遞到商戶的賬戶里。

  對(duì)開發(fā)者的福利:對(duì)于開發(fā)者,微信支付平臺(tái)提供了測(cè)試的Demo,也在Demo源碼中提供了有用的用于測(cè)試代碼的APPID。這樣開發(fā)者就除去了花個(gè)300元買個(gè)APPID的必要性。

2、為了讀者能夠更便利以及更針對(duì)性的學(xué)習(xí)這個(gè)微信SDK的使用過程,本人就建立一個(gè)普通的工程,直接在上面簡易的使用微信SDK,并完成微信支付。

  https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=11_1

  點(diǎn)進(jìn)去之后下載SDK,另外也要把Demo下載下來,可以帶你參考學(xué)習(xí)源碼的使用,也可以留著以后進(jìn)一步的探究:

  在新建的工程里,我們把下載的SDK拖進(jìn)去,下載的SDK文件中有五個(gè)文件,那個(gè)read_me.txt可以不用留著工程里,隨你喜歡,但是可以打開閱讀里面的提示信息:

  

  我們先打開read_me.txt文件,其實(shí)里面就是講了最近幾個(gè)版本的更新中解決的問題,以及使用該SDK的注意事項(xiàng),紅色框框起來的部分我在后面的操作中都會(huì)用上,SO這個(gè)read_me文件很重要的哦。

3、好,我們就按照read_me.txt做一下必須要做的流程:

  Xcode 7版本之后需要導(dǎo)入一下框架和鏈接庫:

    

  如果是XCode 7之前,估計(jì)還需要手動(dòng)導(dǎo)入Foundation.framework、UIKit.framework等框架。

  接著,按照read_me.txt的提示,我們把那段plist代碼拷貝到info.plist文件中:

<key>LSApplicationQueriesSchemes</key><array><string>weixin</string></array><key>NSAppTransportSecurity</key><dict><key>NSAllowsArbitraryLoads</key><true/></dict>

  然后將info.plist文件切換為Property list顯示視圖,你就會(huì)看到多了兩項(xiàng):

  App Transport Security Settings是XCode7以后就需要開發(fā)中手動(dòng)添加設(shè)置的,因?yàn)閕OS9默認(rèn)限制了http協(xié)議的訪問。

  LSApplicationQueriesSchemes是可以將要使用的URL Schemes列為白名單,這樣當(dāng)前應(yīng)用可以使用微信的相關(guān)能力(分享、收藏、支付、登錄等)。

  最后還有一個(gè)操作哦,將微信支付要用到的APPID設(shè)置為URL Schemes [英 skiːm]。

4、好,我們可以開始敲代碼了:

  我們可以打開微信支付平臺(tái)下載的Demo程序,可以在它的AppDelegate的源碼中找到測(cè)試用的APPID:

  然后回到自己建立的工程中,寫下了微信支付的流程:

  既然要注冊(cè)微信,那么我們先到微信SDK的頭文件中查看一下,發(fā)現(xiàn)只提供了兩個(gè)注冊(cè)方法,注釋也寫的很清楚:

  然后我們導(dǎo)入這個(gè)頭文件之后,直接根據(jù)已經(jīng)有的APPID進(jìn)行注冊(cè):

  好,其實(shí)步驟:1、導(dǎo)入微信支付SDK,注冊(cè)微信支付。然后2、設(shè)置微信APPID為URL Schemes前面已經(jīng)做好了。

  然后我們需要進(jìn)行3、發(fā)起支付,調(diào)其微信支付,在這之前,我們直接看看微信官方提供給我們的Demo:

  最后我們找到了Demo中完整的可以直接用的這部分發(fā)起微信支付的源碼:

  將這段直接拷貝到我的工程中,有那么一點(diǎn)經(jīng)驗(yàn)的開發(fā)者就會(huì)注意到一些,比如Demo源碼使用了MRC的autorelease,你可以手動(dòng)去掉,類方法可以換成實(shí)例方法,根據(jù)你的實(shí)際項(xiàng)目開發(fā)需求:

- (NSString *)jumpToBizPay {//============================================================ // V3&V4支付流程實(shí)現(xiàn) // 注意:參數(shù)配置請(qǐng)查看服務(wù)器端Demo // 更新時(shí)間:2015年11月20日 //============================================================ NSString *urlString = @"http://wxpay.weixin.qq.com/pub_v2/app/app_pay.php?plat=ios"; //解析服務(wù)端返回json數(shù)據(jù) NSError *error; //加載一個(gè)NSURL對(duì)象 NSURLRequest *request = [NSURLRequest requestWithURL:[NSURL URLWithString:urlString]]; //將請(qǐng)求的url數(shù)據(jù)放到NSData對(duì)象中 NSData *response = [NSURLConnection sendSynchronousRequest:request returningResponse:nil error:nil]; if ( response != nil) { NSMutableDictionary *dict = NULL; //IOS5自帶解析類NSJSONSerialization從response中解析出數(shù)據(jù)放到字典中 dict = [NSJSONSerialization JSONObjectWithData:response options:NSJSONReadingMutableLeaves error:&error];  NSLog(@"url:%@",urlString); if(dict != nil){ NSMutableString *retcode = [dict objectForKey:@"retcode"]; if (retcode.intValue == 0){ NSMutableString *stamp = [dict objectForKey:@"timestamp"];  //調(diào)起微信支付 PayReq* req = [[PayReq alloc] init]; req.partnerId = [dict objectForKey:@"partnerid"]; req.prepayId = [dict objectForKey:@"prepayid"]; req.nonceStr = [dict objectForKey:@"noncestr"]; req.timeStamp = stamp.intValue; req.package = [dict objectForKey:@"package"]; req.sign = [dict objectForKey:@"sign"]; [WXApi sendReq:req]; //日志輸出 NSLog(@"appid=%@/npartid=%@/nprepayid=%@/nnoncestr=%@/ntimestamp=%ld/npackage=%@/nsign=%@",[dict objectForKey:@"appid"],req.partnerId,req.prepayId,req.nonceStr,(long)req.timeStamp,req.package,req.sign ); return @""; }else{ return [dict objectForKey:@"retmsg"]; } }else{ return @"服務(wù)器返回錯(cuò)誤,未獲取到j(luò)son對(duì)象"; } }else{ return @"服務(wù)器返回錯(cuò)誤"; }}

  哦,對(duì)了,還有一個(gè)很簡單但很必要的操作忘記展示出來了:

  進(jìn)一步,我們?cè)谖⑿诺腟DK源碼頭文件中,可以找到兩個(gè)很有用的方法,你也可以在微信支付平臺(tái)打開開發(fā)者文檔找到這兩個(gè)方法的介紹:

  然后我將其運(yùn)用在我的工程中

  好,就這樣,步驟:3、發(fā)起微信支付,調(diào)起微信 到這里就完成了。

  最后還需要做的就是,處理返回微信支付返回信息,使用了微信知否功能,不管是支付成功和失敗,甚至還是用戶自己取消支付,都會(huì)需要返回當(dāng)前應(yīng)用,并返回相關(guān)的信息。

  這里就需要用到微信SDK的處理返回信息的代理協(xié)議和代理方法了:

  在微信SDK的頭文件中,我們可以找到protocol協(xié)議:

  好,我們也官方Demo中看看它是如何使用的:

  而我們只需要使用下面紅色框框起來的部分代碼,直接拷貝拿來使用:

  回到我的簡易工程中,直接粘貼在里面用:

  那么這里面的返回信息中主要就有兩個(gè)東西:resp.errCode錯(cuò)誤碼 和 resp.errStr錯(cuò)誤原因,這兩個(gè)東西在實(shí)際開發(fā)中經(jīng)常遇到,所以也是面試會(huì)問到的一個(gè)細(xì)節(jié)。

  接著你可以通過點(diǎn)進(jìn)連接:https://pay.weixin.qq.com/wiki/doc/api/app.php?chapter=8_5 可以在官方開發(fā)文檔中找到:

  然后,根據(jù)實(shí)際開發(fā)需求,我們可能還需要回傳微信app的相關(guān)信息:

  在當(dāng)前AppDelegate.m文件添加一個(gè)代理方法:

5、到這里,就完成了整個(gè)微信支付的使用流程,下面可以用你的真機(jī)進(jìn)行測(cè)試了,因?yàn)槟M器不好安裝微信。

最后補(bǔ)充無意發(fā)現(xiàn)的大神github上也有微信講解和源碼,大家也可以學(xué)習(xí)學(xué)習(xí):

https://github.com/renzifeng/WXPay

只不過,對(duì)于沒有花99美刀買了開發(fā)者賬戶,該github上下載的源碼估計(jì)不能直接用真機(jī)測(cè)試,原因是上面的項(xiàng)目實(shí)例創(chuàng)建的時(shí)間比較早,那時(shí)候XCode在沒有開發(fā)者賬戶的時(shí)候,不支持真機(jī)測(cè)試。

還有一個(gè)大牛寫的微信支付的博文,而且就是2016年1月20號(hào)寫的呢:

http://www.cnblogs.com/jys509/p/5130990.html

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 巨鹿县| 河北省| 安化县| 河北区| 湾仔区| 若羌县| 兴国县| 璧山县| 凌源市| 华亭县| 治多县| 资阳市| 莱阳市| 满城县| 丰原市| 蓬莱市| 沂南县| 汨罗市| 法库县| 诏安县| 东阿县| 冀州市| 长武县| 星座| 衡山县| 如皋市| 平谷区| 丰顺县| 佛学| 兴和县| 汝城县| 玉龙| 维西| 福海县| 东安县| 鹤山市| 桓台县| 阜新| 张北县| 尉犁县| 磴口县|