springboot對接支付寶支付接口(詳細開發(fā)步驟總結)
最近需要對接支付寶的支付接口,官方文檔寫得內容有點分散,整理了一下發(fā)布出來,用作記錄,同時也希望對不了解情況的人有所幫助,這里以電腦端的網頁支付為例。
開發(fā)主要分為三個步驟:一、生成私鑰公鑰。二、建立應用。三、沙箱環(huán)境。四、接口開發(fā)
一、生成私鑰公鑰
生成密鑰的官網文檔:官網文檔
官方文檔講得已經很詳細,按照步驟來即可,記得保存好公鑰與私鑰,下面需要用到
二、建立應用
1.首先進入螞蟻金服開放平臺的首頁,通過支付寶賬戶登錄,登錄的時候要選擇一個身份,這個選自研開發(fā)者吧,反正后面可以拓展
2.在螞蟻金服的首頁的頭像旁邊進入管理中心,然后點擊“開發(fā)中心”:

然后選擇網頁和移動應用快速接入支付/行業(yè),注意旁邊的“研發(fā)服務”,接下來我們會用到:

進入之后選擇“支付接入”創(chuàng)建一個用于接入支付的應用:

然后輸入相關的信息后點擊確認創(chuàng)建:

創(chuàng)建成功之后可以看到如下頁面:

可以在功能列表選擇自己需要的功能。
開發(fā)設置中可以填入自己需要的信息,其中加密方式建議選擇RSA(SHA256)密鑰,公鑰填寫之前生成的公鑰。
注:輸入公鑰時驗證會失敗,但是對我們的開發(fā)沒有影響,暫時可以不管

填寫完之后,提交審核,審核按鈕在頁面上方= =,審核過程大概一個小時左右吧。實際生產環(huán)境的應用需要等待這個審核,但是我們開發(fā)可以運用沙箱環(huán)境來進行。
三、沙箱環(huán)境
什么是沙箱環(huán)境?
沙箱環(huán)境實際上跟真實的生產環(huán)境差不多,開發(fā)的時候我們用沙箱進行,測試bug,到了生產環(huán)境中,我們只要替換APPID和支付寶網關就可以了,非常方便。
在網頁上端,點擊開發(fā)平臺,進入沙箱:

在這里需要注意兩個地方:
- 沙箱環(huán)境下的支付寶網關
- 配置好自己的公鑰
沙箱賬號

