支付寶+APP支付+Java後臺代碼(1秒接入!!)

支付寶+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();
	}

如果對你有幫助,請給小編一個贊哈!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章