IOS開發--微信支付

前言:下面介紹微信支付的開發流程的細節,圖文並茂,你能夠按照個人隨筆流程過一遍代碼。包你也學會了微信支付。並且支付也是面試常問的內容。php

    

 

正文:html

 

一、首先在開始使用微信支付以前,有一些東西是開發者必需要知道的,打開下面連接:ios

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

  而後能夠看到下面的頁面,這個就是微信支付商戶平臺的開發文檔,不少東西是能夠查閱和了解的,在開發使用微信SDK支付功能的時候,遇到了問題也能夠到這找找相關須知信息:github

    

  而後,還要告訴讀者,點擊這個開發文檔中的" 支付帳戶>支付帳戶 ",而後滾動當前頁面到最下面能夠看到關於APPID:面試

    

  注意:這個APPID是開發中使用微信支付必需要用的東西,而這個APPID也只有商戶經過在該微信支付平臺註冊,花個300元,填寫不少相關重要信息,還要上傳營業執照等必要手續,才能獲取的APPID。json

  而商業app應用程序,在客戶使用app微信消費,程序會根據這個惟一的APPID,查找到商戶,而後把消費者的金額數傳遞到商戶的帳戶裏。api

  

  對開發者的福利:對於開發者,微信支付平臺提供了測試的Demo,也在Demo源碼中提供了有用的用於測試代碼的APPID。這樣開發者就除去了花個300元買個APPID的必要性。服務器

二、爲了讀者可以更便利以及更針對性的學習這個微信SDK的使用過程,本人就創建一個普通的工程,直接在上面簡易的使用微信SDK,並完成微信支付。微信

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

  點進去以後下載SDK,另外也要把Demo下載下來,能夠帶你參考學習源碼的使用,也能夠留着之後進一步的探究:

    

  在新建的工程裏,咱們把下載的SDK拖進去,下載的SDK文件中有五個文件,那個read_me.txt能夠不用留着工程裏,隨你喜歡,可是能夠打開閱讀裏面的提示信息:

    

  咱們先打開read_me.txt文件,其實裏面就是講了最近幾個版本的更新中解決的問題,以及使用該SDK的注意事項,紅色框框起來的部分我在後面的操做中都會用上,SO這個read_me文件很重要的哦。

    

三、好,咱們就按照read_me.txt作一下必需要作的流程:

  Xcode 7版本以後須要導入一下框架和連接庫:

    

  若是是XCode 7以前,估計還須要手動導入Foundation.framework、UIKit.framework等框架。

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

1 <key>LSApplicationQueriesSchemes</key>
2 <array>
3 <string>weixin</string>
4 </array>
5 <key>NSAppTransportSecurity</key>
6 <dict>
7 <key>NSAllowsArbitraryLoads</key>
8 <true/>
9 </dict>

  而後將info.plist文件切換爲Property list顯示視圖,你就會看到多了兩項:

    

  App Transport Security Settings是XCode7之後就須要開發中手動添加設置的,由於iOS9默認限制了http協議的訪問。

  LSApplicationQueriesSchemes是能夠將要使用的URL Schemes列爲白名單,這樣當前應用可使用微信的相關能力(分享、收藏、支付、登陸等)。

  最後還有一個操做哦,將微信支付要用到的APPID設置爲URL Schemes [英 skiːm]。

  

