參考官方文檔https://opendocs.alipay.com/mini/introduce/pay
支付寶小程序的支付和微信小程序的支付一樣第一步都是要獲取到用戶的唯一標識,在微信中我們獲取到的是wxopenid,而支付寶中獲取到的是userid。
1 使用的alipay-sdk包 2 <dependency> 3 <groupId>com.alipay.sdk</groupId> 4 <artifactId>alipay-sdk-java</artifactId> 5 <version>4.5.0.ALL</version> 6 </dependency>
1.授權 ==》前端使用 my.getAuthCode方法。
參考官方文檔https://opendocs.alipay.com/mini/introduce/authcode
2.根據第一步的授權拿到auth_code來獲取唯一標識userid
1 /** 2 * 授權碼 3 * @param auth_code 4 * @return 5 * @throws AlipayApiException 6 */ 7 @RequestMapping("getInfo") 8 public AjaxJson getInfo(String auth_code) throws AlipayApiException { 9 //使用支付寶小程序的固定方法獲取auth_code 10 if(auth_code==null||auth_code.length()==0) { 11 return AjaxJson.getError("請求參數auth_code不能為空"); 12 }else { 13 //String serverUrl, String appId, String privateKey, String format,String charset, String alipayPublicKey, String signType 14 //實例化客戶端 參數:正式環境URL,Appid,商戶私鑰 PKCS8格式,字符編碼格式,字符格式,支付寶公鑰,簽名方式 15 AlipayClient alipayClient = new DefaultAlipayClient("https://openapi.alipay.com/gateway.do",AliPayConfig.APP_ID,AliPayConfig.MERCHANT_PRIVATE_KEY,"json","GBK",AliPayConfig.ALIPAY_PUBLIC_KEY,"RSA2"); 16 AlipaySystemOauthTokenRequest request = new AlipaySystemOauthTokenRequest(); 17 // 值為authorization_code時,代表用code換取 18 request.setGrantType("authorization_code"); 19 //授權碼,用戶對應用授權后得到的 20 request.setCode(auth_code); 21 //這里使用execute方法 22 AlipaySystemOauthTokenResponse response = alipayClient.execute(request); 23 //刷新令牌,上次換取訪問令牌時得到。見出參的refresh_token字段 24 request.setRefreshToken(response.getAccessToken()); 25 //返回成功時 就將唯一標識返回 26 if(response.isSuccess()){ 27 System.out.println("調用成功"); 28 //我這里只返回了一個字段給前端用 29 Map<String,Object> map=new HashMap<>(); 30 map.put("userid", response.getUserId()); 31 return AjaxJson.getSuccessData(map); 32 } else { 33 return AjaxJson.getError("調用失敗"); 34 } 35 } 36 }
3.獲取用戶信息 使用API中的方法 my.getOpenUserInfo 。
注意:獲取會員基礎信息需要在開放平台小程序 管理頁面 申請添加 獲取會員基礎信息 功能包。
這里肯定會有盆友不解授權和獲取用戶信息可以寫在一個方法里而我寫了兩個方法,對的。我一開始是放在一起寫的,但是測試的時候一直報出Isv權限不足,能解決的辦法都試過了,繼續報錯。所以我是分開寫了方法。
4.支付 官方文檔https://opendocs.alipay.com/mini/introduce/pay
注意這里是官方文檔中的代碼
以下是我本人的代碼
/** * 用戶唯一標識id * @param userid * @return */ @RequestMapping("/pay1") public static AlipayTradeCreateResponse pay(String userid){ //獲得初始化的AlipayClient AlipayClient alipayClient = new DefaultAlipayClient(AliPayConfig.GATEWAY_URL, AliPayConfig.APP_ID, AliPayConfig.MERCHANT_PRIVATE_KEY, "json", AliPayConfig.CHARSET, AliPayConfig.ALIPAY_PUBLIC_KEY, AliPayConfig.SIGN_TYPE); //設置請求參數 AlipayTradeCreateRequest request = new AlipayTradeCreateRequest(); JSONObject json=new JSONObject(); //雪花算法訂單號 IdWorker idworker=new IdWorker(); Long oid=idworker.nextId(); String out_trade_no =String.valueOf(oid); //訂單號 json.put("out_trade_no",out_trade_no); //金額 這里的金額是以元為單位的可以不轉換但必須是字符串 json.put("total_amount","0.01"); //描述 json.put("subject","測試"); //用戶唯一標識id 這里必須使用buyer_id 參考文檔 json.put("buyer_id",userid); //對象轉化為json字符串 String jsonStr=json.toString(); //商戶通過該接口進行交易的創建下單 request.setBizContent(jsonStr); //回調地址 是能夠訪問到的域名加上方法名 request.setNotifyUrl("http://vvvvvvv.cn/aliPay/notifyUrl"); try { //使用的是execute AlipayTradeCreateResponse response = alipayClient.execute(request); return response; } catch (AlipayApiException e) { e.printStackTrace(); } return null; }
我在這里有一些代碼沒有使用官方文檔的方式寫參數,是因為我一開始寫的時候去測試時一直返回參數無效,而我找了好久也不知道是什么原因,這就很尷尬了,所以我換了一種方式。大家寫到這個地方的話可以參考。
前端調用my.tradePay方法
注意這里的trandeNo參數不用改,這是固定的,訂單號需要你自己去支付那里獲取。切記:獲取到的值是trade_no,並不是outTradeNo。
這是本人調試時的圖,接下來離成功就不遠了。
5.回調方法
1 /** 2 * 支付寶服務器異步通知url 3 * @throws Exception 4 */ 5 @RequestMapping(value="/notifyUrl") 6 public void notifyUrl(HttpServletRequest request,HttpServletResponse response) throws Exception{ 7 //獲取支付寶發送過來的信息 8 Map<String,String> params = new HashMap<String,String>(); 9 Map<String,String[]> requestParams = request.getParameterMap(); 10 //循環獲取到所有的值 11 for(String str:requestParams.keySet()) { 12 String name =str; 13 String[] values = (String[]) requestParams.get(name); 14 String valueStr = ""; 15 for (int i = 0; i < values.length; i++) { 16 valueStr = (i == values.length - 1) ? valueStr + values[i] 17 : valueStr + values[i] + ","; 18 } 19 //亂碼解決,這段代碼在出現亂碼時使用 20 //valueStr = new String(valueStr.getBytes("ISO-8859-1"), "utf-8"); 21 params.put(name, valueStr); 22 } 23 //調用SDK驗證簽名 24 boolean signVerified = AlipaySignature.rsaCheckV1(params, AliPayConfig.ALIPAY_PUBLIC_KEY, AliPayConfig.CHARSET, AliPayConfig.SIGN_TYPE); 25 //boolean類型signVerified為true時 則驗證成功 26 if(signVerified) { 27 //獲取到支付的狀態 TRADE_SUCCESS則支付成功 28 String trade_status =request.getParameter("trade_status"); 29 if (trade_status.equals("TRADE_SUCCESS")){ 30 System.out.println("支付成功"); 31 }else { 32 System.out.println("支付失敗"); 33 } 34 } 35 //簽名驗證失敗 36 else { 37 System.out.println(AlipaySignature.getSignCheckContentV1(params)); 38 } 39 }