springboot對(duì)接支付寶支付接口(詳細(xì)開(kāi)發(fā)步驟總結(jié))
最近需要對(duì)接支付寶的支付接口,官方文檔寫(xiě)得內(nèi)容有點(diǎn)分散,整理了一下發(fā)布出來(lái),用作記錄,同時(shí)也希望對(duì)不了解情況的人有所幫助,這里以電腦端的網(wǎng)頁(yè)支付為例。
開(kāi)發(fā)主要分為三個(gè)步驟:一、生成私鑰公鑰。二、建立應(yīng)用。三、沙箱環(huán)境。四、接口開(kāi)發(fā)
一、生成私鑰公鑰
生成密鑰的官網(wǎng)文檔:官網(wǎng)文檔官方文檔講得已經(jīng)很詳細(xì),按照步驟來(lái)即可,記得保存好公鑰與私鑰,下面需要用到
二、建立應(yīng)用
1.首先進(jìn)入螞蟻金服開(kāi)放平臺(tái)的首頁(yè),通過(guò)支付寶賬戶登錄,登錄的時(shí)候要選擇一個(gè)身份,這個(gè)選自研開(kāi)發(fā)者吧,反正后面可以拓展
2.在螞蟻金服的首頁(yè)的頭像旁邊進(jìn)入管理中心,然后點(diǎn)擊“開(kāi)發(fā)中心”:
然后選擇網(wǎng)頁(yè)和移動(dòng)應(yīng)用快速接入支付/行業(yè),注意旁邊的“研發(fā)服務(wù)”,接下來(lái)我們會(huì)用到:
進(jìn)入之后選擇“支付接入”創(chuàng)建一個(gè)用于接入支付的應(yīng)用:
然后輸入相關(guān)的信息后點(diǎn)擊確認(rèn)創(chuàng)建:
創(chuàng)建成功之后可以看到如下頁(yè)面:
可以在功能列表選擇自己需要的功能。
開(kāi)發(fā)設(shè)置中可以填入自己需要的信息,其中加密方式建議選擇RSA(SHA256)密鑰,公鑰填寫(xiě)之前生成的公鑰。注:輸入公鑰時(shí)驗(yàn)證會(huì)失敗,但是對(duì)我們的開(kāi)發(fā)沒(méi)有影響,暫時(shí)可以不管
填寫(xiě)完之后,提交審核,審核按鈕在頁(yè)面上方= =,審核過(guò)程大概一個(gè)小時(shí)左右吧。實(shí)際生產(chǎn)環(huán)境的應(yīng)用需要等待這個(gè)審核,但是我們開(kāi)發(fā)可以運(yùn)用沙箱環(huán)境來(lái)進(jìn)行。
三、沙箱環(huán)境
什么是沙箱環(huán)境?沙箱環(huán)境實(shí)際上跟真實(shí)的生產(chǎn)環(huán)境差不多,開(kāi)發(fā)的時(shí)候我們用沙箱進(jìn)行,測(cè)試bug,到了生產(chǎn)環(huán)境中,我們只要替換APPID和支付寶網(wǎng)關(guān)就可以了,非常方便。
在網(wǎng)頁(yè)上端,點(diǎn)擊開(kāi)發(fā)平臺(tái),進(jìn)入沙箱:
在這里需要注意兩個(gè)地方:
沙箱環(huán)境下的支付寶網(wǎng)關(guān) 配置好自己的公鑰沙箱賬號(hào)
這個(gè)賬號(hào)用來(lái)模擬真實(shí)的支付寶賬戶,畢竟我們開(kāi)發(fā)進(jìn)行支付時(shí)不會(huì)使用自己的真實(shí)支付寶進(jìn)行支付。
后面還有什么沙箱賬號(hào)以及沙箱工具什么的,就自己看了。準(zhǔn)備得差不多了,接下來(lái)說(shuō)說(shuō)怎么開(kāi)發(fā)接口
四、接口開(kāi)發(fā)
我用的開(kāi)發(fā)語(yǔ)言是JAVA,工具為IDEA,一個(gè)簡(jiǎn)單的springboot工程1.構(gòu)建一個(gè)普通的springboot工程,引入支付寶SDK的maven依賴:
<dependency> <groupId>com.alipay.sdk</groupId> <artifactId>alipay-sdk-java</artifactId> <version>3.0.0</version> </dependency>
新建一個(gè)AlipayConfig類,用于配置支付的相關(guān)配置:
public class AlipayConfig { // 應(yīng)用ID,您的APPID,收款賬號(hào)既是您的APPID對(duì)應(yīng)支付寶賬號(hào),開(kāi)發(fā)時(shí)使用沙箱提供的APPID,生產(chǎn)環(huán)境改成自己的APPID public static String APP_ID = '你的沙箱APPID'; // 商戶私鑰,您的PKCS8格式RSA2私鑰 public static String APP_PRIVATE_KEY = '你自己的私鑰'; // 支付寶公鑰,查看地址:https://openhome.alipay.com/platform/keyManage.htm 對(duì)應(yīng)APPID下的支付寶公鑰。 public static String ALIPAY_PUBLIC_KEY = '你自己的支付寶公鑰,注意是支付寶公鑰,不是應(yīng)用公鑰'; // 服務(wù)器異步通知頁(yè)面路徑 需http://格式的完整路徑,不能加?id=123這類自定義參數(shù),必須外網(wǎng)可以正常訪問(wèn) public static String notify_url = 'http://localhost:8080/alipay.trade.page.pay-JAVA-UTF-8/notify_url.jsp'; // 頁(yè)面跳轉(zhuǎn)同步通知頁(yè)面路徑 需http://格式的完整路徑,不能加?id=123這類自定義參數(shù),必須外網(wǎng)可以正常訪問(wèn)(其實(shí)就是支付成功后返回的頁(yè)面) 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'; // 支付寶網(wǎng)關(guān),這是沙箱的網(wǎng)關(guān) public static String gatewayUrl = 'https://openapi.alipaydev.com/gateway.do'; // 支付寶網(wǎng)關(guān) public static String log_path = 'C:';//↑↑↑↑↑↑↑↑↑↑請(qǐng)?jiān)谶@里配置您的基本信息↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑ /** * 寫(xiě)日志,方便測(cè)試(看網(wǎng)站需求,也可以改成把記錄存入數(shù)據(jù)庫(kù)) * @param sWord 要寫(xiě)入日志里的文本內(nèi)容 */ 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.新建一個(gè)controller包,用于存放Action,新建一個(gè)PayController類,編寫(xiě)一個(gè)用于支付的接口/pay
@RestControllerpublic 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); //設(shè)置請(qǐng)求參數(shù) AlipayTradePagePayRequest alipayRequest = new AlipayTradePagePayRequest(); alipayRequest.setReturnUrl(AlipayConfig.return_url); alipayRequest.setNotifyUrl(AlipayConfig.notify_url); //商戶訂單號(hào),商戶網(wǎng)站訂單系統(tǒng)中唯一訂單號(hào),必填 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增加其他可選請(qǐng)求參數(shù),以增加自定義超時(shí)時(shí)間參數(shù)timeout_express來(lái)舉例說(shuō)明 //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'}'); //請(qǐng)求參數(shù)可查閱【電腦網(wǎng)站支付的API文檔-alipay.trade.page.pay-請(qǐng)求參數(shù)】章節(jié) //請(qǐng)求 String form=''; try { form = alipayClient.pageExecute(alipayRequest).getBody(); //調(diào)用SDK生成表單 } catch (AlipayApiException e) { e.printStackTrace(); } response.setContentType('text/html;charset=' + AlipayConfig.CHARSET); response.getWriter().write(form);//直接將完整的表單html輸出到頁(yè)面 response.getWriter().flush(); response.getWriter().close(); }
新建一個(gè)JSP頁(yè)面,用于模擬提交訂單首先要添加JSP的相關(guān)依賴:
<!-- 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
新建一個(gè)頁(yè)面:
頁(yè)面所在的目錄
<%@ page language='java' contentType='text/html; charset=UTF-8' pageEncoding='UTF-8'%><form action='/pay' method='post'> 訂單號(hào):<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>
required保證提交的時(shí)候這兩項(xiàng)內(nèi)容非空5. controller類添加跳轉(zhuǎn)到j(luò)sp頁(yè)面的映射:
@RequestMapping('/') public String toTest(){ return 'index'; }
6.測(cè)試運(yùn)行,啟動(dòng)項(xiàng)目,在瀏覽器輸入:http://localhost:8080/
輸入訂單號(hào),訂單名稱,金額,就可以跳轉(zhuǎn)到支付寶的支付頁(yè)面了:
由于這個(gè)是沙箱環(huán)境,所以這個(gè)二維碼無(wú)法識(shí)別,我們選擇右邊的登錄支付寶賬戶付款
在這里我們輸入的是之前沙箱賬號(hào)和支付密碼,輸入之后就可以進(jìn)入到支付頁(yè)面,與實(shí)際中的操作是一樣的:
這里跳轉(zhuǎn)回去的頁(yè)面就是之前AlipayConfig類中的return_url 在這之前需要進(jìn)入notify_url 接口進(jìn)行驗(yàn)簽,這兩個(gè)接口就不演示了,先知道這回事,實(shí)際開(kāi)發(fā)的時(shí)候再進(jìn)行開(kāi)發(fā)。
到此這篇關(guān)于springboot對(duì)接支付寶支付接口(詳細(xì)開(kāi)發(fā)步驟總結(jié))的文章就介紹到這了,更多相關(guān)springboot 支付寶支付接口內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章: