大部分APP必備需求,使用總結 Android接入文章在此:官方文檔 文檔很簡單,Android分為四步: 1、後臺配置 2、Android 內 註冊appId 3、Android 內 調起支付 4、Android 內 支付結果回調 詳細流程總結: 1、後臺配置 這個讓伺服器同事去做就行,記得把項目 ...
大部分APP必備需求,使用總結
Android接入文章在此:官方文檔
文檔很簡單,Android分為四步:
1、後臺配置
2、Android 內 註冊appId
3、Android 內 調起支付
4、Android 內 支付結果回調
詳細流程總結:
1、後臺配置
這個讓伺服器同事去做就行,記得把項目APP的包名和簽名文件給他
包名在app目錄下的build.gradle文件中可以查看,為applicationId 鍵的值
簽名就用微信官方給的簽名工具獲取
註:有文章說這個工具獲取的簽名是錯誤的,經測試是正確的,所以放心用。
2、Android 內 註冊appId
這個比較簡單,就是兩行代碼 , 放在發起支付的那個activity的onCreate裡面註冊即可
final IWXAPI msgApi = WXAPIFactory.createWXAPI(context, null); // 將該app註冊到微信 msgApi.registerApp("wxd930ea5d5a258f4f");
註:有文章說createWXAPI(content,null) 寫成 createWXAPI(content,false)
實際上第二個參數null或者false都沒關係,檢測辦法就是看一下msgApi.registerApp返回是不是true ,經測試,都為true
3、Android 內 調起支付
IWXAPI api; PayReq request = new PayReq(); request.appId = "wxd930ea5d5a258f4f"; request.partnerId = "1900000109"; request.prepayId= "1101000000140415649af9fc314aa427",; request.packageValue = "Sign=WXPay"; request.nonceStr= "1101000000140429eb40476f8896f4c9"; request.timeStamp= "1398746574"; request.sign= "7FFECB600D7157C5AA49810D2D8F28BC2811827B"; api.sendReq(request);
操作一般為:
客戶端發送訂單數據給伺服器, 伺服器進行處理之後,返回微信支付需要的這幾個參數,客戶端用這幾個參數調起支付
這個就是調起支付的操作,執行sendReq之後即可。
註意:最好數據都由伺服器返回,儘量不要在客戶端寫死。
4、Android 內 支付結果回調
涉及一個Activity名為WXPayEntryActivity
這個Activity可以從官方下載的demo中獲取:地址
註意:
1、需要將這個Activity放到自己的項目中,放置的位置為包名.wxapi.WXPayEntryActivity.java
加入你的包名為com.aaa.wx ,則在目錄com-aaa-wx下有一個wxapi的包 包里為這個WXPayEntryActivity文件
結果目錄就為:com.aaa.wx.wxapi.WXPayEntryActivity
這個位置一定要寫對,否則調起支付調不出支付視窗
2、將WXPayEntryActivity放到自己的項目中的時候,需要在AndroidManifest.xml中註冊一下
有文章說要寫<intent-filter></intent-filter> , 經測試 現在的版本不需要也是可以的,跟調起支付失敗沒有關係
以上四步實現,正常來說就可以實現支付功能了,
支付結果從WXPayEntryActivity中的onResp方法中回調
publicvoidonResp(BaseRespresp){ if(resp.getType()==ConstantsAPI.COMMAND_PAY_BY_WX){ Log.d(TAG,"onPayFinish,errCode="+resp.errCode); AlertDialog.Builderbuilder=newAlertDialog.Builder(this); builder.setTitle(R.string.app_tip); } }
--------------------------------------------------------------------微信支付排坑總結------------------------------------------------------------------------
1、簽名
後臺配置的簽名要為release包的簽名
客戶端檢查的時候,需要打成release包,註意直接編譯的debug包是沒有簽名的,所以會調取失敗。
檢查方法:獲取已經集成好微信支付的app(測試微信支付的app)的簽名(用官方的簽名獲取app),和後臺配置的對比,不一致導致支付調起失敗。
2、WXPayEntryActivity
這個Activity從官方demo中獲取,放到自己的項目中,放置的位置必須為你的包名.wxapi下 , 具體查看上面集成第四步
AndroidManifest.xml文件需要註冊這個WXPayEntryActivity
3、包名
檢查項目包名和後臺配置的包名是否一致
4、PayReq 對象參數錯誤
伺服器原因,導致返回的PayReq對象需要的參數出現問題,導致調起支付失敗
檢測辦法,對比iOS端,如果iOS也不可以發起支付,極有可能是伺服器的問題,如果iOS端可以發起支付,則仍為客戶端集成問題
5、微信客戶端端緩存
當你反覆檢查代碼就是認為沒有問題的時候,極有可能是微信緩存的問題。
去手機設置---應用管理---微信---清除數據/緩存
再發起支付就可以正常發起支付了。
(該問題一般是一開始代碼有問題,調起支付失敗,這時候微信賬號上有訂單緩存,然後你修改代碼之後,代碼正確了,仍然調起支付失敗,就時這個訂單緩存導致的)
註意:
列印WXPayEntryActivity的onResp方法的resp.errCode
如果沒有列印,說明可能是上述第二個和第四個問題
如果列印值為-1 , 異常錯誤,則考慮為 第1 、 3 、5個問題