Idea執行支付寶網站支付demo踩坑解決及其測試注意事項

2022-10-14 12:12:02

一、前言

在一些商城網上中,必不可少的是支付,支付寶和微信比較常見,最近小編也是在研究這一塊,看看支付寶怎麼進行支付的,支付寶給我們提供了demo和沙箱測試。減少我們的申請的麻煩,公鑰和祕鑰也比之前方便了,還是挺簡單的,沙箱和正式的區別就是申請一下許可權和把閘道器修改了就可以了!

不過支付寶的案例還是jsp,我們就可以把java程式碼抽離出來就可以了!!

話不多說,我們直接開始!!

二、知識儲備

我們在之前,要先了解到加密方式:
公鑰、私鑰、加密、簽名和驗籤

1、公鑰私鑰

公鑰和私鑰是一個相對概念
它們的公私性是相對於生成者來說的。
一對金鑰生成後,儲存在生成者手裡的就是私鑰,
生成者釋出出去大家用的就是公鑰

2、加密

 加密是指:
 我們使用一對公私鑰中的一個金鑰來對資料進行加密,而使用另一個金鑰來進行解
密的技術。
 公鑰和私鑰都可以用來加密,也都可以用來解密。
 但這個加解密必須是一對金鑰之間的互相加解密,否則不能成功。
 加密的目的是:
 為了確保資料傳輸過程中的不可讀性,就是不想讓別人看到。

3、簽名

 給我們將要傳送的資料,做上一個唯一簽名(類似於指紋)
 用來互相驗證接收方和傳送方的身份;
 在驗證身份的基礎上再驗證一下傳遞的資料是否被篡改過。因此使用數位簽章可以
用來達到資料的明文傳輸。

4、驗籤

 支付寶為了驗證請求的資料是否商戶本人發的,
 商戶為了驗證響應的資料是否支付寶發的

三、下載demo

連結地址:java版demo

四、Idea開啟

1、 idea中新建

2、選擇專案


選擇為eclipse專案


直接一路下一步即可!

五、設定

1、設定為web專案

選中專案:


新增依賴

2、大坑

由於支付寶重新建了一個web目錄,我們要自己給指定上,所有的頁面都在新的目錄下:WebContent裡面,預設會指定到web目錄!不然會報404!

解決方案:
WebContent指定為讀取頁面的目錄

我們發現,WebContent可以被讀取了!!

3、設定tomcat



六、測試執行

直接執行,我們發現編譯報錯:

D:\data\alipay.trade.wap.pay-java-utf-8\alipay.trade.wap.pay-java-utf-8\src\com\alipay\config\AlipayConfig.java
java: 需要class, interface或enum

在這裡插入圖片描述
報錯原因
是因為編碼格式不對,我們發現右下角是UTF-8沒問題,原因是沒有生效,需要先切換一下另一個編碼,然後再換回來,這樣UTF-8就會生效!!

點選UTF-8,選型中選擇GBK。點選生效


重複操作換為UTF-8即可

再次執行:


前端頁面:

七、對接沙箱

沙箱環境控制檯

1、開啟設定類

下面是需要我們修改的欄位,如果是springboot把這些設定在組態檔中即可!

2、填充資訊

APPID:

私鑰和公鑰:

上圖點選啟用即可,不需要向以前自己生成,這樣就可以直接使用!

上面為:RSA_PRIVATE_KEY
下面為:ALIPAY_PUBLIC_KEY

設定請求閘道器地址:URLhttps://openapi.alipaydev.com/gateway.do
和正式的加了一個dev

設定同步通知頁面路徑和非同步通知頁面路徑:

例子:

public static String notify_url = "http://localhost:8080/notify_url.jsp";
public static String return_url = "http://localhost:8080/return_url.jsp";

同步路徑時支付成功的跳轉頁面,一般會跳到訂單詳情頁,
非同步一般是支付成功我們進行修改訂單的支付狀態的請求地址,
兩者必須外網可以正常存取,不能加?id=123這類自定義引數。

全部設定如下:

