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

首頁 > 系統 > iOS > 正文

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

2020-07-26 02:45:09
字體:
來源:轉載
供稿:網友

前言

本文主要給大家介紹了關于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鍵再打開應用是無法走回調的。


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

總結

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 长汀县| 池州市| 定日县| 阜康市| 东兴市| 横山县| 彭山县| 永胜县| 马关县| 吴江市| 固阳县| 石柱| 开远市| 彰化县| 余江县| 临沧市| 都安| 屏南县| 潮州市| 建水县| 晋宁县| 和静县| 巴马| 正定县| 怀仁县| 金塔县| 云林县| 会理县| 峨山| 丹棱县| 松江区| 阿拉尔市| 吴忠市| 高尔夫| 汉源县| 当雄县| 宁远县| 岗巴县| 丰都县| 营山县| 京山县|