四、好,咱們能夠開始敲代碼了:

  咱們能夠打開微信支付平臺下載的Demo程序,能夠在它的AppDelegate的源碼中找到測試用的APPID:

  

  而後回到本身創建的工程中,寫下了微信支付的流程:

  

  既然要註冊微信,那麼咱們先到微信SDK的頭文件中查看一下,發現只提供了兩個註冊方法,註釋也寫的很清楚:

  

  而後咱們導入這個頭文件以後,直接根據已經有的APPID進行註冊:

  

  好,其實步驟:一、導入微信支付SDK,註冊微信支付。而後二、設置微信APPID爲URL Schemes前面已經作好了。

  而後咱們須要進行三、發起支付,調其微信支付,在這以前,咱們直接看看微信官方提供給咱們的Demo:

  

  

  最後咱們找到了Demo中完整的能夠直接用的這部分發起微信支付的源碼:

  

  將這段直接拷貝到個人工程中,有那麼一點經驗的開發者就會注意到一些,好比Demo源碼使用了MRC的autorelease,你能夠手動去掉,類方法能夠換成實例方法,根據你的實際項目開發需求:

 1 - (NSString *)jumpToBizPay {
 2 
 3 //============================================================
 4     // V3&V4支付流程實現
 5     // 注意:參數配置請查看服務器端Demo
 6     // 更新時間:2015年11月20日
 7     //============================================================
 8     NSString *urlString   = @"http://wxpay.weixin.qq.com/pub_v2/app/app_pay.php?plat=ios";
 9     //解析服務端返回json數據
10     NSError *error;
11     //加載一個NSURL對象
12     NSURLRequest *request = [NSURLRequest requestWithURL:[NSURL URLWithString:urlString]];
13     //將請求的url數據放到NSData對象中
14     NSData *response = [NSURLConnection sendSynchronousRequest:request returningResponse:nil error:nil];
15     if ( response != nil) {
16         NSMutableDictionary *dict = NULL;
17         //IOS5自帶解析類NSJSONSerialization從response中解析出數據放到字典中
18         dict = [NSJSONSerialization JSONObjectWithData:response options:NSJSONReadingMutableLeaves error:&error];
19         
20         NSLog(@"url:%@",urlString);
21         if(dict != nil){
22             NSMutableString *retcode = [dict objectForKey:@"retcode"];
23             if (retcode.intValue == 0){
24                 NSMutableString *stamp  = [dict objectForKey:@"timestamp"];
25                 
26                 //調起微信支付
27                 PayReq* req             = [[PayReq alloc] init];
28                 req.partnerId           = [dict objectForKey:@"partnerid"];
29                 req.prepayId            = [dict objectForKey:@"prepayid"];
30                 req.nonceStr            = [dict objectForKey:@"noncestr"];
31                 req.timeStamp           = stamp.intValue;
32                 req.package             = [dict objectForKey:@"package"];
33                 req.sign                = [dict objectForKey:@"sign"];
34                 [WXApi sendReq:req];
35                 //日誌輸出
36                 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 );
37                 return @"";
38             }else{
39                 return [dict objectForKey:@"retmsg"];
40             }
41         }else{
42             return @"服務器返回錯誤,未獲取到json對象";
43         }
44     }else{
45         return @"服務器返回錯誤";
46     }
47 }

  哦,對了,還有一個很簡單但很必要的操做忘記展現出來了:

  

  進一步,咱們在微信的SDK源碼頭文件中,能夠找到兩個頗有用的方法,你也能夠在微信支付平臺打開開發者文檔找到這兩個方法的介紹:

  

  而後我將其運用在個人工程中

  

  好,就這樣,步驟:三、發起微信支付,調起微信 到這裏就完成了。

  最後還須要作的就是,處理返回微信支付返回信息,使用了微信知否功能,不論是支付成功和失敗,甚至仍是用戶本身取消支付,都會須要返回當前應用,並返回相關的信息。

  這裏就須要用到微信SDK的處理返回信息的代理協議和代理方法了:

  

  在微信SDK的頭文件中,咱們能夠找到protocol協議:

  

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

  

  

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

  

  回到個人簡易工程中,直接粘貼在裏面用:

  

  那麼這裏面的返回信息中主要就有兩個東西:resp.errCode錯誤碼 和 resp.errStr錯誤緣由,這兩個東西在實際開發中常常遇到,因此也是面試會問到的一個細節。

  接着你能夠經過點進鏈接:https://pay.weixin.qq.com/wiki/doc/api/app.php?chapter=8_5 能夠在官方開發文檔中找到:

    

  而後,根據實際開發需求,咱們可能還須要回傳微信app的相關信息:

  在當前AppDelegate.m文件添加一個代理方法:

  

五、到這裏,就完成了整個微信支付的使用流程,下面能夠用你的真機進行測試了,由於模擬器很差安裝微信。

 

 

 

轉載註明出處:http://www.cnblogs.com/goodboy-heyang/p/5255818.html ,尊重勞動成果。

 

最後補充無心發現的大神github上也有微信講解和源碼,你們也能夠學習學習:

https://github.com/renzifeng/WXPay

只不過,對於沒有花99美刀買了開發者帳戶,該github上下載的源碼估計不能直接用真機測試,緣由是上面的項目實例建立的時間比較早,那時候XCode在沒有開發者帳戶的時候,不支持真機測試。

還有一個大牛寫的微信支付的博文,並且就是2016年1月20號寫的呢:

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

相關文章
相關標籤/搜索