原文地址:http://blog.csdn.net/intbird
微信官方文檔地址:https://open.weixin.qq.com/cgi-bin/frame?t=resource/res_main_tmpl&verify=1&lang=zh_CN
微信官方Demo:http://download.csdn.net/detail/intbird/8476901
@與服務器交互通信調用,android端只需獲取服務器參數填入微信.
==========================================
1,開啓
2,結果(支付和微信分享的Activity要安裝api文檔上說明的放到指定的包名內),支付結果最好要通知一下服務器.
3,示例
發佈使用的簽名正確的話取消和成功都能正確通知.
==========================================
@自己測試調用:Android自己請求微信服務器,一般不會這樣搞,只是練習需要這樣...
1,導入微信的libs包libammsdk.jar;
2,測試時使用weixinDemo中的debug_keystore;
3,需要注意應用要通過審覈,並且幾個Key值正確,一下爲微信支付Demo中的值:
//微信公衆平臺id;
private String app_wx_appid=WxConstants.app_wx_appid;
//微信開放平臺和商戶約定的密鑰
private String app_wx_secret_key="db426a9829e4b49a0dcac7b4162da6b6";
//微信公衆平臺商戶模塊和商戶約定的密鑰
private String app_wx_parent_key="8934e7d15453e97507ef794cf7b0519d";
//微信公衆平臺商戶模塊和商戶約定的支付密鑰
private String app_wx_pay_key="L8LrMqqeGRxST5reouB0K66CaYAWpqhAVsq7ggKkxHCOastWksvuX1uvmvQclxaHoYd3ElNBrNO2DHnnzgfVG9Qs473M3DTOZug5er46FhuGofumV8H2FVR9qkjSlC5K";
// 商家向財付通申請的商家id */
private String app_tx_parent_key = "1900000109";
==========================================
根據微信支付Demo,微信支付分爲三步:
第一步,獲取accessToken,accessToken值第二步要用;
private class GetAccessTokenTask extends AsyncTask<Void, Void, WxGetAccessTokenResult> {
@Override
protected WxGetAccessTokenResult doInBackground(Void... params) {
WxGetAccessTokenResult result = getAccessToken();
return result;
}
@Override
protected void onPostExecute(WxGetAccessTokenResult result) {
if (result.localRetCode == WxLocalRetCode.ERR_OK) {
GetPrepayIdTask getPrepayId = new GetPrepayIdTask();
getPrepayId.execute(result);
}
}
}
解析服務器響應private WxGetAccessTokenResult getAccessToken() {
WxGetAccessTokenResult result = new WxGetAccessTokenResult();
String url = String.format(api_get_access_token,
"client_credential",
app_wx_appid,
app_wx_secret_key);
byte[] buf = WeixinUtil.httpGet(url);
if (buf == null || buf.length == 0) {
result.localRetCode = WxLocalRetCode.ERR_HTTP;
return result;
}
String content = new String(buf);
result.parseFrom(content);
return result;
}
第二步,根據第一步的accesstoken值,將 組裝的商品參數Post給微信服務器
private class GetPrepayIdTask extends AsyncTask<WxGetAccessTokenResult, Void, WxGetPrepayIdResult> {
@Override
protected WxGetPrepayIdResult doInBackground(WxGetAccessTokenResult... params) {
WxGetPrepayIdResult result = getPrepayId(params[0]);
return result;
}
@Override
protected void onPostExecute(WxGetPrepayIdResult result) {
if (result.localRetCode == WxLocalRetCode.ERR_OK) {
sendPayReq(result);
}
}
}
組裝參數
private WxGetPrepayIdResult getPrepayId(WxGetAccessTokenResult accessTokenResult) {
String url = String.format(api_get_preorder_id,accessTokenResult.accessToken);
String entity = appSign.getWxPrepayAppSign();
WxGetPrepayIdResult result = new WxGetPrepayIdResult();
byte[] buf = WeixinUtil.httpPost(url, entity);
if (buf == null || buf.length == 0) {
result.localRetCode = WxLocalRetCode.ERR_HTTP;
return result;
}
String content = new String(buf);
result.parseFrom(content);
return result;
}
Post給服務器<span style="white-space:pre"> </span>private void sendPayReq(WxGetPrepayIdResult result) {
PayReq req = new PayReq();
req.appId = app_wx_appid;
req.partnerId = app_tx_parent_key;
req.prepayId = result.prepayId;
req.nonceStr = appSign.getNoncestr();
req.timeStamp = appSign.getTimestamp();
req.packageValue = "Sign=" + appSign.getPackageSign();
List<NameValuePair> signParams = new LinkedList<NameValuePair>();
signParams.add(new BasicNameValuePair("appid", req.appId));
signParams.add(new BasicNameValuePair("appkey", app_wx_pay_key));
signParams.add(new BasicNameValuePair("noncestr", req.nonceStr));
signParams.add(new BasicNameValuePair("package", req.packageValue));
signParams.add(new BasicNameValuePair("partnerid", req.partnerId));
signParams.add(new BasicNameValuePair("prepayid", req.prepayId));
signParams.add(new BasicNameValuePair("timestamp", req.timeStamp));
req.sign = WeixinUtil.genSign(signParams);
wxRequest.sendReq(req);
}
第三步:在項目下新建一個包wxapi,建立一個類名爲WXPayEntryActivity作爲接受微信的支付結果,不過最終結果以服務器的返回爲準notify_url:package net.sourceforge.simcpux.wxapi;
public class WXPayEntryActivity extends Activity implements IWXAPIEventHandler{<pre name="code" class="java"><span style="white-space:pre"> </span>@Override
public void onResp(BaseResp resp) {
Log.d(TAG, "onPayFinish, errCode = " + resp.errCode);
if (resp.getType() == ConstantsAPI.COMMAND_PAY_BY_WX) {
AlertDialog.Builder builder = new AlertDialog.Builder(this);
builder.setTitle("支付結果");
builder.setMessage("支付結果"+String.valueOf(resp.errCode));
builder.show();
}
}
}
==========================================
暫時沒想到其他想說的,先看個效果
1,包結構,需要注意的就是接收微信返回結果的那個類名;
2,組裝數據,規則在文檔中有說明
//package_ 字段生成方法
//package生成方法:
//A)對所有傳入參數按照字段名的ASCII 碼從小到大排序(字典序)後,使用URL 鍵值對的格式(即key1=value1&key2=value2…)拼接成字符串string1;
//B) 在string1 最後拼接上key=partnerKey 得到stringSignTemp 字符串, 並對 stringSignTemp進行md5 運算,再將得到的字符串所有字符轉換爲大寫,得到sign值signValue。
//C)對string1 中的所有鍵值對中的value 進行urlencode 轉碼,按照a 步驟重新拼接成字符串,得到string2。對於js 前端程序,一定要使用函數encodeURIComponent 進行urlencode編碼(注意!進行urlencode時要將空格轉化爲%20而不是+)。
//D)將sign=signValue 拼接到string1 後面得到最終的package 字符串。
//app_signature生成方法:
//A)參與簽名的字段包括:appid、appkey、noncestr、package、timestamp以及 traceid
//B)對所有待簽名參數按照字段名的ASCII 碼從小到大排序(字典序)後,使用URL 鍵值對的格式(即key1=value1&key2=value2…)拼接成字符串string1。 注意:所有參數名均爲小寫字符
//C)對string1 作簽名算法,字段名和字段值都採用原始值,不進行URL 轉義。具體簽名算法爲SHA1
3,對應的支付界面