iOS開發(fā)傻瓜式微信支付的方法教程
前言
本文主要給大家介紹了關(guān)于iOS開發(fā)傻瓜式微信支付的相關(guān)內(nèi)容,分享出來供大家參考學(xué)習(xí),下面來一起看看詳細(xì)的介紹吧。
方法步驟如下:
先下載微信SDK,如果集成了友盟分享里的微信,那就不用下載,也不用配置環(huán)境,因?yàn)榕渲糜衙朔窒淼臅r(shí)候已經(jīng)把微信支付的環(huán)境都配置好了(包括框架,schema跳轉(zhuǎn),白名單)如果沒有集成過友盟分享那么請(qǐng)到微信開放平臺(tái)下載SDK
如果公司沒有給微信平臺(tái)的appkey則需要自己幫公司去微信平臺(tái)申請(qǐng) 工程的bundle id 也要和在微信平臺(tái)注冊(cè)的bundle id一樣
登錄賬號(hào)后下載SDK 把文件夾導(dǎo)入工程
下面是配置環(huán)境,集成了友盟分享的可以跳過下面的4個(gè)步驟
1.添加依賴庫:
打開工程->build phases ->link binary with libriaries
2.添加scheme:為了app之間的跳轉(zhuǎn)
打開工程->info->URL types
這里的url schemes就填在微信開發(fā)平臺(tái)申請(qǐng)的appID
3.白名單:(貌似不配置白名單也可以跳轉(zhuǎn))
打開工程里的info.plist文件 添加LSApplicationQueriesSchemes數(shù)組并添加wechat 和 weixin字符串
或者info.plist右鍵->source code打開添加下面這段代碼
<key>LSApplicationQueriesSchemes</key> <array><string>wechat</string> <string>weixin </string> </array>
4.工程->build setttings -> 搜索other linker flags 添加-Objc -all_load 如下圖所示,不然運(yùn)行工程會(huì)崩潰
環(huán)境配置好了 編譯一下工程,發(fā)現(xiàn)工程報(bào)錯(cuò)(中文名的工程會(huì)報(bào)這個(gè)錯(cuò)誤,英文名則不會(huì))
不要害怕,這是因?yàn)槿鄙賃IKit庫 在WXApiObject.h里導(dǎo)入庫#import <UIKit/UIKit.h>
再編譯,錯(cuò)誤沒啦!
接下來上代碼
在appdelegate.m文件中 - (BOOL)application:(UIApplication )application didFinishLaunchingWithOptions:(NSDictionary )launchOptions
方法里設(shè)置微信SDK的appID或者用的友盟也可以用友盟設(shè)置微信appID的方法
1.微信自帶注冊(cè)方法
導(dǎo)入頭文件#import “WXApi.h"
遵守協(xié)議 <WXApiDelegate>
[WXApi registerApp:kWechatID];
2.友盟注冊(cè)方法
//設(shè)置微信的appKey和appSecret appsecret也可以填nil
[[UMSocialManager defaultManager] setPlaform:UMSocialPlatformType_WechatSession appKey:kWechatID appSecret:kWechatKey redirectURL:@http://mobile.umeng.com/social];
在需要用到的類里導(dǎo)入頭文件
import "WXApi.h"
我自己封裝了一個(gè)PayManager類,把支付方法寫成了類方法,在需要使用微信支付的地方直接用類就可以調(diào)用這個(gè)類方法
首先生成微信訂單
pragma mark 生成微信訂單
+ (void)createWechatOrderWithGoldType:(NSString *)type amount:(NSNumber *)amount{ // 向后臺(tái)請(qǐng)求訂單,根據(jù)自己公司后臺(tái)給的url來做 [RequestTool requestWithType:POST RRLString:kWechatURL parameter:@{@"user_id":[UserLoginStateManager shareManager].model.userID,@"sign_key":[UserLoginStateManager shareManager].model.sign_key,@"gold_type":type,@"amount":amount} HTTPHeader:nil callBlock:^(NSData *data, NSError *error) { NSDictionary *dic = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingMutableContainers error:nil]; NSLog(@"%@",dic); if (!dic[@"error_msg"]) { // 調(diào)用自己寫的微信支付方法 [self WXPayWithAppid:dic[@"appid"] noncestr:dic[@"noncestr"] package:dic[@"package"] partnerid:dic[@"partnerid"] prepayid:dic[@"prepayid"] timestamp:dic[@"timestamp"] key:dic[@"key"] sign:dic[@"sign"]]; } }]; }
#pragma mark 微信支付方法+ (void)WXPayWithAppid:(NSString *)appid noncestr:(NSString *)noncestr package:(NSString *)package partnerid:(NSString *)partnerid prepayid:(NSString *)prepayid timestamp:(NSString *)timestamp key:(NSString *)key sign:(NSString *)sign{ //需要?jiǎng)?chuàng)建這個(gè)支付對(duì)象 PayReq *req = [[PayReq alloc] init]; //由用戶微信號(hào)和AppID組成的唯一標(biāo)識(shí),用于校驗(yàn)微信用戶 req.openID = appid; // 商家id,在注冊(cè)的時(shí)候給的 req.partnerId = partnerid; // 預(yù)支付訂單這個(gè)是后臺(tái)跟微信服務(wù)器交互后,微信服務(wù)器傳給你們服務(wù)器的,你們服務(wù)器再傳給你 req.prepayId = prepayid; // 根據(jù)財(cái)付通文檔填寫的數(shù)據(jù)和簽名 req.package = package; // 隨機(jī)編碼,為了防止重復(fù)的,在后臺(tái)生成 req.nonceStr = noncestr; // 這個(gè)是時(shí)間戳,也是在后臺(tái)生成的,為了驗(yàn)證支付的 NSString * stamp = timestamp; req.timeStamp = stamp.intValue; // 這個(gè)簽名也是后臺(tái)做的 req.sign = sign; //發(fā)送請(qǐng)求到微信,等待微信返回onResp [WXApi sendReq:req]; }
在需要微信支付的地方調(diào)用封裝的類方法之后會(huì)跳轉(zhuǎn)到微信app,如果沒有安裝則沒有任何反應(yīng)。這里需要注意,因?yàn)闆]有安裝微信,必須要提供webview的方式登錄微信來支付,否則蘋果公司會(huì)拒絕應(yīng)用上架。但是微信又不自帶webview的方式,(支付寶是自帶的)所以要判斷用戶有沒有安裝微信,如果沒有安裝微信就不顯示微信支付這個(gè)按鈕。
// 判斷手機(jī)有沒有微信 if ([WXApi isWXAppInstalled]) { wechatButton.hidden = NO; }else{ wechatButton.hidden = YES; }
跳轉(zhuǎn)到微信客戶端支付完成后返回應(yīng)用,會(huì)走appdelegate.m里的
// iOS9.0以前調(diào)用此方法 - (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url { if ([url.host isEqualToString:@"pay"]) { return [WXApi handleOpenURL:url delegate:self]; } }
// iOS9.0及9.0以后調(diào)用此方法 - (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation{ // 在此方法中做如下判斷,因?yàn)檫€有可能有其他的支付,如支付寶就是@"safepay" if ([url.host isEqualToString:@"pay"]) { return [WXApi handleOpenURL:url delegate:self]; } return YES; }
在appdelegate.m里隨便找個(gè)地方寫上下面的方法,這個(gè)方法就是收到的微信消息
pragma mark 收到微信支付后的信息
- (void)onResp:(BaseResp *)resp{ if ([resp isKindOfClass:[PayResp class]]) { // 微信支付 PayResp*response=(PayResp*)resp; switch(response.errCode){ case 0: NSLog(@“支付成功!"); break; case -1: NSLog(@"支付失??!"); break; case -2: NSLog(@"支付失敗!"); break; default: NSLog(@"支付失??!"); break; } } }
還有一點(diǎn)需要注意的是,支付完成后點(diǎn)擊右上角的返回可以走回調(diào)方法,但是點(diǎn)擊左上角的返回應(yīng)用或者是點(diǎn)擊home鍵再打開應(yīng)用是無法走回調(diào)的。
付完款后微信服務(wù)器會(huì)通知后臺(tái)有沒有成功 ,讓后臺(tái)來決定是否發(fā)貨吧。具體怎么做請(qǐng)和后臺(tái)溝通。
總結(jié)
以上就是這篇文章的全部內(nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
簡單實(shí)現(xiàn)iOS指紋解鎖(TouchID)
這篇文章主要介紹了如何簡單實(shí)現(xiàn)iOS指紋解鎖,驗(yàn)證TouchID,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02iOS自定義轉(zhuǎn)場(chǎng)動(dòng)畫的幾種情況
這篇文章主要給大家介紹了關(guān)于iOS自定義轉(zhuǎn)場(chǎng)動(dòng)畫的幾種情況,文中通過示例代碼介紹的非常詳細(xì),對(duì)各位iOS開發(fā)者們具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06iOS在固定的label上動(dòng)態(tài)顯示所有文字
這篇文章給大家主要介紹了iOS中如何實(shí)現(xiàn),在固定的label上動(dòng)態(tài)顯示所有文字的方法,文中給出了示例和思路,對(duì)大家的理解很有幫助,感興趣的朋友們下面來一起看看吧。2016-10-10iOS之?dāng)?shù)據(jù)解析之XML解析詳解
本篇文章主要介紹了iOS之?dāng)?shù)據(jù)解析之XML解析詳解,XML解析常見的兩種方式:DOM解析和SAX解析,有興趣的可以了解一下。2016-12-12SIGPIPE(Signal?13,?Code?0)?異常排查及處理
這篇文章主要為大家介紹了SIGPIPE(Signal?13,?Code?0)?異常排查原因解析及處理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01