public class AlipayConfig {
	// 商戶appid
	public static String APPID = "2021000117627470";
	// 私鑰 pkcs8格式的
	public static String RSA_PRIVATE_KEY = "MIIEvAIBADANBgkqhkiG9w0BAQEFAASCBKYwggSiAgEAAoIBAQCwJO/zYxYYjLW3AKUEKJSzl/tisAMV7Nycc2+p9pZuuVE+yEDr/9rTYtWBGdsoQap4P8hbsvz2JXEUnJHdzBajCWyM85eVCV5fVO9RUb1kzhjrPdqyRzvJvPXic2UkXueKkQ2H/b5BryHQRfjAotY+jjhcre/Ikxx2GkOCNbEOzmcSkBZTG3QZgOl9O151DFkUj8H7u4wu9X2CHvXiV9g9H/8iIHlcf2KNf1pmnHYfOaYj/8v9/gxQg+r3+0F5oJhm4TKm8Ot+7I1rNAnBTLAe03qbPXLrZIASRJkEMG1cQb4mCmVDNAdqdXxBCAQnT+ggylvhiB9jXuqVp9zXVTMtAgMBAAECggEAJHuiD2EohHEwefTyOMhG9GO4N5qJKRNkJitqp2NhiRFtGHnVqIvXwQypeBHo6I+hRULAtu19o2Xh5AkB1VSeI6qiBxe0/7NvDoPDBa7OcYCWfLLVBzPl2EUBEKQiAMR/ZJ3ilZYiv+wMLt0vRobzpQVD+z4zefGuZW/PJ7sDLzOMwbtaQ3nCUYor4GAZuA+WKfkLKYj3HmApvyhb2o/8Yl+GmE9It91vCI7RTyhOr9CBw3Rz6d3xeVnfbHr2lQ4AGrzYvAlS77R+0YWla3x9MqnM/iFUjWzV3QdBOTmM/4ga0JVdeLKJtfW3fdn2WdRrydfMTffWLOTH/MUhfltCgQKBgQDlFfBotzFTpJCNv9lQkIGorpVSQkp1shlkob5SWVKufshS2/m5AkSAkvpc3TmUH1GDfIneMdelLeJwvx3gho/lyQayGD6og1Z6CQGwVVvZxO65aejEjyruo/zfrSn260nACd2CyKHBg3spsxfE0U8lt7zmmk7JSzrU4+UxaJiQEQKBgQDE1rbDKzWRqk1ihNepLfTTmUDpgjfuVEmX9xUbIBalm0PtdLL4y+AAFCI01VwiTvs6rpXjkc0Yp624t1RwJmPYvJ1LPlp4hkpTZIbI5e0gv9RkGmQ1YXEQ/+SON8d3qmTrRnSDKUlRBSBQ5yeT3lfcNI4nNDX6Ag6kxYq6JxgNXQKBgD01wnnIUQa/Vtx5IXC0W+CdXUqQaeLOxpgr23WXZk83kwEIw83aPEF6hCjh92uLfrU6RoA3Ix6AhxuHBU2jxrkoIIDfl4ZhKW8MDwZ1mEg0pXCnSsmSU29WI9AELc1LCvaj7Crwvr+9COCYeMZfAt3aHUAkhN6mGj8d8XRlNTZxAoGAHCIwNw769hnoO5ePF3ApGQFDhNyGz/qeFilLi/f3JK5fdBYE6oiBOKGoDfMc2w582/NOGxugu9BjhQ429FyYUscKmFGOLsHK58ZreVVboh2o5rHa9sI5ndtlOGqCiPkCuZn1VzXUc88OwmF3h6v01NVyJ+pPeK9IloZhgJ/L0UUCgYAB99cEMRSdWZ6QLbgIPdLkMmo3eIHQAvzWAI560uSgQwBZYXBHvJyPF3qL3Yn2QAghOuwcRYT4Y+jDhf3eXoy25flpROqzhmeWXQf/ksjmmEA/qdWi6pHTDLd4FPiHhCsp9gjo8lheJMvPcIiMt3+tOnkS4/vwoS+bOEZJqTlSnw==";
	// 伺服器非同步通知頁面路徑 需http://或者https://格式的完整路徑,不能加?id=123這類自定義引數,必須外網可以正常存取
	public static String notify_url = "http://localhost:8080/notify_url.jsp";
	// 頁面跳轉同步通知頁面路徑 需http://或者https://格式的完整路徑,不能加?id=123這類自定義引數,必須外網可以正常存取 商戶可以自定義同步跳轉地址
	public static String return_url = "http://localhost:8080/return_url.jsp";
	// 請求閘道器地址
	public static String URL = "https://openapi.alipaydev.com/gateway.do";
	// 編碼
	public static String CHARSET = "UTF-8";
	// 返回格式
	public static String FORMAT = "json";
	// 支付寶公鑰
	public static String ALIPAY_PUBLIC_KEY = "MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAw2+1X9+g/YkZCqpyiN9EGEu951ODowp627WCxu/thtI5J0b8XDGsfK0gabH0Jz7o1JRTC37ZHaEPMUCd8NjeWb6tsnWZzhmxr7dqHu9Umy2QKl41UFMxMnvuwKjmXx7+jxNIeNv/fpdV9r+K6Gm0qHmaL23OuS/RB37cZ/kZ7SCzmIweca7f93wpO5knpT0DFRF48l2Js/rJm4/03vxjadCywKsSx2LnhdSpsypzHShTQJBolryzav0fp9gkBEW35n4v/261ZIepWpEtFcWSO+YTqeOjR9ciOjmMXjc/HYZTyMro9RzSfFqHouONZj+E3V0MPg1/Qea8el78p5QVwwIDAQAB";
	// 紀錄檔記錄目錄
	public static String log_path = "/log";
	// RSA2
	public static String SIGNTYPE = "RSA2";
}


自己測試可以使用內網穿透技術來實現, 常見的技術有三種:

花生殼不支援輸入域名,續斷可以支援域名!

八、頁面支付測試

進入首頁:

點選第一個進入支付,點選確認!


選擇繼續瀏覽器付款:


登入賬號:


在沙箱中找到買家的賬號密碼:
沙箱地址


輸入賬號密碼:


確認付款:


付款成功後會在5秒跳轉到我們上面設定的同步地址中去!

提醒:
在非同步請求中,我們必須返回支付寶success,不然支付寶會不斷重發,詳情如下:

程式執行完後必須列印輸出「success」(不包含引號)。如果商家反饋給支付寶的字元不是 success 這7個字元,支付寶伺服器會不斷重發通知,直到超過 24 小時 22 分鐘。一般情況下,25 小時以內完成 8 次通知(通知的間隔頻率一般是:4m,10m,10m,1h,2h,6h,15h)。
詳細連結

我們一般在修改訂單支付狀態後返回即可!

九、總結

這樣就完成了支付寶的簡單偵錯和注意事項,我們可以把設定和jsp的支付相關搬到java程式碼中,這樣就可以使用了!


看到這裡了,如果對你有幫助,還不給小編來個一鍵三連!謝謝大家了!!

可以看下一小編的微信公眾號,和網站文章首發看,歡迎關注!!!

點選存取!小編自己的網站,裡面也是有很多好的文章哦!