支付寶+APP支付+Java後臺代碼(1秒接入!!)非證書版本
廢話不多說,直接上代碼
pom.xml
導入支付寶官方jar包
<!-- 支付寶支付 -->
<dependency>
<groupId>com.alipay.sdk</groupId>
<artifactId>alipay-sdk-java</artifactId>
<version>3.6.0.ALL</version>
</dependency>
封裝Util工具類,封裝支付寶的各種密鑰等屬性
// 商戶appid 控制檯查看對應的接口的ID
// 私鑰 pkcs8格式的 有支付寶提供工具支付寶開放平臺開發助手生成
// 服務器異步通知頁面路徑 需http://或者https://格式的完整路徑,不能加?id=123這類自定義參數,必須外網可以正常訪問,後端處理 (後臺接收判斷是否支付成功)
// 支付寶公鑰(是支付寶的公鑰,不是應用公鑰)
public class AlipayConfig {
// 商戶appid
public static String APPID = "";
// 私鑰 pkcs8格式的 有支付寶提供工具==支付寶開放平臺開發助手==生成
public static String RSA_PRIVATE_KEY = "";
// 服務器異步通知頁面路徑 需http://或者https://格式的完整路徑,不能加?id=123這類自定義參數,必須外網可以正常訪問,後端處理
public static String notify_url = "https://www.***.com/pay_s";
// 頁面跳轉同步通知頁面路徑 需http://或者https://格式的完整路徑,不能加?id=123這類自定義參數,必須外網可以正常訪問 商戶可以自定義同步跳轉地址
// public static String return_url = "";
// 請求網關地址
public static String URL = "https://openapi.alipay.com/gateway.do";
// 編碼
public static String CHARSET = "UTF-8";
// 返回格式
public static String FORMAT = "json";
// 支付寶公鑰
public static String ALIPAY_PUBLIC_KEY = "";
// 日誌記錄目錄
public static String log_path = "/log";
// RSA2
public static String SIGNTYPE = "RSA2";
}
controller層 調用支付,(HTML整合的APP或者ApiCloud的APP)拉取支付調用
@ResponseBody
@RequestMapping(value="",method=RequestMethod.POST)
//傳入商品信息
public Map<String,String> pay(@RequestBody User user) {
Map<String,String> success = new HashMap<String,String>();
AlipayClient alipayClient = new DefaultAlipayClient("https://openapi.alipay.com/gateway.do", AlipayConfig.APPID,AlipayConfig.RSA_PRIVATE_KEY, "json", AlipayConfig.CHARSET, AlipayConfig.ALIPAY_PUBLIC_KEY, AlipayConfig.SIGNTYPE);
//實例化具體API對應的request類,類名稱和接口名稱對應,當前調用接口名稱:alipay.trade.app.pay
AlipayTradeAppPayRequest request = new AlipayTradeAppPayRequest();
//SDK已經封裝掉了公共參數,這裏只需要傳入業務參數。以下方法爲sdk的model入參方式(model和biz_content同時存在的情況下取biz_content)。
AlipayTradeAppPayModel model = new AlipayTradeAppPayModel();
model.setBody("");//商品描述
model.setSubject("");//關鍵字
model.setOutTradeNo(ordernum); //唯一訂單不能重複
model.setTimeoutExpress("30m");//最晚付款時間
model.setTotalAmount("1.5");//商品價格
model.setProductCode("QUICK_MSECURITY_PAY");//產品銷售碼
//建議保存唯一訂單號 方便於回調查看是否支付成功
user.set***(ordernum);
userDao.****(user);
request.setBizModel(model);
request.setNotifyUrl("https://www.**.com/pay_s");//異步請求地址 回調查看是否支付成功
String result;
//
try {
//這裏和普通的接口調用不同,使用的是sdkExecute
AlipayTradeAppPayResponse response = alipayClient.sdkExecute(request);
result = response.getBody();
// result = new String(result.getBytes("ISO-8859-1"), "utf-8");
//就是orderString 可以直接給客戶端請求,無需再做處理。
success.put("success", result);
return success;
} catch (AlipayApiException e) {
System.out.println("錯誤");
e.printStackTrace();
}
success.put("success", "支付失敗");
return success;
}
controller層 回調支付接口查看是否成功
@RequestMapping(value="/pay_s")
public String asy(HttpServletRequest request) throws UnsupportedEncodingException {
//獲取支付寶POST過來反饋信息
Map<String,String> params = new HashMap<String,String>();
Map requestParams = request.getParameterMap();
Map<Object, Object> resultMap = new HashMap<>();
for (Iterator iter = requestParams.keySet().iterator(); iter.hasNext();) {
String name = (String) iter.next();
String[] values = (String[]) requestParams.get(name);
String valueStr = "";
for (int i = 0; i < values.length; i++) {
valueStr = (i == values.length - 1) ? valueStr + values[i]
: valueStr + values[i] + ",";
}
//亂碼解決,這段代碼在出現亂碼時使用。
//valueStr = new String(valueStr.getBytes("ISO-8859-1"), "utf-8");
params.put(name, valueStr);
}
//切記alipaypublickey是支付寶的公鑰,請去open.alipay.com對應應用下查看。
//boolean AlipaySignature.rsaCheckV1(Map<String, String> params, String publicKey, String charset, String sign_type)
boolean flag = false;
try {
flag = AlipaySignature.rsaCheckV1(params, AlipayConfig.ALIPAY_PUBLIC_KEY, AlipayConfig.CHARSET,"RSA2");
if (flag) {
try {
//商戶訂單號
String out_trade_no = new String(request.getParameter("out_trade_no").getBytes("ISO-8859-1"), "UTF-8");
// //支付寶交易號
// String trade_no = new String(request.getParameter("trade_no").getBytes("ISO-8859-1"), "UTF-8");
//
// //付款金額
// String total_amount = new String(request.getParameter("total_amount").getBytes("ISO-8859-1"), "UTF-8");
// System.out.println(total_amount);
String trade_status = new String(request.getParameter("trade_status").getBytes("ISO-8859-1"), "UTF-8");
//判斷是否支付成功
if ("TRADE_SUCCESS".equals(trade_status)) {
//接下來對業務進行數據處理
**********
**********
**********
}
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return "SUCCESS";
} else {
String out_trade_no = new String(request.getParameter("out_trade_no").getBytes("ISO-8859-1"), "UTF-8");
User user = new User();
user.setpay_orderid(out_trade_no);
user.setPay_status("fall");
userDao.User_PayStatus(user);
return "FAIL";
}
} catch (AlipayApiException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return "SUCCESS";
}
最後提供一個生成不重複的隨機數的方法,可以用作生成唯一訂單號
public String random(){
UUID uuid = UUID.randomUUID();
//如果數據量非常大,建議加上時間戳!
return uuid.toString();
}
如果對你有幫助,請給小編一個贊哈!