支付寶開發(fā)文檔地址
(https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=11_1)

系統(tǒng)交互流程
支付寶參數(shù)配置
public class AliPayConfig {
// 1.商戶appid
public static String APP_ID = "yourAppId";
// 2.請求網(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.服務器異步通知頁面路徑
public static String ASY_URL = "yourAsyUrl";
// 6.編碼
public static String CHARSET = "UTF-8";
// 7.返回格式
public static String FORMAT = "json";
// 8.加密類型
public static String SIGNTYPE = "RSA2";
}
創(chuàng)建訂單
public static JSONObject createPayOrder(String orderId, String cost,
String describe) {
JSONObject ret = new JSONObject();
// 實例化客戶端
AlipayClient alipayClient = new DefaultAlipayClient(
AliPayConfig.SERVER_URL, AliPayConfig.APP_ID,
AliPayConfig.APP_PRIVATE_KEY, AliPayConfig.FORMAT,
AliPayConfig.CHARSET, AliPayConfig.ALIPAY_PUBLIC_KEY,
AliPayConfig.SIGNTYPE);
// 實例化具體API對應的request類,類名稱和接口名稱對應,當前調(diào)用接口名稱:alipay.trade.app.pay
AlipayTradeAppPayRequest request = new AlipayTradeAppPayRequest();
// SDK已經(jīng)封裝掉了公共參數(shù),這里只需要傳入業(yè)務參數(shù)。以下方法為sdk的model入?yún)⒎绞?model和biz_content同時存在的情況下取biz_content)。
AlipayTradeAppPayModel model = new AlipayTradeAppPayModel();
model.setBody(describe);
model.setSubject("App支付測試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
// 可以直接給客戶端請求,無需再做處理。
} 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過來反饋信息
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)亂碼時使用。
// valueStr = new String(valueStr.getBytes("ISO-8859-1"), "utf-8");
params.put(name, valueStr);
}
// 獲取到返回的所有參數(shù) 先判斷是否交易成功trade_status 再做簽名校驗
// 1、商戶需要驗證該通知數(shù)據(jù)中的out_trade_no是否為商戶系統(tǒng)中創(chuàng)建的訂單號,
// 2、判斷total_amount是否確實為該訂單的實際金額(即商戶訂單創(chuàng)建時的金額),
// 3、校驗通知中的seller_id(或者seller_email)
// 是否為out_trade_no這筆單據(jù)的對應的操作方(有的時候,一個商戶可能有多個seller_id/seller_email),
// 4、驗證app_id是否為該商戶本身。上述1、2、3、4有任何一個驗證不通過,則表明本次通知是異常通知,務必忽略。
try {
// 驗證簽名
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");
// 用戶支付金額
String amount = params.get("buyer_pay_amount");
// 商戶訂單號
String out_trade_no = params.get("out_trade_no");
// 支付寶交易號
String trade_no = params.get("trade_no");
// 買家支付寶賬號
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)建時間
String gmt_create = params.get("gmt_create");
// 交易付款時間
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對應的request類
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 + "\"" + " }");// 設置業(yè)務參數(shù)
AlipayTradeRefundResponse response;
try {
response = alipayClient.execute(request);
if (response.isSuccess()) {
strResponse = "退款成功";
} else {
strResponse = "退款失敗";
}
} catch (AlipayApiException e) {
strResponse = "退款出錯";
}
return strResponse;
}
訂單查詢
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對應的request類
request.setBizContent("{" + " \"out_trade_no\":\"" + out_trade_no
+ "\"," + " \"trade_no\":\"" + trade_no + "\"" + " }");// 設置業(yè)務參數(shù)
AlipayTradeQueryResponse response;
try {
response = alipayClient.execute(request);
System.out.print(response.getBody());
Map<String, String> restmap = new HashMap<String, String>();// 返回提交支付寶訂單交易查詢信息
boolean flag = false; // 查詢狀態(tài)
if (response.isSuccess()) {
// 調(diào)用成功,則處理業(yè)務邏輯
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();
}
}