實現支付寶支付接口的話,首先需要在螞蟻金服官網進行開發入駐。
登錄螞蟻進入開放平台
,進行開發者入駐,這里不講,你們一登錄官網就會看到入駐的入口。
在開發中心
找到開發服務的那一塊的沙箱
,點進去
首先點擊設置公鑰,然后去生成密鑰
然后點擊WINDOWS
鏈接去下載一個東西,這個東西就是去生成密鑰的。
安裝完成之后就是自動生成私鑰和公鑰的軟件,密鑰長度選擇2048。
生成私鑰和公鑰
生成私鑰和公鑰之后,復制一份公鑰,然后再回到沙箱環境,把公鑰設置進去
保存之后它會自動生成一個支付寶的密鑰
說明一點:私鑰、公鑰以及支付寶公鑰都是接口中的參數,私鑰一定不能泄露出去。
然后下載一個沙箱錢包用於下面付款的模擬
點擊沙箱賬號,查看賬號信息,上面的沙箱錢包下載好之后就使用買家信息進行登錄,默認有100000元的余額。
上面的沙箱環境配置好之后就開始轉eclipse
了,這個demo
支付寶支付是在eclipse
上完成的,是web項目,配置完基本的jdk
和Tomcat
之后在螞蟻金服下載Java版本的eclipse環境的支付Demo項目,如果你找不到的話也沒關系,給你個鏈接。
鏈接:https://pan.baidu.com/s/19YcErTnvswB8QDfxDQNPqQ
提取碼:ecjv
設置eclipse
的默認編碼格式為utf-8
,否則會亂碼。不過這個demo項目的頁面是jsp
文件,搞得有點兒不爽,因為現在的公司項目使用的都是Thymeleaf
、beetl
等模板引擎(都是html
頁面),像jsp
很多新項目都舍棄不用了!
由於代碼太多,放在這里不太合適,上面已經把Demo項目鏈接給你們了,下載下來然后打開,我在這里對支付demo分析一下。
項目的目錄結構如下
首先把你剛才生成的私鑰、公鑰以及支付寶公鑰還有APPID這些參數輸到配置類中(只有這一個配置類)
public class AlipayConfig {
//↓↓↓↓↓↓↓↓↓↓請在這里配置您的基本信息↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓
// 應用ID,您的APPID,收款賬號既是您的APPID對應支付寶賬號
public static String app_id = "2016101400681231";
// 商戶私鑰,您的PKCS8格式RSA2私鑰
public static String merchant_private_key = "MIIEvQIBADANBgkqhkiG9w0BAQEFAASCBKcwggSjAgEAAoIBAQCfiB24WONyZadVTNMibZbZ+/zCH22kbQ6yhoS+mxbFzZQPDZPb0JWwbWqfZteS8cvD4lunAafDhhOmUaHbBVbnNjJ5Ym/mdNOhWPI80fWkHkUYL3QZ8Ku0wZ1ZtuxzreYkGd+covUNPj2Lqp45+2/DTNkgHS8FH48V4m+WkIqnZgDN6m18fkFmsdD+e24Im7EYSBmsiFl1+lxa8dJ8v9wUvCgEHzW2FEvtVy90Qk8Gp9kMdt6yczyZu+WtCtzqA5X5Ftb2ROOXAGyb2RVEHQeMJ0dG9+g+qokh+RmNh8qbuXb5ElIa8vG45oJo7DZCIiAnImVU5rN39nchVzt3H3TlAgMBAAECggEAItETI2uK4CmdVnl4zte6B4L+S+OOC0ed4IqJKAwy8SKHwK1G6r9gG+wVTAqm27QXs32QYSd0VLDLUw4X0/QbXkSuyV0ZbONsWJdP7sQn5xSQIdIhdZPX9ZAX5j+M5UY7pv9alRXfg29lATlQZPkiEC6SaHbWDzkvAii0D9kl2ZiKK4rozUYsbdZkV5pJS3eyTJKdqhw/U0KpeguhZ7jLpj7yiDFhovCbR6lJigEH3qnPPeo4ru/CJ5s/D6RO4d8KScgiRRD0uXDdSvJpgiiYQxpSktb+xDeMzeDazkdey6Kp9lKi1LUrSx+NhmQT5opXAARK9wtvygePVVDXXvqPQQKBgQDRDM8LFkOYtLobjnx2XZBZeIJNlvFVsRnR5Z1xtPnrRrBTsFW4Kp5xkX/EDRxO2YGUnLeLhP2Kn2TpYpqN6jv+nQy04mzyZmXWKmC7frWi59i1HhGBUAOKWFbn63t6j6KrQnqK6NPRYyTctTl/IfqFXHW+1WNZr2I7L5MTpIkFNQKBgQDDXEjAITIXSfIV37TH2SH4T4SbcQi7pcUgE2flpr9Gm9k8GXClZgxo7qIvsFervMoXshIBKh9sb7Epzupm1iZFR+oO8MtmLylU67iY+lPSnVoV2lWBD11lmx8zmXQoVKiaVPuF18C6/UUQLiFAEpnyjwy/NazcJY3/wSa1ndMW8QKBgA3Lv5omtP1N5/5Lj/EryYvuBQNj07dpAaA1fAd1/wxE1Pwg5fdKcLxj8r+YcebOOdv5368IbscIL9urEzIMZDswWBdT3ga9NTlGAK4+9XOzwzxoqJUVF7a4j7uscbCr6/tLXtTt+pSV62fZWdsG/gZxDKA0auMPTPdE83rXX+eFAoGAEcmCOjQLioFKEGHI5PVJGYGr8jctc2BZfV0m9YrkGXqxIb6zOev7r0Yi8DKfGNzcjaHB7+c06zuUJtlXEDvpSh+NGQUlj801dyzrJsqL/T4kaJ7zcAfFGi4wfhM3t0BWBY89Q2dsfdn3gsygbGQFLkeGApbRgU3OCv48FwcipBECgYEAmX4XjXlUv4igeaTsPJUd3J35wePKKcRPHWMMFinNURTcVPfLoMdiKPuy0z4krPUSUWZXt0vyqbFFxkipmY9zZR5uMqjXHOslnAmYDPyC+B6MYBdI+5M6GWOhz2kDiWmXz1vYr9Fcjj8kxkY1wnQEodRgAPplwpWMwUg5NFhzMAM=";
// 支付寶公鑰,查看地址:https://openhome.alipay.com/platform/keyManage.htm 對應APPID下的支付寶公鑰。
public static String alipay_public_key = "MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAjjUONnaekkwbEDE08ikwK8KLRqX81dgMdYHKgkCYm62Ps4NpIWshYAPRz8yh/hG9QNdqCb7/DkpW7vBL8Dcv5rEHUq/f6XfhNFkE2mosk3X9DO8vgmqlnqElAgbi6Fagu3kAGbTOQmQobb0Quatq+sUP6ILHbji2mAhwhZUkODwBSxRA2kzNa/+lQByhAVQz8n8nBt105DAnCYBjuJcSopkqtSPneiauWWbiRh3G70Xwqx/x6JSlive6f2advekbfds4Bj05gx/VPlrlFwZyLZBd+UdUeC9Raac9MVEt8zWn+51eE/YENEXJcQQMULLsTIdB5EQWale7cWqAwaCTPQIDAQAB";
// 服務器異步通知頁面路徑 需http://格式的完整路徑,不能加?id=123這類自定義參數,必須外網可以正常訪問
public static String notify_url = "http://工程公網訪問地址/alipay.trade.page.pay-JAVA-UTF-8/notify_url.jsp";
// 頁面跳轉同步通知頁面路徑 需http://格式的完整路徑,不能加?id=123這類自定義參數,必須外網可以正常訪問
public static String return_url = "http://工程公網訪問地址/alipay.trade.page.pay-JAVA-UTF-8/return_url.jsp";
// 簽名方式
public static String sign_type = "RSA2";
// 字符編碼格式
public static String charset = "utf-8";
// 支付寶網關
//因為這是沙箱測試環境,所以支付寶網關應該換一下
public static String gatewayUrl = "https://openapi.alipaydev.com/gateway.do";
// 支付寶網關
public static String log_path = "C:\\";
因為是沙箱環境,所以支付寶網關需要換成測試網關。
// 支付寶網關
//因為這是沙箱測試環境,所以支付寶網關應該換一下
public static String gatewayUrl = "https://openapi.alipaydev.com/gateway.do";
上面已經在沙箱環境那已經展示測試網關了。
然后開始分析付款過程(只是會用這並不行啊兄弟萌,如果老是用的時候來這里拿的話,給你換個環境或者換個模板引擎就又搞不好了,所以這里分析一波)
一,主頁index.html
這是一個普通的表單,作為商品付款表單,付款之后跳轉到alipay.trade.page.pay.jsp
頁面。
<form name=alipayment action=alipay.trade.page.pay.jsp method=post
target="_blank">
<div id="body1" class="show" name="divcontent">
<dl class="content">
<dt>商戶訂單號 :</dt>
<dd>
<input id="WIDout_trade_no" name="WIDout_trade_no" />
</dd>
<hr class="one_line">
<dt>訂單名稱 :</dt>
<dd>
<input id="WIDsubject" name="WIDsubject" />
</dd>
<hr class="one_line">
<dt>付款金額 :</dt>
<dd>
<input id="WIDtotal_amount" name="WIDtotal_amount" />
</dd>
<hr class="one_line">
<dt>商品描述:</dt>
<dd>
<input id="WIDbody" name="WIDbody" />
</dd>
<hr class="one_line">
<dt></dt>
<dd id="btn-dd">
<span class="new-btn-login-sp">
<button class="new-btn-login" type="submit"
style="text-align: center;">付 款</button>
</span> <span class="note-help">如果您點擊“付款”按鈕,即表示您同意該次的執行操作。</span>
</dd>
</dl>
</div>
</form>
二,在index頁面的JS方法生成商品的訂單號
function GetDateNow() {
var vNow = new Date();
var sNow = "";
sNow += String(vNow.getFullYear());
sNow += String(vNow.getMonth() + 1);
sNow += String(vNow.getDate());
sNow += String(vNow.getHours());
sNow += String(vNow.getMinutes());
sNow += String(vNow.getSeconds());
sNow += String(vNow.getMilliseconds());
document.getElementById("WIDout_trade_no").value = sNow;
document.getElementById("WIDsubject").value = "測試";
document.getElementById("WIDtotal_amount").value = "0.01";
}
三,付款參數進行處理
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>付款</title>
</head>
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
<%@ page import="com.alipay.config.*"%>
<%@ page import="com.alipay.api.*"%>
<%@ page import="com.alipay.api.request.*"%>
<%
//獲得初始化的AlipayClient
AlipayClient alipayClient = new DefaultAlipayClient(AlipayConfig.gatewayUrl, AlipayConfig.app_id, AlipayConfig.merchant_private_key, "json", AlipayConfig.charset, AlipayConfig.alipay_public_key, AlipayConfig.sign_type);
//設置請求參數
AlipayTradePagePayRequest alipayRequest = new AlipayTradePagePayRequest();
alipayRequest.setReturnUrl(AlipayConfig.return_url);
alipayRequest.setNotifyUrl(AlipayConfig.notify_url);
//商戶訂單號,商戶網站訂單系統中唯一訂單號,必填
String out_trade_no = new String(request.getParameter("WIDout_trade_no").getBytes("ISO-8859-1"),"UTF-8");
//付款金額,必填
String total_amount = new String(request.getParameter("WIDtotal_amount").getBytes("ISO-8859-1"),"UTF-8");
//訂單名稱,必填
String subject = new String(request.getParameter("WIDsubject").getBytes("ISO-8859-1"),"UTF-8");
//商品描述,可空
String body = new String(request.getParameter("WIDbody").getBytes("ISO-8859-1"),"UTF-8");
alipayRequest.setBizContent("{\"out_trade_no\":\""+ out_trade_no +"\","
+ "\"total_amount\":\""+ total_amount +"\","
+ "\"subject\":\""+ subject +"\","
+ "\"body\":\""+ body +"\","
+ "\"product_code\":\"FAST_INSTANT_TRADE_PAY\"}");
//若想給BizContent增加其他可選請求參數,以增加自定義超時時間參數timeout_express來舉例說明
//alipayRequest.setBizContent("{\"out_trade_no\":\""+ out_trade_no +"\","
// + "\"total_amount\":\""+ total_amount +"\","
// + "\"subject\":\""+ subject +"\","
// + "\"body\":\""+ body +"\","
// + "\"timeout_express\":\"10m\","
// + "\"product_code\":\"FAST_INSTANT_TRADE_PAY\"}");
//請求參數可查閱【電腦網站支付的API文檔-alipay.trade.page.pay-請求參數】章節
//請求
String result = alipayClient.pageExecute(alipayRequest).getBody();
//輸出
out.println(result);
%>
<body>
</body>
</html>
alipayRequest.setBizContent
是把所有商品的參數都設置進去。
最后的result
是一個json
字符串,返回你的支付狀態。
四,付款成功之后跳轉路徑
因為上面在付款jsp
已經設置了付款成功后同步跳轉和異步跳轉的路徑,而在配置類AlipayConfit
中配置了同步跳轉和異步跳轉的路徑,所以付款成功后會同時跳轉兩個路徑。這里就要說明一下了。
支付成功其實跳轉兩個頁面,一個同步跳轉,另一個則異步跳轉。
同步通知頁面
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>電腦網站支付return_url</title>
</head>
<%@ page import="java.util.*"%>
<%@ page import="java.util.Map"%>
<%@ page import="com.alipay.config.*"%>
<%@ page import="com.alipay.api.*"%>
<%@ page import="com.alipay.api.internal.util.*"%>
<%
/* *
* 功能:支付寶服務器同步通知頁面
* 日期:2017-03-30
* 說明:
* 以下代碼只是為了方便商戶測試而提供的樣例代碼,商戶可以根據自己網站的需要,按照技術文檔編寫,並非一定要使用該代碼。
* 該代碼僅供學習和研究支付寶接口使用,只是提供一個參考。
*************************頁面功能說明*************************
* 該頁面僅做頁面展示,業務邏輯處理請勿在該頁面執行
*/
//獲取支付寶GET過來反饋信息
Map<String,String> params = new HashMap<String,String>();
Map<String,String[]> requestParams = request.getParameterMap();
for (Iterator<String> 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] + ",";
}
//亂碼解決,這段代碼在出現亂碼時使用
valueStr = new String(valueStr.getBytes("ISO-8859-1"), "utf-8");
params.put(name, valueStr);
}
boolean signVerified = AlipaySignature.rsaCheckV1(params, AlipayConfig.alipay_public_key, AlipayConfig.charset, AlipayConfig.sign_type); //調用SDK驗證簽名
//——請在這里編寫您的程序(以下代碼僅作參考)——
if(signVerified) {
//商戶訂單號
String out_trade_no = new String(request.getParameter("out_trade_no").getBytes("ISO-8859-1"),"UTF-8");
//支付寶交易號
String trade_no = new String(request.getParameter("trade_no").getBytes("ISO-8859-1"),"UTF-8");
//付款金額
String total_amount = new String(request.getParameter("total_amount").getBytes("ISO-8859-1"),"UTF-8");
out.println("trade_no:"+trade_no+"<br/>out_trade_no:"+out_trade_no+"<br/>total_amount:"+total_amount);
}else {
out.println("驗簽失敗");
}
//——請在這里編寫您的程序(以上代碼僅作參考)——
%>
<body>
</body>
</html>
在同步頁面只需要寫接收從付款jsp
傳過來的參數即可。
異步通知頁面
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@ page import="java.util.*"%>
<%@ page import="java.util.Map"%>
<%@ page import="com.alipay.config.*"%>
<%@ page import="com.alipay.api.*"%>
<%@ page import="com.alipay.api.internal.util.*"%>
<%
/* *
* 功能:支付寶服務器異步通知頁面
* 日期:2017-03-30
* 說明:
* 以下代碼只是為了方便商戶測試而提供的樣例代碼,商戶可以根據自己網站的需要,按照技術文檔編寫,並非一定要使用該代碼。
* 該代碼僅供學習和研究支付寶接口使用,只是提供一個參考。
*************************頁面功能說明*************************
* 創建該頁面文件時,請留心該頁面文件中無任何HTML代碼及空格。
* 該頁面不能在本機電腦測試,請到服務器上做測試。請確保外部可以訪問該頁面。
* 如果沒有收到該頁面返回的 success
* 建議該頁面只做支付成功的業務邏輯處理,退款的處理請以調用退款查詢接口的結果為准。
*/
//獲取支付寶POST過來反饋信息
Map<String,String> params = new HashMap<String,String>();
Map<String,String[]> requestParams = request.getParameterMap();
for (Iterator<String> 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] + ",";
}
//亂碼解決,這段代碼在出現亂碼時使用
valueStr = new String(valueStr.getBytes("ISO-8859-1"), "utf-8");
params.put(name, valueStr);
}
boolean signVerified = AlipaySignature.rsaCheckV1(params, AlipayConfig.alipay_public_key, AlipayConfig.charset, AlipayConfig.sign_type); //調用SDK驗證簽名
//——請在這里編寫您的程序(以下代碼僅作參考)——
/* 實際驗證過程建議商戶務必添加以下校驗:
1、需要驗證該通知數據中的out_trade_no是否為商戶系統中創建的訂單號,
2、判斷total_amount是否確實為該訂單的實際金額(即商戶訂單創建時的金額),
3、校驗通知中的seller_id(或者seller_email) 是否為out_trade_no這筆單據的對應的操作方(有的時候,一個商戶可能有多個seller_id/seller_email)
4、驗證app_id是否為該商戶本身。
*/
if(signVerified) {//驗證成功
//商戶訂單號
String out_trade_no = new String(request.getParameter("out_trade_no").getBytes("ISO-8859-1"),"UTF-8");
//支付寶交易號
String trade_no = new String(request.getParameter("trade_no").getBytes("ISO-8859-1"),"UTF-8");
//交易狀態
String trade_status = new String(request.getParameter("trade_status").getBytes("ISO-8859-1"),"UTF-8");
if(trade_status.equals("TRADE_FINISHED")){
//判斷該筆訂單是否在商戶網站中已經做過處理
//如果沒有做過處理,根據訂單號(out_trade_no)在商戶網站的訂單系統中查到該筆訂單的詳細,並執行商戶的業務程序
//如果有做過處理,不執行商戶的業務程序
//注意:
//退款日期超過可退款期限后(如三個月可退款),支付寶系統發送該交易狀態通知
}else if (trade_status.equals("TRADE_SUCCESS")){
//判斷該筆訂單是否在商戶網站中已經做過處理
//如果沒有做過處理,根據訂單號(out_trade_no)在商戶網站的訂單系統中查到該筆訂單的詳細,並執行商戶的業務程序
//如果有做過處理,不執行商戶的業務程序
//注意:
//付款完成后,支付寶系統發送該交易狀態通知
}
out.println("success");
}else {//驗證失敗
out.println("fail");
//調試用,寫文本函數記錄程序運行情況是否正常
//String sWord = AlipaySignature.getSignCheckContentV1(params);
//AlipayConfig.logResult(sWord);
}
//——請在這里編寫您的程序(以上代碼僅作參考)——
%>
五,測試付款
運行項目
使用沙箱環境付款
然后就支付成功,等待跳轉頁面。
上面是付款,還有交易查詢、退款、退款查詢、交易關閉,都在上面的demo項目中,每一個功能其實就是一個form
表單,然后跳轉一個jsp
,在jsp
里對參數進行處理然后返回一個json
狀態提示成功或失敗,這個demo
項目,它把jsp
當作servlet
來用了,真是過分了!
springboot接入支付寶支付
支付接口
用的開發語言是JAVA,工具為IDEA,一個簡單的springboot工程
1.構建一個普通的springboot工程,引入支付寶SDK的maven依賴
<dependency>
<groupId>com.alipay.sdk</groupId>
<artifactId>alipay-sdk-java</artifactId>
<version>3.0.0</version>
</dependency>
新建一個AlipayConfig類,用於配置支付的相關配置
public class AlipayConfig {
// 應用ID,您的APPID,收款賬號既是您的APPID對應支付寶賬號,開發時使用沙箱提供的APPID,生產環境改成自己的APPID
public static String APP_ID = "你的沙箱APPID";
// 商戶私鑰,您的PKCS8格式RSA2私鑰
public static String APP_PRIVATE_KEY = "你自己的私鑰";
// 支付寶公鑰,查看地址:https://openhome.alipay.com/platform/keyManage.htm 對應APPID下的支付寶公鑰。
public static String ALIPAY_PUBLIC_KEY = "你自己的支付寶公鑰,注意是支付寶公鑰,不是應用公鑰";
// 服務器異步通知頁面路徑 需http://格式的完整路徑,不能加?id=123這類自定義參數,必須外網可以正常訪問
public static String notify_url = "http://localhost:8080/alipay.trade.page.pay-JAVA-UTF-8/notify_url.jsp";
// 頁面跳轉同步通知頁面路徑 需http://格式的完整路徑,不能加?id=123這類自定義參數,必須外網可以正常訪問(其實就是支付成功后返回的頁面)
public static String return_url = "http://localhost:8080/alipay.trade.page.pay-JAVA-UTF-8/return_url.jsp";
// 簽名方式
public static String sign_type = "RSA2";
// 字符編碼格式
public static String CHARSET = "utf-8";
// 支付寶網關,這是沙箱的網關
public static String gatewayUrl = "https://openapi.alipaydev.com/gateway.do";
// 支付寶網關
public static String log_path = "C:\\";
//↑↑↑↑↑↑↑↑↑↑請在這里配置您的基本信息↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑
/**
* 寫日志,方便測試(看網站需求,也可以改成把記錄存入數據庫)
* @param sWord 要寫入日志里的文本內容
*/
public static void logResult(String sWord) {
FileWriter writer = null;
try {
writer = new FileWriter(log_path + "alipay_log_" + System.currentTimeMillis()+".txt");
writer.write(sWord);
} catch (Exception e) {
e.printStackTrace();
} finally {
if (writer != null) {
try {
writer.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
}
3.新建一個controller包,用於存放Action,新建一個PayController類,編寫一個用於支付的接口/pay
@RestController
public class PayController {
@RequestMapping("/pay")
public void payController(HttpServletRequest request, HttpServletResponse response) throws IOException {
//獲得初始化的AlipayClient
AlipayClient alipayClient = new DefaultAlipayClient(AlipayConfig.gatewayUrl, AlipayConfig.APP_ID, AlipayConfig.APP_PRIVATE_KEY, "json", AlipayConfig.CHARSET, AlipayConfig.ALIPAY_PUBLIC_KEY, AlipayConfig.sign_type);
//設置請求參數
AlipayTradePagePayRequest alipayRequest = new AlipayTradePagePayRequest();
alipayRequest.setReturnUrl(AlipayConfig.return_url);
alipayRequest.setNotifyUrl(AlipayConfig.notify_url);
//商戶訂單號,商戶網站訂單系統中唯一訂單號,必填
String out_trade_no = new String(request.getParameter("WIDout_trade_no").getBytes("ISO-8859-1"),"UTF-8");
//付款金額,必填
String total_amount = new String(request.getParameter("WIDtotal_amount").getBytes("ISO-8859-1"),"UTF-8");
//訂單名稱,必填
String subject = new String(request.getParameter("WIDsubject").getBytes("ISO-8859-1"),"UTF-8");
//商品描述,可空
String body = new String(request.getParameter("WIDbody").getBytes("ISO-8859-1"),"UTF-8");
alipayRequest.setBizContent("{\"out_trade_no\":\""+ out_trade_no +"\","
+ "\"total_amount\":\""+ total_amount +"\","
+ "\"subject\":\""+ subject +"\","
+ "\"body\":\""+ body +"\","
+ "\"product_code\":\"FAST_INSTANT_TRADE_PAY\"}");
//若想給BizContent增加其他可選請求參數,以增加自定義超時時間參數timeout_express來舉例說明
//alipayRequest.setBizContent("{\"out_trade_no\":\""+ out_trade_no +"\","
// + "\"total_amount\":\""+ total_amount +"\","
// + "\"subject\":\""+ subject +"\","
// + "\"body\":\""+ body +"\","
// + "\"timeout_express\":\"10m\","
// + "\"product_code\":\"FAST_INSTANT_TRADE_PAY\"}");
//請求參數可查閱【電腦網站支付的API文檔-alipay.trade.page.pay-請求參數】章節
//請求
String form="";
try {
form = alipayClient.pageExecute(alipayRequest).getBody(); //調用SDK生成表單
} catch (AlipayApiException e) {
e.printStackTrace();
}
response.setContentType("text/html;charset=" + AlipayConfig.CHARSET);
response.getWriter().write(form);//直接將完整的表單html輸出到頁面
response.getWriter().flush();
response.getWriter().close();
}
4,新建一個JSP頁面,用於模擬提交訂單
首先要添加JSP的相關依賴
<!-- tomcat 依賴包 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</dependency>
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-jasper</artifactId>
</dependency>
<!-- servlet 依賴包 -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
</dependency>
配置文件添加springMvc的映射路徑
spring.mvc.view.prefix=/WEB-INF/jsp/
spring.mvc.view.suffix=.jsp
新建一個頁面,頁面所在的目錄
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<form action="/pay" method="post">
訂單號:<input type="text" name="WIDout_trade_no" required><br/>
訂單名稱:<input type="text" name="WIDsubject" required><br/>
付款金額:<input type="text" name="WIDtotal_amount" required><br/>
WIDbody:<input type="text" name="WIDbody"><br/>
<input type="submit" value="下單"> <input type="reset" value="重置">
</form>
- controller類添加跳轉到jsp頁面的映射
@RequestMapping("/")
public String toTest(){
return "index";
}
6.測試運行,啟動項目,在瀏覽器輸入:http://localhost:8080/
輸入訂單號,訂單名稱,金額,就可以跳轉到支付寶的支付頁面了
這里跳轉回去的頁面就是之前AlipayConfig類中的return_url 在這之前需要進入notify_url 接口進行驗簽,這兩個接口就不演示了,先知道這回事,實際開發的時候再進行開發。
退款接口
<form name=traderefund action=alipay.trade.refund.jsp method=post
target="_blank">
<div id="body3" class="tab-content" name="divcontent">
<dl class="content">
<dt>商戶訂單號 :</dt>
<dd>
<input id="WIDTRout_trade_no" name="WIDTRout_trade_no" />
</dd>
<hr class="one_line">
<dt>支付寶交易號 :</dt>
<dd>
<input id="WIDTRtrade_no" name="WIDTRtrade_no" />
</dd>
<hr class="one_line">
<dt>退款金額 :</dt>
<dd>
<input id="WIDTRrefund_amount" name="WIDTRrefund_amount" />
</dd>
<hr class="one_line">
<dt>退款原因 :</dt>
<dd>
<input id="WIDTRrefund_reason" name="WIDTRrefund_reason" />
</dd>
<hr class="one_line">
<dt>退款請求號 :</dt>
<dd>
<input id="WIDTRout_request_no" name="WIDTRout_request_no" />
</dd>
<hr class="one_line">
<dt></dt>
<dd id="btn-dd">
<span class="new-btn-login-sp">
<button class="new-btn-login" type="submit"
style="text-align: center;">退 款</button>
</span> <span class="note-help">商戶訂單號與支付寶交易號二選一,如果您點擊“退款”按鈕,即表示您同意該次的執行操作。</span>
</dd>
</dl>
</div>
</form>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>退款</title>
</head>
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
<%@ page import="com.alipay.config.*"%>
<%@ page import="com.alipay.api.*"%>
<%@ page import="com.alipay.api.request.*"%>
<%
//獲得初始化的AlipayClient
AlipayClient alipayClient = new DefaultAlipayClient(AlipayConfig.gatewayUrl, AlipayConfig.app_id, AlipayConfig.merchant_private_key, "json", AlipayConfig.charset, AlipayConfig.alipay_public_key, AlipayConfig.sign_type);
//設置請求參數
AlipayTradeRefundRequest alipayRequest = new AlipayTradeRefundRequest();
//商戶訂單號,商戶網站訂單系統中唯一訂單號
String out_trade_no = new String(request.getParameter("WIDTRout_trade_no").getBytes("ISO-8859-1"),"UTF-8");
//支付寶交易號
String trade_no = new String(request.getParameter("WIDTRtrade_no").getBytes("ISO-8859-1"),"UTF-8");
//請二選一設置
//需要退款的金額,該金額不能大於訂單金額,必填
String refund_amount = new String(request.getParameter("WIDTRrefund_amount").getBytes("ISO-8859-1"),"UTF-8");
//退款的原因說明
String refund_reason = new String(request.getParameter("WIDTRrefund_reason").getBytes("ISO-8859-1"),"UTF-8");
//標識一次退款請求,同一筆交易多次退款需要保證唯一,如需部分退款,則此參數必傳
String out_request_no = new String(request.getParameter("WIDTRout_request_no").getBytes("ISO-8859-1"),"UTF-8");
alipayRequest.setBizContent("{\"out_trade_no\":\""+ out_trade_no +"\","
+ "\"trade_no\":\""+ trade_no +"\","
+ "\"refund_amount\":\""+ refund_amount +"\","
+ "\"refund_reason\":\""+ refund_reason +"\","
+ "\"out_request_no\":\""+ out_request_no +"\"}");
//請求
String result = alipayClient.execute(alipayRequest).getBody();
//輸出
out.println(result);
%>
<body>
</body>
</html>
退款查詢接口
<form name=traderefundquery
action=alipay.trade.fastpay.refund.query.jsp method=post
target="_blank">
<div id="body4" class="tab-content" name="divcontent">
<dl class="content">
<dt>商戶訂單號 :</dt>
<dd>
<input id="WIDRQout_trade_no" name="WIDRQout_trade_no" />
</dd>
<hr class="one_line">
<dt>支付寶交易號 :</dt>
<dd>
<input id="WIDRQtrade_no" name="WIDRQtrade_no" />
</dd>
<hr class="one_line">
<dt>退款請求號 :</dt>
<dd>
<input id="WIDRQout_request_no" name="WIDRQout_request_no" />
</dd>
<hr class="one_line">
<dt></dt>
<dd id="btn-dd">
<span class="new-btn-login-sp">
<button class="new-btn-login" type="submit"
style="text-align: center;">退 款 查 詢</button>
</span> <span class="note-help">商戶訂單號與支付寶交易號二選一,如果您點擊“退款查詢”按鈕,即表示您同意該次的執行操作。</span>
</dd>
</dl>
</div>
</form>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>退款查詢</title>
</head>
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
<%@ page import="com.alipay.config.*"%>
<%@ page import="com.alipay.api.*"%>
<%@ page import="com.alipay.api.request.*"%>
<%
//獲得初始化的AlipayClient
AlipayClient alipayClient = new DefaultAlipayClient(AlipayConfig.gatewayUrl, AlipayConfig.app_id, AlipayConfig.merchant_private_key, "json", AlipayConfig.charset, AlipayConfig.alipay_public_key, AlipayConfig.sign_type);
//設置請求參數
AlipayTradeFastpayRefundQueryRequest alipayRequest = new AlipayTradeFastpayRefundQueryRequest();
//商戶訂單號,商戶網站訂單系統中唯一訂單號
String out_trade_no = new String(request.getParameter("WIDRQout_trade_no").getBytes("ISO-8859-1"),"UTF-8");
//支付寶交易號
String trade_no = new String(request.getParameter("WIDRQtrade_no").getBytes("ISO-8859-1"),"UTF-8");
//請二選一設置
//請求退款接口時,傳入的退款請求號,如果在退款請求時未傳入,則該值為創建交易時的外部交易號,必填
String out_request_no = new String(request.getParameter("WIDRQout_request_no").getBytes("ISO-8859-1"),"UTF-8");
alipayRequest.setBizContent("{\"out_trade_no\":\""+ out_trade_no +"\","
+"\"trade_no\":\""+ trade_no +"\","
+"\"out_request_no\":\""+ out_request_no +"\"}");
//請求
String result = alipayClient.execute(alipayRequest).getBody();
//輸出
out.println(result);
%>
<body>
</body>
</html>
交易查詢接口
<form name=tradequery action=alipay.trade.query.jsp method=post
target="_blank">
<div id="body2" class="tab-content" name="divcontent">
<dl class="content">
<dt>商戶訂單號 :</dt>
<dd>
<input id="WIDTQout_trade_no" name="WIDTQout_trade_no" />
</dd>
<hr class="one_line">
<dt>支付寶交易號 :</dt>
<dd>
<input id="WIDTQtrade_no" name="WIDTQtrade_no" />
</dd>
<hr class="one_line">
<dt></dt>
<dd id="btn-dd">
<span class="new-btn-login-sp">
<button class="new-btn-login" type="submit"
style="text-align: center;">交 易 查 詢</button>
</span> <span class="note-help">商戶訂單號與支付寶交易號二選一,如果您點擊“交易查詢”按鈕,即表示您同意該次的執行操作。</span>
</dd>
</dl>
</div>
</form>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>交易查詢</title>
</head>
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
<%@ page import="com.alipay.config.*"%>
<%@ page import="com.alipay.api.*"%>
<%@ page import="com.alipay.api.request.*"%>
<%
//獲得初始化的AlipayClient
AlipayClient alipayClient = new DefaultAlipayClient(AlipayConfig.gatewayUrl, AlipayConfig.app_id, AlipayConfig.merchant_private_key, "json", AlipayConfig.charset, AlipayConfig.alipay_public_key, AlipayConfig.sign_type);
//設置請求參數
AlipayTradeQueryRequest alipayRequest = new AlipayTradeQueryRequest();
//商戶訂單號,商戶網站訂單系統中唯一訂單號
String out_trade_no = new String(request.getParameter("WIDTQout_trade_no").getBytes("ISO-8859-1"),"UTF-8");
//支付寶交易號
String trade_no = new String(request.getParameter("WIDTQtrade_no").getBytes("ISO-8859-1"),"UTF-8");
//請二選一設置
alipayRequest.setBizContent("{\"out_trade_no\":\""+ out_trade_no +"\","+"\"trade_no\":\""+ trade_no +"\"}");
//請求
String result = alipayClient.execute(alipayRequest).getBody();
//輸出
out.println(result);
%>
<body>
</body>
</html>
交易關閉接口
<form name=tradeclose action=alipay.trade.close.jsp method=post
target="_blank">
<div id="body5" class="tab-content" name="divcontent">
<dl class="content">
<dt>商戶訂單號 :</dt>
<dd>
<input id="WIDTCout_trade_no" name="WIDTCout_trade_no" />
</dd>
<hr class="one_line">
<dt>支付寶交易號 :</dt>
<dd>
<input id="WIDTCtrade_no" name="WIDTCtrade_no" />
</dd>
<hr class="one_line">
<dt></dt>
<dd id="btn-dd">
<span class="new-btn-login-sp">
<button class="new-btn-login" type="submit"
style="text-align: center;">交 易 關 閉</button>
</span> <span class="note-help">商戶訂單號與支付寶交易號二選一,如果您點擊“交易關閉”按鈕,即表示您同意該次的執行操作。</span>
</dd>
</dl>
</div>
</form>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>交易關閉</title>
</head>
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
<%@ page import="com.alipay.config.*"%>
<%@ page import="com.alipay.api.*"%>
<%@ page import="com.alipay.api.request.*"%>
<%
//獲得初始化的AlipayClient
AlipayClient alipayClient = new DefaultAlipayClient(AlipayConfig.gatewayUrl, AlipayConfig.app_id, AlipayConfig.merchant_private_key, "json", AlipayConfig.charset, AlipayConfig.alipay_public_key, AlipayConfig.sign_type);
//設置請求參數
AlipayTradeCloseRequest alipayRequest = new AlipayTradeCloseRequest();
//商戶訂單號,商戶網站訂單系統中唯一訂單號
String out_trade_no = new String(request.getParameter("WIDTCout_trade_no").getBytes("ISO-8859-1"),"UTF-8");
//支付寶交易號
String trade_no = new String(request.getParameter("WIDTCtrade_no").getBytes("ISO-8859-1"),"UTF-8");
//請二選一設置
alipayRequest.setBizContent("{\"out_trade_no\":\""+ out_trade_no +"\"," +"\"trade_no\":\""+ trade_no +"\"}");
//請求
String result = alipayClient.execute(alipayRequest).getBody();
//輸出
out.println(result);
%>
<body>
</body>
</html>