支付寶開(kāi)發(fā)文檔地址
(https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=11_1)
系統(tǒng)交互流程
支付寶參數(shù)配置
public class AliPayConfig {
// 1.商戶(hù)appid
public static String APP_ID = "yourAppId";
// 2.請(qǐng)求網(wǎng)關(guān)地址
public static String SERVER_URL = "https://openapi.alipay.com/gateway.do";
// 3.私鑰
public static String APP_PRIVATE_KEY = "yourAppPrivateKey";
// 4.支付寶公鑰
public static String ALIPAY_PUBLIC_KEY = "yourAlipayPublicKey";
// 5.服務(wù)器異步通知頁(yè)面路徑
public static String ASY_URL = "yourAsyUrl";
// 6.編碼
public static String CHARSET = "UTF-8";
// 7.返回格式
public static String FORMAT = "json";
// 8.加密類(lèi)型
public static String SIGNTYPE = "RSA2";
}
創(chuàng)建訂單
public static JSONObject createPayOrder(String orderId, String cost,
String describe) {
JSONObject ret = new JSONObject();
// 實(shí)例化客戶(hù)端
AlipayClient alipayClient = new DefaultAlipayClient(
AliPayConfig.SERVER_URL, AliPayConfig.APP_ID,
AliPayConfig.APP_PRIVATE_KEY, AliPayConfig.FORMAT,
AliPayConfig.CHARSET, AliPayConfig.ALIPAY_PUBLIC_KEY,
AliPayConfig.SIGNTYPE);
// 實(shí)例化具體API對(duì)應(yīng)的request類(lèi),類(lèi)名稱(chēng)和接口名稱(chēng)對(duì)應(yīng),當(dāng)前調(diào)用接口名稱(chēng):alipay.trade.app.pay
AlipayTradeAppPayRequest request = new AlipayTradeAppPayRequest();
// SDK已經(jīng)封裝掉了公共參數(shù),這里只需要傳入業(yè)務(wù)參數(shù)荔烧。以下方法為sdk的model入?yún)⒎绞?model和biz_content同時(shí)存在的情況下取biz_content)懈叹。
AlipayTradeAppPayModel model = new AlipayTradeAppPayModel();
model.setBody(describe);
model.setSubject("App支付測(cè)試Java");
model.setOutTradeNo(orderId);
model.setTimeoutExpress("20m");
model.setTotalAmount(cost);
model.setProductCode("QUICK_MSECURITY_PAY");
request.setBizModel(model);
request.setNotifyUrl(AliPayConfig.ASY_URL);
System.out.println(request);
String orderStr = "";
try {
// 這里和普通的接口調(diào)用不同,使用的是sdkExecute
AlipayTradeAppPayResponse response = alipayClient
.sdkExecute(request);
orderStr = response.getBody();
System.out.println(response.getBody());// 就是orderString
// 可以直接給客戶(hù)端請(qǐng)求豁生,無(wú)需再做處理。
} catch (AlipayApiException e) {
ret.put("code", ErrorCode.OTHER);
ret.put("msg", e.getMessage());
return ret;
}
ret.put("code", ErrorCode.SUCCESS);
ret.put("sign", orderStr);
return ret;
}
支付寶結(jié)果異步回調(diào)
public static JSONObject aliPayNotify(Map<String, String[]> requestParams) {
JSONObject result = new JSONObject();
System.out.println("支付寶支付結(jié)果通知" + requestParams.toString());
// 獲取支付寶POST過(guò)來(lái)反饋信息
Map<String, String> params = new HashMap<String, String>();
for (Iterator<?> iter = requestParams.keySet().iterator(); iter
.hasNext();) {
String name = (String) iter.next();
String[] values = (String[]) requestParams.get(name);
String valueStr = "";
for (int i = 0; i < values.length; i++) {
valueStr = (i == values.length - 1) ? valueStr + values[i]
: valueStr + values[i] + ",";
}
// 亂碼解決,這段代碼在出現(xiàn)亂碼時(shí)使用特漩。
// valueStr = new String(valueStr.getBytes("ISO-8859-1"), "utf-8");
params.put(name, valueStr);
}
// 獲取到返回的所有參數(shù) 先判斷是否交易成功trade_status 再做簽名校驗(yàn)
// 1、商戶(hù)需要驗(yàn)證該通知數(shù)據(jù)中的out_trade_no是否為商戶(hù)系統(tǒng)中創(chuàng)建的訂單號(hào)骨杂,
// 2涂身、判斷total_amount是否確實(shí)為該訂單的實(shí)際金額(即商戶(hù)訂單創(chuàng)建時(shí)的金額),
// 3搓蚪、校驗(yàn)通知中的seller_id(或者seller_email)
// 是否為out_trade_no這筆單據(jù)的對(duì)應(yīng)的操作方(有的時(shí)候蛤售,一個(gè)商戶(hù)可能有多個(gè)seller_id/seller_email),
// 4妒潭、驗(yàn)證app_id是否為該商戶(hù)本身悴能。上述1、2雳灾、3漠酿、4有任何一個(gè)驗(yàn)證不通過(guò),則表明本次通知是異常通知谎亩,務(wù)必忽略炒嘲。
try {
// 驗(yàn)證簽名
boolean flag = AlipaySignature.rsaCheckV1(params,
AliPayConfig.ALIPAY_PUBLIC_KEY, "utf-8", "RSA2");
if (flag) {
if ("TRADE_SUCCESS".equals(params.get("trade_status"))
|| "TRADE_FINISHED".equals(params.get("trade_status"))) {
String appId = params.get("app_id");
if (!appId.equals(AliPayConfig.APP_ID)) {
result.put("code", ErrorCode.OTHER);
return result;
}
// 訂單金額
String total_amount = params.get("total_amount");
// 用戶(hù)支付金額
String amount = params.get("buyer_pay_amount");
// 商戶(hù)訂單號(hào)
String out_trade_no = params.get("out_trade_no");
// 支付寶交易號(hào)
String trade_no = params.get("trade_no");
// 買(mǎi)家支付寶賬號(hào)
String buyer_logon_id = params.get("buyer_logon_id");
// 交易狀態(tài)
String trade_status = params.get("trade_status");
// 商品描述
String body = params.get("body");
// 交易創(chuàng)建時(shí)間
String gmt_create = params.get("gmt_create");
// 交易付款時(shí)間
String gmt_payment = params.get("gmt_payment");
JSONObject payParams = new JSONObject();
payParams.put("total_amount", total_amount);
payParams.put("amount", amount);
payParams.put("out_trade_no", out_trade_no);
payParams.put("trade_no", trade_no);
payParams.put("buyer_logon_id", buyer_logon_id);
payParams.put("trade_status", trade_status);
payParams.put("body", body);
payParams.put("gmt_create", gmt_create);
payParams.put("gmt_payment", gmt_payment);
result.put("params", payParams);
result.put("code", ErrorCode.SUCCESS);
}
} else {
result.put("code", ErrorCode.OTHER);
return result;
}
} catch (AlipayApiException e) {
result.put("code", ErrorCode.OTHER);
return result;
}
return result;
}
退款
public String AliRefund(String out_trade_no, String trade_no,
String out_request_no, String refund_amount) {
AlipayClient alipayClient = new DefaultAlipayClient(
"https://openapi.alipay.com/gateway.do", AliPayConfig.APP_ID,
AliPayConfig.APP_PRIVATE_KEY, "json", "utf-8",
AliPayConfig.ALIPAY_PUBLIC_KEY, "RSA2"); // 獲得初始化的AlipayClient
AlipayTradeRefundRequest request = new AlipayTradeRefundRequest();// 創(chuàng)建API對(duì)應(yīng)的request類(lèi)
String strResponse = null;
request.setBizContent("{" + " \"out_trade_no\":\"" + out_trade_no
+ "\"," + " \"trade_no\":\"" + trade_no + "\","
+ " \"out_request_no\":\"" + out_request_no + "\","
+ " \"refund_amount\":\"" + refund_amount + "\"" + " }");// 設(shè)置業(yè)務(wù)參數(shù)
AlipayTradeRefundResponse response;
try {
response = alipayClient.execute(request);
if (response.isSuccess()) {
strResponse = "退款成功";
} else {
strResponse = "退款失敗";
}
} catch (AlipayApiException e) {
strResponse = "退款出錯(cuò)";
}
return strResponse;
}
訂單查詢(xún)
public void orderPayQuery(String trade_no, String out_trade_no) {
AlipayClient alipayClient = new DefaultAlipayClient(
"https://openapi.alipay.com/gateway.do", AliPayConfig.APP_ID,
AliPayConfig.APP_PRIVATE_KEY, "json", "utf-8",
AliPayConfig.ALIPAY_PUBLIC_KEY, "RSA2"); // 獲得初始化的AlipayClient
AlipayTradeQueryRequest request = new AlipayTradeQueryRequest();// 創(chuàng)建API對(duì)應(yīng)的request類(lèi)
request.setBizContent("{" + " \"out_trade_no\":\"" + out_trade_no
+ "\"," + " \"trade_no\":\"" + trade_no + "\"" + " }");// 設(shè)置業(yè)務(wù)參數(shù)
AlipayTradeQueryResponse response;
try {
response = alipayClient.execute(request);
System.out.print(response.getBody());
Map<String, String> restmap = new HashMap<String, String>();// 返回提交支付寶訂單交易查詢(xún)信息
boolean flag = false; // 查詢(xún)狀態(tài)
if (response.isSuccess()) {
// 調(diào)用成功,則處理業(yè)務(wù)邏輯
if ("10000".equals(response.getCode())) {
// 訂單創(chuàng)建成功
flag = true;
restmap.put("order_no", response.getOutTradeNo());
restmap.put("trade_no", response.getTradeNo());
restmap.put("buyer_logon_id", response.getBuyerLogonId());
restmap.put("trade_status", response.getTradeStatus());
} else {
}
}
} catch (AlipayApiException e) {
e.printStackTrace();
}
}