總結(jié)iOS中微信支付實現(xiàn)的幾個的步驟

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

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

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

開發(fā)步驟 :

第一步:



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

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

第三步:

1、項目設(shè)置APPID

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


2、注冊APPID

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

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

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

3、調(diào)起支付

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

[UDFsetObject:priceforKey:@"amount"];

//1.創(chuàng)建支付簽名對象

payRequsestHandler*req = [[payRequsestHandleralloc]init] ;

[reqinit:APP_IDmch_id:MCH_ID];//設(shè)置appid和商戶ID

[reqsetKey:PARTNER_ID];//設(shè)置密鑰

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

NSMutableDictionary*dict = [reqsendPay_demo];

//3.發(fā)送微信支付請求

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

NSString*debug = [reqgetDebugifo];

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

}else{

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

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

//調(diào)起微信支付

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];//發(fā)送微信的支付請求

}

}

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

- (NSMutableDictionary*)sendPay_demo{

NSUserDefaults*udf = [NSUserDefaultsstandardUserDefaults];

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

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

//預付單參數(shù)訂單設(shè)置

srand( (unsigned)time(0) );

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

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

NSMutableDictionary*packageParams = [NSMutableDictionarydictionary];

//開放平臺appid

[packageParamssetObject:appidforKey:@"appid"];

//商戶號

[packageParamssetObject:mchidforKey:@"mch_id"];

//支付設(shè)備號或門店號

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

//固定:隨機串

[packageParamssetObject: noncestrforKey:@"nonce_str"];

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

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

//變動:自己商品名稱

[packageParamssetObject: order_nameforKey:@"body"];

//變動:支付結(jié)果異步通知

[packageParamssetObject:NOTIFY_URLforKey:@"notify_url"];

//商戶訂單號

[packageParamssetObject: ordernoforKey:@"out_trade_no"];

//發(fā)起支付的機器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;

//設(shè)置支付參數(shù)

time_tnow;

time(&now);

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

nonce_str= [WXUtilmd5:time_stamp];

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

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

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

//第二次簽名參數(shù)列表

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

//返回參數(shù)列表

returnsignParams;

}else{

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

}

returnnil;

}

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

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

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

if ([respisKindOfClass:[PayRespclass]]){

PayResp*response=(PayResp*)rest;

switch(response.errCode){

caseWXSuccess:

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

NSlog(@"支付成功");

break;

default:

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

break;

}

}

}

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

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關(guān)閱讀更多精彩內(nèi)容

  • 目前項目里有微信支付的需求,調(diào)研過一段時間后,發(fā)現(xiàn)其實并沒有想象中的那么困難。如果你只是想實現(xiàn)該功能,一個方法足以...
    劉光軍_MVP閱讀 1,534評論 0 7
  • 前提是已經(jīng)創(chuàng)建完應用了在微信的官網(wǎng)上。根據(jù)上一篇的微信獲得支付能力的步驟,這一篇主要制作微信支付的demo?;仡櫳?..
    扶光啟玄閱讀 24,439評論 28 50
  • 許多年前,有個老頭,心憂天下,無力回天,壯志未酬,投身江濤。 以前,我們紀念屈老頭,希望當下和后世都能記得住他做過...
    西西愛木閱讀 333評論 3 1
  • 今天的晨讀對于有拖延癥的人來說又是一大福音啊。小習慣的養(yǎng)成能讓我們解決小拖延,今天的晨讀是在教我們解決大拖延嗎? ...
    從容如羊閱讀 104評論 0 1

友情鏈接更多精彩內(nèi)容