一、前言
在一些商城網上中,必不可少的是支付,支付寶和微信比較常見,最近小編也是在研究這一塊,看看支付寶怎么進行支付的,支付寶給我們提供了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

配置請求網關地址: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";
}
自己測驗可以使用內網穿透技術來實作, 常見的技術有三種:
- natapp
- 續斷
- 花生殼
花生殼不支持輸入域名,續斷可以支持域名!
八、頁面支付測驗
進入首頁:

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

選擇繼續瀏覽器付款:

登錄賬號:

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

輸入賬號密碼:

確認付款:


付款成功后會在5秒跳轉到我們上面配置的同步地址中去!

提醒:
在異步請求中,我們必須回傳支付寶success,不然支付寶會不斷重發,詳情如下:
程式執行完后必須列印輸出“success”(不包含引號),如果商家反饋給支付寶的字符不是 success 這7個字符,支付寶服務器會不斷重發通知,直到超過 24 小時 22 分鐘,一般情況下,25 小時以內完成 8 次通知(通知的間隔頻率一般是:4m,10m,10m,1h,2h,6h,15h),
詳細鏈接
我們一般在修改訂單支付狀態后回傳即可!
九、總結
這樣就完成了支付寶的簡單除錯和注意事項,我們可以把配置和jsp的支付相關搬到java代碼中,這樣就可以使用了!
看到這里了,如果對你有幫助,還不給小編來個一鍵三連!謝謝大家了!!
可以看下一小編的微信公眾號,和網站文章首發看,歡迎關注!!!

點擊訪問!小編自己的網站,里面也是有很多好的文章哦!
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/514221.html
標籤:Java
上一篇:面試官問:Stream 中的 map、peek、foreach 方法的區別?傻傻分不清楚。。
下一篇:Java注解(1):碼農的小秘
