H5頁面調用支付寶支付功能
粘貼核心代碼
使用SpringMVC 將 返回的htm代碼 輸出到頁面
本文中測 AppId APP_PRIVATE_KEY ALIPAY_PUBLIC_KEY 替換成自己的 信息
/** * */ package cn.superjava.alipay; import java.io.IOException; import javax.servlet.ServletException; import javax.servlet.http.HttpServletRequest; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import com.alipay.api.AlipayApiException; import com.alipay.api.AlipayClient; import com.alipay.api.DefaultAlipayClient; import com.alipay.api.request.AlipayOpenPublicTemplateMessageIndustryModifyRequest; import com.alipay.api.request.AlipayTradeWapPayRequest; import com.alipay.api.response.AlipayOpenPublicTemplateMessageIndustryModifyResponse; /** * @description: H5 支付寶支付 * @author SuperJava * @createTime 2017年3月20日 * @version 1.0 */ @Controller public class AliPayController { /** * 支付寶開發文檔 * https://b.alipay.com/signing/productDetail.htm?productId=I1011000290000001001 * {---如果使用的老接口--} * {---https://doc.open.alipay.com/doc2/detail?treeId=60&articleId=103564&docType=1--} * * 支付寶 服務端SDK下載 (支持java .net php) * https://doc.open.alipay.com/doc2/detail?treeId=54&articleId=103419&docType=1 * * 支付寶H5開發 SDK集成 * https://doc.open.alipay.com/docs/doc.htm?treeId=203&articleId=105285&docType=1 * * 創建APPID 生成 公鑰 私鑰 * */ /** * 以下靜態常量 除了(URL) 修改為自己的商戶信息 */ // 支付寶網關(固定) public static final String URL = "https://openapi.alipay.com/gateway.do"; // APPID即創建應用后生成 public static final String APP_ID = "2016032401238"; // 開發者應用私鑰,由開發者自己生成 public static final String APP_PRIVATE_KEY = "MIIEvgIBADANBgkqhkiG9w0BeMWy5FZHMcGysEK5mqWavCqs9qOvKDs/2CxB2o9q8INsih6yldNwsWjC2Y9akfOa3CcJGJ5TLcELEb4rb3tbwayAXM9yx9uRbAbcr2TSNPO2deU6ttvNeMrGZpXItCnihoxTDlu/QUCYQu9eCRiw4OBDUQ87LEIR3bwKIdfWLMsgcDvlSiwdUinG1ZckoBbT1MJ64KfuchOrWLc98QUXpKYJ+udyvDUykEzMU1RG5JbsjwFbYpMH2aHP1tqeALejLWYjxZ0ceff0wBYJ9nvPOVkLkyA74SRfUmlESMaQkymrU6F/DlwSPH05HFRQKDJx1wYigFAgMBAAECggEBAKyo/UKFHzqOxlL0ESbZvfRLCQAzhiqeOuj4x1xl/5XoxMG8BHgAa36glwG3Czyp1aYmGOBqQNfvbTxbMU8dBRX+7Y9ZdON2W20xclDTHgL24YT2MVYZ7EzDedjCtVRDH7Dj4jkoM1vmN6Ly1WTJ+jhqk/Tu4JVPRCef/xIwgnnmUYX6Dx2UjSYNAiEPltiOVKCyShk1Bu0fuuphq+gKnw7Tm1VT2srcjpLcc89Y1ikJvw+6ybH7aA7T4lCaGUgBnkmdSgwqunKBNlSNHW3cCdgJL6no2kWN6OxGhGfj7taC+OcbGtfdrrAWBV92z1dMlvko3ZEl2SWTgLrK3nDLz2ECgYEA+tk1fvy3vPDoHqM15pVWR0GWwoHveTF0/hN+kb9o7X+xkQwbkhZ+2HKLKQyjQzB7b3FRsG33blGjUWXVMdeQa4enBAhHm9uzTmgMmLBcoWJ9AiuHuXQIaPR4+N15ZSK58qHBycT7kc53/2mo3BZj3C8NwU2WvKwYZQpWYVC0Nx0CgYEAs/OBwR/D3exgQb+Qds4iji3mMBL1Sy0nIaCYUocO8mrm06Ot9b/inCFnG6eihhieIuCQo2sYXba7HzmMyxQvTokXwGuaDRHUtIFNdxA/M+yj0Z6mTrKqvmLVC2V6ImVsl0nF4k+VQ+kVBOVuVR2sCZ3eVWu1DeQgh9NEuncvmAkCgYEA70cWImWKFm5t3BuvJJ46yIml9y/ecGpewKVzzC8bNcDibgtwmS9gG7NXTvbBHSw38hvT4kljBhZVhSVv8bVAC3JAPDZxqBgvt5DEwzkngsHhoJpJQvuNsh/Q7QLF81Tmrqzhn0eI+JJMIJR3AElTRAqWQldye9JlCqyLrRRAc3kCgYAUttsg1/879JG//8UpZ+EibLYqooQJ+1Cd1layaUmXLicUBatotoXnYxDzZgCXXw4VBbSgmxta7kXr+jvyxIgNikppo/k/t+W8QYYhRoV//KV+47xRIs/0ynurrCq6+uHdKGjW/EI6ZwI8ZgylT50WHk4RlyxoRPJZsEAhFscrwQKBgHpZLw5pYg8AeG/P5gqZraMoEb75ULiSuolT3DLX+pzJf2bne40SAHTaxhAVG0pBz9b45sOXJz9+eLi6UzyDHWZCL+cCMSC7TA3Q4AxHy+1LNzh6abLk1QjC3yLLZFyUAqEvTHpnizikD+5viC7LdGT96jVCI4H0ywvk2USd46Mw"; // 支付寶公鑰,由支付寶生成 public static final String ALIPAY_PUBLIC_KEY = "MIIBIjANBgkqhkiG9w0BAQEFAAOCAQuRWRzHBsrBCuZqlmrwqrPajryg7P9gsQdqPavCDbIoespXTcLFowtmPWpHzmtwnCRieUy3BCxG+K297W8GsgFzPcsfbkWwG3K9k0jTztnXlOrbbzXjKxmaVyLQp4oaMUw5bv0FAmELvXgkYsODgQ1EPOyxCEd28CiHX1izLIHA75UosHVIpxtWXJKAW09TCeuCn7nITq1i3PfEFF6SmCfrncrw1MpBMzFNURuSW7I8BW2KTB9mhz9bangC3oy1mI8WdHHn39MAWCfZ7zzlZC5MgO+EkX1JpREjGkJMpq1Ohfw5cEjx9ORxUUCgycdcGIoBQIDAQAB"; // 請求編碼 public static final String CHARSET = "UTF-8"; /** * @description: 調用支付寶接口 使用SDK快速接入 * @author SuperJava * @createTime 2017年3月20日 * @version 1.0 * @return */ @RequestMapping("AliPay") public String AliPay(HttpServletRequest req) throws Exception{ /** * 實例化客戶端 在使用SDK調用具體API前,進行初始化 */ AlipayClient alipayClient = new DefaultAlipayClient("https://openapi.alipay.com/gateway.do", APP_ID, APP_PRIVATE_KEY, "json", CHARSET, ALIPAY_PUBLIC_KEY, "RSA2"); /** * 實例化具體API對應的request類,類名稱和接口名稱對應,當前調用接口名稱: * alipay.open.public.template.message.industry.modify * alipayClient只需要初始化一次,后續調用不同的API都可以使用同一個alipayClient對象。 */ AlipayTradeWapPayRequest alipayRequest = new AlipayTradeWapPayRequest(); //在公共參數中設置回跳和通知地址 alipayRequest.setReturnUrl("http://www.baidu.com.com"); alipayRequest.setNotifyUrl("http://www.baidu.com.com/notify"); /** * SDK已經封裝掉了公共參數,這里只需要傳入業務參數 * 此次只是參數展示,未進行字符串轉義,實際情況下請轉義 (此處模擬請求參數,生產環境需要自己嵌套訂單信息) */ alipayRequest.setBizContent(" {" + " \"primary_industry_name\":\"購買理財服務\"," + " \"primary_industry_code\":\"10001/20102\"," + " \"secondary_industry_code\":\"10001/20102\"," + " \"secondary_industry_name\":\"IT科技/IT軟件與服務\"" + " }"); /** * 手機網站支付alipay.trade.wap.pay: * 對於頁面跳轉類API,SDK不會也無法像系統調用類API一樣自動請求支付寶並獲得結果, * 而是在接受request請求對象后,為開發者生成前台頁面請求需要的完整form表單的html(包含自動提交腳本), * 商戶直接將這個表單的String打印到頁面即可 */ String form = alipayClient.pageExecute(alipayRequest).getBody(); //調用SDK生成表單 req.setAttribute("aliPayForm", form); return "itemShow"; } }
代碼中的 ReturnUrl 和 NotifyUrl
ReturnUrl
支付寶支付成功頁面的跳轉
NotifyUrl
支付寶支付成功 通知的商戶接口
注意事項:
我看到有的開發人員 將處理業務功能放在 ReturnUrl 做同步處理 那樣 NotifyUrl 不需要傳 也是可以的
簡單的Demo 記錄一下