本篇主要介紹接入App原生微信支付的具體步驟(簽名在服務端進行生成,客戶端主要就是吊起支付)
注冊相關信息
1,在微信開放平臺上申請app管理,獲取AppId,AppServece.
2,認證開發者資質
3,申請微信支付共能
項目中集成微信sdk
-
打開工程直接將下載的SDK拖進去
SDK包內 -
導入SDK所依賴的庫
在 Build Phases ->Linked Frameworks and Libraries 添加 在info,plist 中添加微信白名單和網絡協議設置
<key>LSApplicationQueriesSchemes</key>
<array>
<string>weixin</string>
</array>
<key>NSAppTransportSecurity</key>
<dict>
<key>NSAllowsArbitraryLoads</key>
<true/>
</dict>
38CC8413-4F37-43BD-A82F-7EDDBA98EBEB.png
-
將微信支付的APPID設為URL Schemes
2F6D48CB-0CFD-4836-BCB8-8D751A9854DD.png 實現代碼
//1.導入微信支付SDK,注冊微信支付
//2.設置微信APPID為URL Schemes
//3.發起支付,調起微信支付
//4.處理支付結果
#import "WXApi.h"
-(BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
//向微信注冊
[WXApi registerApp:WXKey];
}
在微信支付按鈕方法里 首先根據訂單編號傳給后臺,后臺調用微信api接口生成預支付訂單,然后將預支付訂單信息進行第二次簽名 將相關信息傳給客戶端,客戶端調用SDK方法完成微信支付。
微信支付點擊方法如下:
//以下調用后臺的方法為我們自己封裝的方法具體可按照你們自己處理的邏輯
WxpayClientEntity*client = [[WxpayClientEntity alloc]init];
client.orderid = self.orderid;
[[NSUserDefaults standardUserDefaults]setObject:client.orderid forKey:@"orderid"];
client.ipaddress =[self getIPAddress];
[[Network new]httpRequestJosn:client WithRespoinseObj:^(id respoinseObj) {
NSLog(@"%@",respoinseObj);
[MBProgressHUD showText:respoinseObj[@"message"]];
if ([[respoinseObj objectForKey:@"status"]isEqualToString:@"2000123"]) { NSDictionary*dic = [respoinseObj objectForKey:@"results"];
WxpayEntity*model = [[WxpayEntity alloc]initWithDictinary:dic];
PayReq *request = [[PayReq alloc] init];
/** 商家向財付通申請的商家id */
request.partnerId =model.partnerid;
/** 預支付訂單 */
request.prepayId= model.prepayid;
/** 商家根據財付通文檔填寫的數據和簽名 */
request.package = @"Sign=WXPay";
/** 隨機串,防重發 */
request.nonceStr= model.noncestr;
/** 時間戳,防重發 */
// request.timeStamp= [model.timestamp intValue];
// 將當前時間轉化成時間戳
NSDate *datenow = [NSDate date];
NSString *timeSp = [NSString stringWithFormat:@"%ld", (long)[datenow timeIntervalSince1970]];
UInt32 timeStamp =[timeSp intValue];
request.timeStamp= timeStamp;
// * 商家根據微信開放平臺文檔對數據做的簽名
// request.sign=[self createMD5SingForPay:WXKey
// partnerid:request.partnerId
// prepayid:request.prepayId
// package:request.package
// noncestr:request.nonceStr
// timestamp:request.timeStamp];
// request.sign = model.sign;
request.sign = model.sign;
NSLog(@"%@",model.timestamp);
[WXApi sendReq: request];
}
} failBlock:^(NSHTTPURLResponse *responseObj) {
}];
在AppDelegate 實現如下回調方法
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation{
return [WXApi handleOpenURL:url delegate:self];
}
實現微信支付回調協議
- (void)onResp:(BaseResp *)resp
{
//支付返回結果,實際支付結果需要去微信服務器端查詢
NSString *strMsg ,*strTitle= [NSString stringWithFormat:@"支付結果"];
switch (resp.errCode) {
case WXSuccess:
{
strMsg = @"支付結果:成功!";
// 此處寫自己協議
//通過通知中心發送通知
NSLog(@"支付成功-PaySuccess,retcode = %d", resp.errCode);
}
break;
default:
strMsg = [NSString stringWithFormat:@"支付結果:失敗!retcode = %d, retstr = %@", resp.errCode,resp.errStr];
NSLog(@"錯誤,retcode = %d, retstr = %@", resp.errCode,resp.errStr);
break;
}
}