Java如何在沙箱環(huán)境中測試支付寶支付接口
java沙箱環(huán)境測試支付寶支付接口?
準(zhǔn)備工作,登陸支付寶開放平臺(tái),進(jìn)入沙箱環(huán)境
開放平臺(tái)鏈接:https://developers.alipay.com/platform/developerIndex.htm
沙箱環(huán)境中給測試提供了一些必要和非必要的參數(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ù)器異步通知頁面路徑 需http://格式的完整路徑,不能加?id=123這類自定義參數(shù),必須外網(wǎng)可以正常訪問.如果只是測試使用,那么設(shè)置成自己項(xiàng)目啟動(dòng)后可以訪問到的一個(gè)路徑,作為支付寶發(fā)送通知的路徑(有什么用暫時(shí)沒發(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è)置成自己項(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\":\""+ "測試支付" +"\"," + "\"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)到其他頁面或重定向到其他方法 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é)果展示
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Netty結(jié)合Protobuf進(jìn)行編解碼的方法
這篇文章主要介紹了Netty結(jié)合Protobuf進(jìn)行編解碼,通過文檔表述和代碼實(shí)例充分說明了如何進(jìn)行使用和操作,需要的朋友可以參考下2021-06-06詳解SpringMVC的攔截器鏈實(shí)現(xiàn)及攔截器鏈配置
攔截器(Interceptor)是一種動(dòng)態(tài)攔截方法調(diào)用的機(jī)制,在SpringMVC中動(dòng)態(tài)攔截控制器方法的執(zhí)行。本文將詳細(xì)講講SpringMVC中攔截器參數(shù)及攔截器鏈配置,感興趣的可以嘗試一下2022-08-08如何將默認(rèn)的maven倉庫改為阿里的maven倉庫
這篇文章主要介紹了如何將默認(rèn)的maven倉庫改為阿里的maven倉庫,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12實(shí)現(xiàn)Servlet程序的三種方法(小結(jié))
這篇文章主要介紹了實(shí)現(xiàn)Servlet程序的三種方法(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01Windows下Java+MyBatis框架+MySQL的開發(fā)環(huán)境搭建教程
這篇文章主要介紹了Windows下Java+MyBatis框架+MySQL的開發(fā)環(huán)境搭建教程,Mybatis對(duì)普通SQL語句的支持非常好,需要的朋友可以參考下2016-04-04