Java如何在沙箱環(huán)境中測試支付寶支付接口
java沙箱環(huán)境測試支付寶支付接口?
準備工作,登陸支付寶開放平臺,進入沙箱環(huán)境
開放平臺鏈接:https://developers.alipay.com/platform/developerIndex.htm


沙箱環(huán)境中給測試提供了一些必要和非必要的參數(shù),需要自己動手修改的只有RSA密鑰,需要通過支付寶提供的開發(fā)工具生成RSA密鑰,下載鏈接:https://docs.open.alipay.com/291/105971#LDsXr
下載完成安裝之后,可以生成RSA密鑰.生成的密鑰分為應用公鑰,應用私鑰.應用私鑰自己保存,應用公鑰應該到支付寶的開放平臺上生成相應的支付寶公鑰才可以正常使用.


沙箱工具中點擊設置


將RSA生成的應用公鑰,復制到下面的文本框中,點擊保存設置

保存好

上述操作完成后,即可進行代碼的編寫.
進入開發(fā)工具編寫代碼
創(chuàng)建配置類,用作初始化配置
public class AlipayConfig {
// 應用ID,支付寶提供的APPID,上面截圖中有提到
public static String app_id = "2016101200670453";
// 商戶私鑰,您的PKCS8格式RSA2私鑰
public static String merchant_private_key = "這里寫入上面生成的**應用私鑰**";
// 支付寶公鑰,查看地址:https://openhome.alipay.com/platform/appDaily.htm 對應APPID下的支付寶公鑰。
public static String alipay_public_key = "注意是上面再三提示的支付寶公鑰";
// 服務器異步通知頁面路徑 需http://格式的完整路徑,不能加?id=123這類自定義參數(shù),必須外網可以正常訪問.如果只是測試使用,那么設置成自己項目啟動后可以訪問到的一個路徑,作為支付寶發(fā)送通知的路徑(有什么用暫時沒發(fā)現(xiàn))
public static String notify_url = "http://localhost:8080/pay/alipay-callback-notify-url";
// 頁面跳轉同步通知頁面路徑 需http://格式的完整路徑,不能加?id=123這類自定義參數(shù),必須外網可以正常訪問.如果只是測試使用,那么設置成自己項目啟動后可以訪問到的一個路徑.是支付正常完成后,會訪問的路徑.
public static String return_url = "http://localhost:8080/pay/alipay-callback-return-sult";
// 簽名方式,注意這里,如果步驟設置的是RSA則用RSA,如果按照扇面步驟做的話,選擇RSA2
public static String sign_type = "RSA2";
// 字符編碼格式
public static String charset = "utf-8";
// 支付寶網關
public static String gatewayUrl = "https://openapi.alipaydev.com/gateway.do";
}
導入Maven坐標
<dependency>
<groupId>com.alipay.sdk</groupId>
<artifactId>alipay-sdk-java</artifactId>
<version>3.7.4.ALL</version>
</dependency>
創(chuàng)建配置類,用作初始化配置
寫Controller類供前臺訪問,去調用支付接口.
@RequestMapping("/toPay")//設置請求的路徑
@ResponseBody//記得加上,否則無法正常調用
public String toPay(String id,String sumMoney) throws Exception{
byte[] serialize = SerializeUtil.serialize(orderIds);
redisServer.setCacheValueForTime(uuid,serialize,1000*60*60*30);
//獲得初始化的AlipayClient,將上面創(chuàng)建的配置類中的變量設置到該對象中
AlipayClient alipayClient = new DefaultAlipayClient(AlipayConfig.gatewayUrl, AlipayConfig.app_id, AlipayConfig.merchant_private_key, "json", AlipayConfig.charset, AlipayConfig.alipay_public_key, AlipayConfig.sign_type);
//設置請求參數(shù),并把配置類中的兩個路徑設置進去
AlipayTradePagePayRequest alipayRequest = new AlipayTradePagePayRequest();
alipayRequest.setReturnUrl(AlipayConfig.return_url);
alipayRequest.setNotifyUrl(AlipayConfig.notify_url);
//如果想正常調用接口則需要傳一些必要參數(shù),out_trade_no:訂單號,保證唯一性,支付寶根據(jù)該參數(shù)生成你的支付單號,total_amount:需要支付的金額,注意是String型,且金額計數(shù)的分割","不能存在(例如1,000就是錯誤的參數(shù)),subject:對物品進行描述,product_code:是支付類型.更多詳細的參數(shù)信息參考鏈接: [https://docs.open.alipay.com/api_1/alipay.trade.page.pay](https://docs.open.alipay.com/api_1/alipay.trade.page.pay)
try {
alipayRequest.setBizContent("{\"out_trade_no\":\""+id +"\","
+ "\"total_amount\":\""+sumMoney +"\","
+ "\"subject\":\""+ "測試支付" +"\","
+ "\"product_code\":\"FAST_INSTANT_TRADE_PAY\"}");
//請求
String result;
//發(fā)送請求并返回
result = alipayClient.pageExecute(alipayRequest).getBody();
//System.out.println("*********************\n返回結果為:"+result);
return result;
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
return null;
}
}
這是配置類中設置的跳轉路徑,可自行編寫業(yè)務
@RequestMapping("alipay-callback-return-sult")
public String successResult(HttpServletRequest request, HttpServletResponse response){
//可以根據(jù)request.getParameterMap()獲得到調用接口時傳遞的一些參數(shù)去做后續(xù)的業(yè)務處理
Map<String, String[]> parameterMap = request.getParameterMap();
String[] out_trade_nos = parameterMap.get("out_trade_no");
String id = out_trade_nos[0];
//跳轉到其他頁面或重定向到其他方法
return "redirect:/good/toPayFor";
}
@RequestMapping("alipay-callback-notify-url")
public String failResult(HttpServletRequest request, HttpServletResponse response){
Map<String, String[]> parameterMap = request.getParameterMap();
String[] out_trade_nos = parameterMap.get("out_trade_no");
String uuid = out_trade_nos[0];
orderService.updateOrderInfo(uuid);
return "redirect:/good/toPayFor";
}
運行項目,發(fā)送請求.跳轉到如下路徑代表成功.
結果展示

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
SpringBoot+MyBatis實現(xiàn)MD5加密數(shù)據(jù)庫用戶密碼的方法
MD5技術主要用于對用戶密碼加密,增加賬戶的安全性,他具有不可逆的特性,不會被輕易解密,這篇文章給大家介紹SpringBoot+MyBatis實現(xiàn)MD5加密數(shù)據(jù)庫用戶密碼的方法,感興趣的朋友跟隨小編一起看看吧2024-03-03
springboot v2.0.3版本多數(shù)據(jù)源配置方法
這篇文章主要介紹了springboot v2.0.3版本多數(shù)據(jù)源配置方法,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下2018-11-11
基于SpringBoot+SpringAI+Ollama開發(fā)智能問答系統(tǒng)
在人工智能技術飛速發(fā)展的今天,大語言模型(LLM)已成為開發(fā)者工具箱中不可或缺的一部分,本文將介紹如何利用SpringBoot、SpringAI框架結合Ollama本地大模型服務,搭建一個完全運行在本地Windows環(huán)境下的智能問答系統(tǒng),有需要的可以了解下2025-06-06
MyBatis-Plus MetaObjectHandler的原理及使用
MyBatis-Plus的MetaObjectHandler接口允許開發(fā)者自動填充實體類字段,如創(chuàng)建時間、更新時間等公共字段,減少代碼重復,提高數(shù)據(jù)一致性和完整性,感興趣的可以了解一下2024-10-10

