總結iOS中微信支付實現的幾個的步驟

1.微信開發平臺:http://kf.qq.com/faq/120911VrYVrA150906F3qqY3.html

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

3.開發文檔:https://pay.weixin.qq.com/wiki/doc/api/index.html

開發步驟 :

第一步:



第二步:(記得看SDK里的readme和demo,因為有白名單和依賴庫要添加)

下載SDK開發包:https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=11_1

第三步:

1、項目設置APPID

商戶在微信開放平臺申請開發APP應用后,微信開放平臺會生成APP的唯一標識APPID。在Xcode中打開項目,設置微信的URL Schemes為申請成功的APPID。


2、注冊APPID

(1)在工程中導入微信lib庫和頭文件,

(2)向微信注冊您的APPID,代碼如下:

[WXApi registerApp:@"wxd930ea5d5a258f4f" withDescription:@"demo 2.0"];

3、調起支付

-(void)WeixinPay:(NSString*)price{

[UDFsetObject:priceforKey:@"amount"];

//1.創建支付簽名對象

payRequsestHandler*req = [[payRequsestHandleralloc]init] ;

[reqinit:APP_IDmch_id:MCH_ID];//設置appid和商戶ID

[reqsetKey:PARTNER_ID];//設置密鑰

//2.獲取到實際調起微信支付的參數后,在app端調起支付(此方法里要修改某些自己商品參數)

NSMutableDictionary*dict = [reqsendPay_demo];

//3.發送微信支付請求

if(dict ==nil){//錯誤提示

NSString*debug = [reqgetDebugifo];

// [self alert:@"提示信息" msg:debug];

}else{

//[self alert:@"確認" msg:@"下單成功,點擊OK后調起支付!"];

NSMutableString*stamp? = [dictobjectForKey:@"timestamp"];

//調起微信支付

PayReq* req ??????????? = [[PayReqalloc]init];

req.openID= [dictobjectForKey:@"appid"];

req.partnerId= [dictobjectForKey:@"partnerid"];

req.prepayId= [dictobjectForKey:@"prepayid"];

req.nonceStr= [dictobjectForKey:@"noncestr"];

req.timeStamp= stamp.intValue;

req.package= [dictobjectForKey:@"package"];

req.sign= [dictobjectForKey:@"sign"];

[WXApisendReq:req];//發送微信的支付請求

}

}

//這個方法是WXApi類里的方法

- (NSMutableDictionary*)sendPay_demo{

NSUserDefaults*udf = [NSUserDefaultsstandardUserDefaults];

//訂單標題,展示給用戶

NSString*order_name??? = [udfobjectForKey:@"courseTitle"];

//預付單參數訂單設置

srand( (unsigned)time(0) );

NSString*noncestr? = [NSStringstringWithFormat:@"%d",rand()];

NSString*orderno ? = [UDFvalueForKey:@"Orderid"];

NSMutableDictionary*packageParams = [NSMutableDictionarydictionary];

//開放平臺appid

[packageParamssetObject:appidforKey:@"appid"];

//商戶號

[packageParamssetObject:mchidforKey:@"mch_id"];

//支付設備號或門店號

[packageParamssetObject:@"APP-001"forKey:@"device_info"];

//固定:隨機串

[packageParamssetObject: noncestrforKey:@"nonce_str"];

//固定:支付類型,固定為APP

[packageParamssetObject:@"APP"forKey:@"trade_type"];

//變動:自己商品名稱

[packageParamssetObject: order_nameforKey:@"body"];

//變動:支付結果異步通知

[packageParamssetObject:NOTIFY_URLforKey:@"notify_url"];

//商戶訂單號

[packageParamssetObject: ordernoforKey:@"out_trade_no"];

//發起支付的機器ip

[packageParamssetObject:@"196.168.1.1"forKey:@"spbill_create_ip"];

//訂單金額,單位為分(變動:自己商品價格)

[packageParamssetObject:[NSStringstringWithFormat:@"%.f",[ [udfvalueForKey:@"amount"]floatValue]*100]forKey:@"total_fee"];

//獲取prepayId(預支付交易會話標識)

NSString*prePayid;

prePayid ? = [selfsendPrepay:packageParams];

if( prePayid !=nil) {

//獲取到prepayid后進行第二次簽名

NSString*package, *time_stamp, *nonce_str;

//設置支付參數

time_tnow;

time(&now);

time_stamp? = [NSStringstringWithFormat:@"%ld", now];

nonce_str= [WXUtilmd5:time_stamp];

//重新按提交格式組包,微信客戶端暫只支持package=Sign=WXPay格式,須考慮升級后支持攜帶package具體參數的情況

//package ????? = [NSString stringWithFormat:@"Sign=%@",package];

package ??????? =@"Sign=WXPay";

//第二次簽名參數列表

NSMutableDictionary*signParams = [NSMutableDictionarydictionary];

[signParamssetObject:appidforKey:@"appid"];

[signParamssetObject: nonce_strforKey:@"noncestr"];

[signParamssetObject: packageforKey:@"package"];

[signParamssetObject:mchidforKey:@"partnerid"];

[signParamssetObject: time_stampforKey:@"timestamp"];

[signParamssetObject: prePayidforKey:@"prepayid"];

//生成簽名

NSString*sign? = [selfcreateMd5Sign:signParams];

//添加簽名

[signParamssetObject: signforKey:@"sign"];

[debugInfoappendFormat:@"第二步簽名成功,sign=%@\n",sign];

//返回參數列表

returnsignParams;

}else{

[debugInfoappendFormat:@"獲取prepayid失敗!\n"];

}

returnnil;

}

4、支付結果回調 (在appdelegate.m里寫上這個回調方法!)

照微信SDK Sample,在類實現onResp函數,支付完成后,微信APP會返回到商戶APP并回調onResp函數,開發者需要在該函數中接收通知,判斷返回錯誤碼,如果支付成功則去后臺查詢支付結果再展示用戶實際支付結果。注意 一定不能以客戶端返回作為用戶支付的結果,應以服務器端的接收的支付通知或查詢API返回的結果為準。代碼示例如下:

-(void)onResp:(BaseResp*)resp{

if ([respisKindOfClass:[PayRespclass]]){

PayResp*response=(PayResp*)rest;

switch(response.errCode){

caseWXSuccess:

//服務器端查詢支付通知或查詢API返回的結果再提示成功

NSlog(@"支付成功");

break;

default:

NSlog(@"支付失敗,retcode=%d",resp.errCode);

break;

}

}

}

如果上面的文章對您在以后的開發中能派上用場,請關注或點個喜歡吧,我會不定期的給您分享或推薦一些好的文章哦^_^

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容