編輯:關於Android編程
開發Android APP微信支付功能,需要完成三個步驟:第一步生成預支付訂單、第二步生成微信支付參數、第三步調起微信APP支付。除了需要審核通過的APP應用外,還需要獲得微信支付接口權限,然後獲取對應的商戶號、API密鑰,這兩者缺一不可,並且在APP微信支付中使用
獲得商戶號、API密鑰
在微信開放平台中查看審核通過的APP應用,是否申請支付功能,若已申請,登錄微信支付|商戶平台:http://pay.weixin.qq.com 查看對應的商戶號、API密鑰
》申請微信支付接口

》登錄商戶平台

》查看商戶號

》獲取API密鑰


第一步:生成預支付訂單
將商品信息、商戶信息使用BasicNameValuePair存放,然後存儲在List列表中,並構造成xml字符串格式,以POST方式微信提供的接口:https://api.mch.weixin.qq.com/pay/unifiedorder 發送數據,接收返回信息,獲取prepay_id預支付訂單編號
》生成訂單請求

private String genProductArgs() {
StringBuffer xml = new StringBuffer();
try {
String nonceStr = genNonceStr();
xml.append("</xml>");
List<NameValuePair> packageParams = new LinkedList<NameValuePair>();
packageParams
.add(new BasicNameValuePair("appid", Constants.APP_ID));
packageParams.add(new BasicNameValuePair("body", "weixin"));
packageParams
.add(new BasicNameValuePair("mch_id", Constants.MCH_ID));
packageParams.add(new BasicNameValuePair("nonce_str", nonceStr));
packageParams.add(new BasicNameValuePair("notify_url",
"http://121.40.35.3/test"));
packageParams.add(new BasicNameValuePair("out_trade_no",
genOutTradNo()));
packageParams.add(new BasicNameValuePair("spbill_create_ip",
"127.0.0.1"));
packageParams.add(new BasicNameValuePair("total_fee", "1"));
packageParams.add(new BasicNameValuePair("trade_type", "APP"));
String sign = genPackageSign(packageParams);
packageParams.add(new BasicNameValuePair("sign", sign));
String xmlstring = toXml(packageParams);
return xmlstring;
} catch (Exception e) {
Log.e(TAG, "genProductArgs fail, ex = " + e.getMessage());
return null;
}
}
》獲取預支付訂單編號

String url = String.format("https://api.mch.weixin.qq.com/pay/unifiedorder");
String entity = genProductArgs();
Log.e("orion", entity);
byte[] buf = Util.httpPost(url, entity);
String content = new String(buf);
Log.e("orion", content);
Map<String, String> xml = decodeXml(content);
第二步:生成微信支付參數
appId對應APP應用的APPID,partnerId對應商戶號,prepayId對應第一步獲得的預支付訂單,packageValue取值Sign=WXPay,nonceStr是一串隨機數,timeStamp生成的時間戳,sign對應APP簽名
》支付參數配置
private void genPayReq() {
req.appId = Constants.APP_ID;
req.partnerId = Constants.MCH_ID;
req.prepayId = resultunifiedorder.get("prepay_id");
req.packageValue = "Sign=WXPay";
req.nonceStr = genNonceStr();
req.timeStamp = String.valueOf(genTimeStamp());
List<NameValuePair> signParams = new LinkedList<NameValuePair>();
signParams.add(new BasicNameValuePair("appid", req.appId));
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 = genAppSign(signParams);
sb.append("sign\n" + req.sign + "\n\n");
show.setText(sb.toString());
Log.e("orion", signParams.toString());
}
》nonceStr隨機數
private String genNonceStr() {
Random random = new Random();
return MD5.getMessageDigest(String.valueOf(random.nextInt(10000))
.getBytes());
}
》timeStamp時間戳
private long genTimeStamp() {
return System.currentTimeMillis() / 1000;
}
》APP簽名
private String genAppSign(List<NameValuePair> params) {
StringBuilder sb = new StringBuilder();
for (int i = 0; i < params.size(); i++) {
sb.append(params.get(i).getName());
sb.append('=');
sb.append(params.get(i).getValue());
sb.append('&');
}
sb.append("key=");
sb.append(Constants.API_KEY);
this.sb.append("sign str\n" + sb.toString() + "\n\n");
String appSign = MD5.getMessageDigest(sb.toString().getBytes())
.toUpperCase();
Log.e("orion", appSign);
return appSign;
}
第三步:調起微信APP支付
支付之前,需要手機安裝微信客戶端,如果沒有,會提示下載安裝微信,然後再調起支付,在AndroidManifest.xml文件中添加如下配置
<activity android:name=".act.PayActivity" android:exported="true" android:launchMode="singleTop" > <intent-filter> <action android:name="android.intent.action.VIEW" /> <category android:name="android.intent.category.DEFAULT" /> <data android:scheme="wxf2f565574a968187" /> </intent-filter> </activity>
》調起微信支付

private void sendPayReq() {
msgApi.registerApp(Constants.APP_ID);
msgApi.sendReq(req);
}
接收微信返回結果
在實現了IWXAPIEventHandler接口的Activity中重寫onResp(BaseResp)方法,接收微信結果
》接收支付結果
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(R.string.app_tip);
builder.setMessage(getString(R.string.pay_result_callback_msg,
resp.errStr + ";code=" + String.valueOf(resp.errCode)));
builder.show();
}
}
本文已被整理到了《Android微信支付教程匯總》,《Android微信開發教程匯總》,歡迎大家學習閱讀。
以上就是本文的全部內容,希望對大家的學習有所幫助。
Android 5.X新特性之RecyclerView基本解析及無限復用
說到RecyclerView,相信大家都不陌生,它是我們經典級ListView的升級版,升級後的RecyclerView展現了極大的靈活性。同時內部直接封裝了ViewHo
xmarin.android for vs2015使用百度地圖api3.6.1
首先新建一個binding Library項目,項目名隨意,我這裡起名Bmap 然後將jar文件放入jars目錄下,生成屬性改為EmbeddedJar這時候如果
Android界面編程——日期時間組件(五)
2.6日期時間組件2.6.1 TextClock以文本的方式顯示系統日期和時間,可以自定義顯示格式,是 Android4.2(對應API Level 17)提供的新特性。
Android中的縮略圖加載-不浪費一點多余的內存
1. Why,為什麼要加載縮略圖? 有的時候不需要展示原圖,只需展示圖片的縮略圖,可以節省內存。比如:網易新聞中的圖片浏覽,左邊展示的小獅子圖片就是一個縮略