1、開通微信開發(fā)者賬號(hào)
2、創(chuàng)建應(yīng)用
3、查看應(yīng)用
4、下載官方Demo
https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=11_1
注:這里不得不吐槽一下,這是什么demo ,一堆報(bào)錯(cuò)!!!
5、正式接入
商戶系統(tǒng)和微信支付系統(tǒng)主要交互說明:
步驟1:用戶在商戶APP中選擇商品,提交訂單,選擇微信支付。
步驟2:商戶后臺(tái)收到用戶支付單,調(diào)用微信支付統(tǒng)一下單接口。參見【統(tǒng)一下單API】。
步驟3:統(tǒng)一下單接口返回正常的prepay_id,再按簽名規(guī)范重新生成簽名后,將數(shù)據(jù)傳輸給APP。參與簽名的字段名為appId,partnerId,prepayId,nonceStr,timeStamp,package。注意:package的值格式為Sign=WXPay
步驟4:商戶APP調(diào)起微信支付。api參見本章節(jié)【app端開發(fā)步驟說明】
步驟5:商戶后臺(tái)接收支付通知。api參見【支付結(jié)果通知API】
步驟6:商戶后臺(tái)查詢支付結(jié)果。,api參見【查詢訂單API】
7、接入Api
注:這里如果結(jié)合后端開發(fā)。統(tǒng)一下單 和 支付結(jié)果通用通知 由后端實(shí)現(xiàn)。App只需要“”調(diào)起支付”就可以了。
8、Android接入
https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=8_5
(1)、注冊(cè)APPID
privateIWXAPIWXApi;
WXApi= WXAPIFactory.createWXAPI(this, MyApplication.instance().appConfig.wxapi_key);
WXApi.registerApp(MyApplication.instance().appConfig.wxapi_key);
(2)、判斷是否安裝微信
if(WXApi.getWXAppSupportAPI() < Build.PAY_SUPPORTED_SDK_INT) {
Utils.toastText(ActivityPay.this,"您未安裝最新版本微信,不支持微信支付,請(qǐng)安裝或升級(jí)微信版本");
}
(3)、調(diào)起支付
PayReq req =newPayReq();
req.appId= map.get("appid");
req.partnerId= map.get("partnerid");
req.prepayId= map.get("prepayid");
req.nonceStr= map.get("noncestr");
req.timeStamp= map.get("timestamp");
req.packageValue= map.get("package");
req.sign= map.get("sign");
req.extData="app data";
WXApi.sendReq(req);
(4)、支付結(jié)果回調(diào)
注:這里最坑的,需要在你的包名例如:com.Sample.demo 下建 wxapi 實(shí)現(xiàn) WXPayEntryActivity 如下:
不然沒法回調(diào)。
更坑的是,這里 回調(diào) errCode == 0 ,并不是真正的成功。應(yīng)以服務(wù)器端的接收的支付通知或查詢API返回的結(jié)果為準(zhǔn)
public class WXPayEntryActivity extends Activity implements IWXAPIEventHandler {
private static final String TAG = "WXPayEntryActivity";
private IWXAPI api;
private Context context;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.account_pay_result);
context = this;
api = WXAPIFactory.createWXAPI(this, "wx_key");
api.handleIntent(getIntent(), this);
}
@Override
public void onReq(BaseReq req) {
}
@Override
public void onResp(final BaseResp resp) {
if (resp.getType() == ConstantsAPI.COMMAND_PAY_BY_WX) {
Intent intent = new Intent(WXPayEntryActivity.this, ActivityPay.class);
intent.putExtra("payState", JsonParseUtil.toJson(resp));
startActivity(intent);
finish();
}
}
}
5、常看簽名
https://open.weixin.qq.com/zh_CN/htmledition/res/dev/download/sdk/Gen_Signature_Android.apk
6、常規(guī)報(bào)錯(cuò)
(1)調(diào)不起微信支付,通常通過以下幾個(gè)步驟檢查下
--檢查 微信開發(fā)平臺(tái)是否開通微信支付功能?
--檢查 App端 的APPID 與服務(wù)端下單時(shí)的APPID 是否一致?
--檢查 App的包名是否與微信開發(fā)平臺(tái)設(shè)置的一致?
--檢查 App的簽名是否與微信開發(fā)平臺(tái)設(shè)置的一致?
注:
--如果還是不行,請(qǐng)清除微信緩存重試
--微信最坑的,就是一切都對(duì),沒有任何的報(bào)錯(cuò),那就得微信的工程師了
(2)微信支付成功,沒有回調(diào)
--檢查app工程下 上面的 第4 點(diǎn)
作者:小玄子_fhx
鏈接:http://www.lxweimin.com/p/5226cc6b4962
來源:簡(jiǎn)書
著作權(quán)歸作者所有。商業(yè)轉(zhuǎn)載請(qǐng)聯(lián)系作者獲得授權(quán),非商業(yè)轉(zhuǎn)載請(qǐng)注明出處。