您好,登錄后才能下訂單哦!
小編給大家分享一下Java如何在沙箱環(huán)境中測試支付寶支付接口,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
java沙箱環(huán)境測試支付寶支付接口?
準(zhǔ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密鑰.生成的密鑰分為應(yīng)用公鑰,應(yīng)用私鑰.應(yīng)用私鑰自己保存,應(yīng)用公鑰應(yīng)該到支付寶的開放平臺上生成相應(yīng)的支付寶公鑰才可以正常使用.
沙箱工具中點擊設(shè)置
將RSA生成的應(yīng)用公鑰,復(fù)制到下面的文本框中,點擊保存設(shè)置
保存好
上述操作完成后,即可進行代碼的編寫.
進入開發(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 對應(yīng)APPID下的支付寶公鑰。 public static String alipay_public_key = "注意是上面再三提示的支付寶公鑰"; // 服務(wù)器異步通知頁面路徑 需http://格式的完整路徑,不能加?id=123這類自定義參數(shù),必須外網(wǎng)可以正常訪問.如果只是測試使用,那么設(shè)置成自己項目啟動后可以訪問到的一個路徑,作為支付寶發(fā)送通知的路徑(有什么用暫時沒發(fā)現(xiàn)) public static String notify_url = "http://localhost:8080/pay/alipay-callback-notify-url"; // 頁面跳轉(zhuǎn)同步通知頁面路徑 需http://格式的完整路徑,不能加?id=123這類自定義參數(shù),必須外網(wǎng)可以正常訪問.如果只是測試使用,那么設(shè)置成自己項目啟動后可以訪問到的一個路徑.是支付正常完成后,會訪問的路徑. 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類供前臺訪問,去調(diào)用支付接口.
@RequestMapping("/toPay")//設(shè)置請求的路徑 @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è)置到該對象中 AlipayClient alipayClient = new DefaultAlipayClient(AlipayConfig.gatewayUrl, AlipayConfig.app_id, AlipayConfig.merchant_private_key, "json", AlipayConfig.charset, AlipayConfig.alipay_public_key, AlipayConfig.sign_type); //設(shè)置請求參數(shù),并把配置類中的兩個路徑設(shè)置進去 AlipayTradePagePayRequest alipayRequest = new AlipayTradePagePayRequest(); alipayRequest.setReturnUrl(AlipayConfig.return_url); alipayRequest.setNotifyUrl(AlipayConfig.notify_url); //如果想正常調(diào)用接口則需要傳一些必要參數(shù),out_trade_no:訂單號,保證唯一性,支付寶根據(jù)該參數(shù)生成你的支付單號,total_amount:需要支付的金額,注意是String型,且金額計數(shù)的分割","不能存在(例如1,000就是錯誤的參數(shù)),subject:對物品進行描述,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\":\""+ "測試支付" +"\"," + "\"product_code\":\"FAST_INSTANT_TRADE_PAY\"}"); //請求 String result; //發(fā)送請求并返回 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ù)去做后續(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)到其他頁面或重定向到其他方法 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ā)送請求.跳轉(zhuǎn)到如下路徑代表成功.
結(jié)果展示
看完了這篇文章,相信你對“Java如何在沙箱環(huán)境中測試支付寶支付接口”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。