這個賬號用來模擬真實的支付寶賬戶,畢竟我們開發(fā)進行支付時不會使用自己的真實支付寶進行支付。
后面還有什么沙箱賬號以及沙箱工具什么的,就自己看了。
準備得差不多了,接下來說說怎么開發(fā)接口
四、接口開發(fā)
我用的開發(fā)語言是JAVA,工具為IDEA,一個簡單的springboot工程
1.構建一個普通的springboot工程,引入支付寶SDK的maven依賴:
<dependency>
<groupId>com.alipay.sdk</groupId>
<artifactId>alipay-sdk-java</artifactId>
<version>3.0.0</version>
</dependency>
新建一個AlipayConfig類,用于配置支付的相關配置:
public class AlipayConfig {
// 應用ID,您的APPID,收款賬號既是您的APPID對應支付寶賬號,開發(fā)時使用沙箱提供的APPID,生產環(huán)境改成自己的APPID
public static String APP_ID = "你的沙箱APPID";
// 商戶私鑰,您的PKCS8格式RSA2私鑰
public static String APP_PRIVATE_KEY = "你自己的私鑰";
// 支付寶公鑰,查看地址:https://openhome.alipay.com/platform/keyManage.htm 對應APPID下的支付寶公鑰。
public static String ALIPAY_PUBLIC_KEY = "你自己的支付寶公鑰,注意是支付寶公鑰,不是應用公鑰";
// 服務器異步通知頁面路徑 需http://格式的完整路徑,不能加?id=123這類自定義參數(shù),必須外網可以正常訪問
public static String notify_url = "http://localhost:8080/alipay.trade.page.pay-JAVA-UTF-8/notify_url.jsp";
// 頁面跳轉同步通知頁面路徑 需http://格式的完整路徑,不能加?id=123這類自定義參數(shù),必須外網可以正常訪問(其實就是支付成功后返回的頁面)
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";
// 支付寶網關,這是沙箱的網關
public static String gatewayUrl = "https://openapi.alipaydev.com/gateway.do";
// 支付寶網關
public static String log_path = "C:\\";
//↑↑↑↑↑↑↑↑↑↑請在這里配置您的基本信息↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑
/**
* 寫日志,方便測試(看網站需求,也可以改成把記錄存入數(shù)據(jù)庫)
* @param sWord 要寫入日志里的文本內容
*/
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.新建一個controller包,用于存放Action,新建一個PayController類,編寫一個用于支付的接口/pay
@RestController
public 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ù)
AlipayTradePagePayRequest alipayRequest = new AlipayTradePagePayRequest();
alipayRequest.setReturnUrl(AlipayConfig.return_url);
alipayRequest.setNotifyUrl(AlipayConfig.notify_url);
//商戶訂單號,商戶網站訂單系統(tǒng)中唯一訂單號,必填
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增加其他可選請求參數(shù),以增加自定義超時時間參數(shù)timeout_express來舉例說明
//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\"}");
//請求參數(shù)可查閱【電腦網站支付的API文檔-alipay.trade.page.pay-請求參數(shù)】章節(jié)
//請求
String form="";
try {
form = alipayClient.pageExecute(alipayRequest).getBody(); //調用SDK生成表單
} catch (AlipayApiException e) {
e.printStackTrace();
}
response.setContentType("text/html;charset=" + AlipayConfig.CHARSET);
response.getWriter().write(form);//直接將完整的表單html輸出到頁面
response.getWriter().flush();
response.getWriter().close();
}
新建一個JSP頁面,用于模擬提交訂單
首先要添加JSP的相關依賴:
<!-- 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
新建一個頁面:
頁面所在的目錄

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<form action="/pay" method="post">
訂單號:<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保證提交的時候這兩項內容非空
5. controller類添加跳轉到jsp頁面的映射:
@RequestMapping("/")
public String toTest(){
return "index";
}
6.測試運行,啟動項目,在瀏覽器輸入:http://localhost:8080/

輸入訂單號,訂單名稱,金額,就可以跳轉到支付寶的支付頁面了:

由于這個是沙箱環(huán)境,所以這個二維碼無法識別,我們選擇右邊的登錄支付寶賬戶付款

在這里我們輸入的是之前沙箱賬號和支付密碼,輸入之后就可以進入到支付頁面,與實際中的操作是一樣的:


這里跳轉回去的頁面就是之前AlipayConfig類中的return_url 在這之前需要進入notify_url 接口進行驗簽,這兩個接口就不演示了,先知道這回事,實際開發(fā)的時候再進行開發(fā)。

到此這篇關于springboot對接支付寶支付接口(詳細開發(fā)步驟總結)的文章就介紹到這了,更多相關springboot 支付寶支付接口內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
解決SpringBoot中MultipartResolver和ServletFileUpload的沖突問題
這篇文章主要介紹了解決SpringBoot中MultipartResolver和ServletFileUpload的沖突問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-10-10
Springboot?手動分頁查詢分批批量插入數(shù)據(jù)的實現(xiàn)流程
這篇文章主要介紹了Springboot?手動分頁查詢分批批量插入數(shù)據(jù)的實現(xiàn)流程,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-07-07
Spring實戰(zhàn)之ServletContextResource訪問資源文件示例
這篇文章主要介紹了Spring實戰(zhàn)之ServletContextResource訪問資源文件,結合實例形式分析了spring使用ServletContextResource讀取與遍歷資源文件相關操作技巧,需要的朋友可以參考下2019-12-12
基于Jpa中ManyToMany和OneToMany的雙向控制
這篇文章主要介紹了Jpa中ManyToMany和OneToMany的雙向控制,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12
idea2020.1設置多個spring boot的service啟動的實現(xiàn)
這篇文章主要介紹了idea2020.1設置多個spring boot的service啟動,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-06-06

