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


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


沙箱工具中點(diǎn)擊設(shè)置


將RSA生成的應(yīng)用公鑰,復(fù)制到下面的文本框中,點(diǎn)擊保存設(shè)置

保存好

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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java對(duì)xls文件進(jìn)行讀寫操作示例代碼
Java開發(fā)項(xiàng)目中經(jīng)常會(huì)碰到處理Excel文件中數(shù)據(jù)的情況,下面這篇文章主要給大家介紹了利用Java對(duì)xls文件進(jìn)行讀寫操作的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。2017-08-08
SpringBoot+MyBatis實(shí)現(xiàn)MD5加密數(shù)據(jù)庫(kù)用戶密碼的方法
MD5技術(shù)主要用于對(duì)用戶密碼加密,增加賬戶的安全性,他具有不可逆的特性,不會(huì)被輕易解密,這篇文章給大家介紹SpringBoot+MyBatis實(shí)現(xiàn)MD5加密數(shù)據(jù)庫(kù)用戶密碼的方法,感興趣的朋友跟隨小編一起看看吧2024-03-03
springboot v2.0.3版本多數(shù)據(jù)源配置方法
這篇文章主要介紹了springboot v2.0.3版本多數(shù)據(jù)源配置方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2018-11-11
Springboot整合Gson報(bào)錯(cuò)問題解決過程
這篇文章主要介紹了Springboot整合Gson報(bào)錯(cuò)問題解決過程,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06
基于SpringBoot+SpringAI+Ollama開發(fā)智能問答系統(tǒng)
在人工智能技術(shù)飛速發(fā)展的今天,大語言模型(LLM)已成為開發(fā)者工具箱中不可或缺的一部分,本文將介紹如何利用SpringBoot、SpringAI框架結(jié)合Ollama本地大模型服務(wù),搭建一個(gè)完全運(yùn)行在本地Windows環(huán)境下的智能問答系統(tǒng),有需要的可以了解下2025-06-06
java抓取網(wǎng)頁(yè)或文件中的郵箱號(hào)碼
這篇文章主要為大家詳細(xì)介紹了java如何抓取網(wǎng)頁(yè)或文件中的郵箱號(hào)碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03
MyBatis-Plus MetaObjectHandler的原理及使用
MyBatis-Plus的MetaObjectHandler接口允許開發(fā)者自動(dòng)填充實(shí)體類字段,如創(chuàng)建時(shí)間、更新時(shí)間等公共字段,減少代碼重復(fù),提高數(shù)據(jù)一致性和完整性,感興趣的可以了解一下2024-10-10

