在一些商城網上中,必不可少的是支付,支付寶和微信比較常見,最近小編也是在研究這一塊,看看支付寶怎麼進行支付的,支付寶給我們提供了demo和沙箱測試。減少我們的申請的麻煩,公鑰和祕鑰也比之前方便了,還是挺簡單的,沙箱和正式的區別就是申請一下許可權和把閘道器修改了就可以了!
不過支付寶的案例還是jsp
,我們就可以把java
程式碼抽離出來就可以了!!
話不多說,我們直接開始!!
我們在之前,要先了解到加密方式:
公鑰、私鑰、加密、簽名和驗籤
公鑰和私鑰是一個相對概念
它們的公私性是相對於生成者來說的。
一對金鑰生成後,儲存在生成者手裡的就是私鑰,
生成者釋出出去大家用的就是公鑰
加密是指:
我們使用一對公私鑰中的一個金鑰來對資料進行加密,而使用另一個金鑰來進行解
密的技術。
公鑰和私鑰都可以用來加密,也都可以用來解密。
但這個加解密必須是一對金鑰之間的互相加解密,否則不能成功。
加密的目的是:
為了確保資料傳輸過程中的不可讀性,就是不想讓別人看到。
給我們將要傳送的資料,做上一個唯一簽名(類似於指紋)
用來互相驗證接收方和傳送方的身份;
在驗證身份的基礎上再驗證一下傳遞的資料是否被篡改過。因此使用數位簽章可以
用來達到資料的明文傳輸。
支付寶為了驗證請求的資料是否商戶本人發的,
商戶為了驗證響應的資料是否支付寶發的
連結地址:java版demo
選擇為eclipse專案
直接一路下一步即可!
選中專案:
新增依賴
由於支付寶重新建了一個web
目錄,我們要自己給指定上,所有的頁面都在新的目錄下:WebContent
裡面,預設會指定到web
目錄!不然會報404!
解決方案:
把WebContent
指定為讀取頁面的目錄
我們發現,WebContent
可以被讀取了!!
直接執行,我們發現編譯報錯:
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
即可
再次執行:
前端頁面:
下面是需要我們修改的欄位,如果是springboot
把這些設定在組態檔中即可!
APPID:
私鑰和公鑰:
上圖點選啟用即可,不需要向以前自己生成,這樣就可以直接使用!
上面為:RSA_PRIVATE_KEY
下面為:ALIPAY_PUBLIC_KEY
設定請求閘道器地址:URL
:https://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程式碼中,這樣就可以使用了!
看到這裡了,如果對你有幫助,還不給小編來個一鍵三連!謝謝大家了!!
可以看下一小編的微信公眾號,和網站文章首發看,歡迎關注!!!