你好,歡迎來到IOS教程網

 Ios教程網 >> IOS編程開發 >> IOS開發綜合 >> iOS開發傻瓜式微信支付的方法教程

iOS開發傻瓜式微信支付的方法教程

編輯:IOS開發綜合

前言

本文主要給大家介紹了關於iOS開發傻瓜式微信支付的相關內容,分享出來供大家參考學習,下面來一起看看詳細的介紹吧。

方法步驟如下:

先下載微信SDK,如果集成了友盟分享裡的微信,那就不用下載,也不用配置環境,因為配置友盟分享的時候已經把微信支付的環境都配置好了(包括框架,schema跳轉,白名單)如果沒有集成過友盟分享那麼請到微信開放平台下載SDK

如果公司沒有給微信平台的appkey則需要自己幫公司去微信平台申請 工程的bundle id 也要和在微信平台注冊的bundle id一樣

鏈接:https://open.weixin.qq.com

登錄賬號後下載SDK 把文件夾導入工程

下面是配置環境,集成了友盟分享的可以跳過下面的4個步驟

1.添加依賴庫:

打開工程->build phases ->link binary with libriaries


2.添加scheme:為了app之間的跳轉

打開工程->info->URL types

這裡的url schemes就填在微信開發平台申請的appID


3.白名單:(貌似不配置白名單也可以跳轉)

打開工程裡的info.plist文件 添加LSApplicationQueriesSchemes數組並添加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 如下圖所示,不然運行工程會崩潰


環境配置好了 編譯一下工程,發現工程報錯(中文名的工程會報這個錯誤,英文名則不會)

不要害怕,這是因為缺少UIKit庫 在WXApiObject.h裡導入庫#import <UIKit/UIKit.h>

再編譯,錯誤沒啦!

接下來上代碼

在appdelegate.m文件中 - (BOOL)application:(UIApplication )application didFinishLaunchingWithOptions:(NSDictionary )launchOptions方法裡設置微信SDK的appID或者用的友盟也可以用友盟設置微信appID的方法

1.微信自帶注冊方法

導入頭文件#import “WXApi.h"

遵守協議 <WXApiDelegate>

[WXApi registerApp:kWechatID];

2.友盟注冊方法

//設置微信的appKey和appSecret appsecret也可以填nil

 [[UMSocialManager defaultManager] setPlaform:UMSocialPlatformType_WechatSession appKey:kWechatID appSecret:kWechatKey redirectURL:@http://mobile.umeng.com/social];

在需要用到的類裡導入頭文件

import "WXApi.h"

我自己封裝了一個PayManager類,把支付方法寫成了類方法,在需要使用微信支付的地方直接用類就可以調用這個類方法

首先生成微信訂單

pragma mark 生成微信訂單

+ (void)createWechatOrderWithGoldType:(NSString *)type amount:(NSNumber *)amount{
// 向後台請求訂單,根據自己公司後台給的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"]) {
// 調用自己寫的微信支付方法
 [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{ 
 //需要創建這個支付對象 
PayReq *req = [[PayReq alloc] init]; 
//由用戶微信號和AppID組成的唯一標識,用於校驗微信用戶 
req.openID = appid; 
// 商家id,在注冊的時候給的 
req.partnerId = partnerid; 
// 預支付訂單這個是後台跟微信服務器交互後,微信服務器傳給你們服務器的,你們服務器再傳給你 
 req.prepayId = prepayid; 
// 根據財付通文檔填寫的數據和簽名 
 req.package = package; 
 // 隨機編碼,為了防止重復的,在後台生成 
 req.nonceStr = noncestr; 
 // 這個是時間戳,也是在後台生成的,為了驗證支付的
 NSString * stamp = timestamp;
 req.timeStamp = stamp.intValue; 
// 這個簽名也是後台做的 
req.sign = sign; 
 //發送請求到微信,等待微信返回onResp 
[WXApi sendReq:req];
}

在需要微信支付的地方調用封裝的類方法之後會跳轉到微信app,如果沒有安裝則沒有任何反應。這裡需要注意,因為沒有安裝微信,必須要提供webview的方式登錄微信來支付,否則蘋果公司會拒絕應用上架。但是微信又不自帶webview的方式,(支付寶是自帶的)所以要判斷用戶有沒有安裝微信,如果沒有安裝微信就不顯示微信支付這個按鈕。

// 判斷手機有沒有微信
 if ([WXApi isWXAppInstalled]) {
 wechatButton.hidden = NO;
 }else{
 wechatButton.hidden = YES;
 }

跳轉到微信客戶端支付完成後返回應用,會走appdelegate.m裡的

// iOS9.0以前調用此方法
- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url {
 if ([url.host isEqualToString:@"pay"]) {
 return [WXApi handleOpenURL:url delegate:self];
 }
}
// iOS9.0及9.0以後調用此方法
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation{
 // 在此方法中做如下判斷,因為還有可能有其他的支付,如支付寶就是@"safepay"
 if ([url.host isEqualToString:@"pay"]) { 
 return [WXApi handleOpenURL:url delegate:self]; 
 } 
 return YES;
}

在appdelegate.m裡隨便找個地方寫上下面的方法,這個方法就是收到的微信消息

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; 
 } 
 }
}

還有一點需要注意的是,支付完成後點擊右上角的返回可以走回調方法,但是點擊左上角的返回應用或者是點擊home鍵再打開應用是無法走回調的。


付完款後微信服務器會通知後台有沒有成功 ,讓後台來決定是否發貨吧。具體怎麼做請和後台溝通。

總結

以上就是這篇文章的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對本站的支持。

  1. 上一頁:
  2. 下一頁:
蘋果刷機越獄教程| IOS教程問題解答| IOS技巧綜合| IOS7技巧| IOS8教程
Copyright © Ios教程網 All Rights Reserved