文章有不當之處,歡迎指正,如果喜歡微信閱讀,你也可以關注我的微信公眾號:
好好學java
,獲取優質學習資源。
一、微信官方文檔微信支付開發流程(公眾號支付)
首先我們到微信支付的官方文檔的開發步驟部分查看一下需要的設置。
[圖片上傳失敗...(image-5eb825-1531014079742)]
因為微信支付需要較高的權限,只有認證了得服務號才有使用微信支付接口的權限,我們個人很難申請到,所以需要向其他朋友借用賬號。
來到文檔的業務流程部分,查看微信支付的流程(我覺得這個還是需要十分仔細的了解和查看的,這有助於你理解微信開發的流程)。
然后,訪問微信支付接口是要傳遞的參數很多,見統一下單
[圖片上傳失敗...(image-df7051-1531014079742)]
通過查看上面的這些微信支付的官方文檔之后,我相信你對這些應該有了一定的了解了,但是還是覺得微信支付的開發十分的麻煩,所以我們接下來使用第三方的sdk來開發。
二、微信支付第三方sdk開發(公眾號支付)
這個是公眾號支付,我們使用best-pay-sdk,這個SDK使用PayRequest
和PayResponse
對請求接口和相應結果做了大量的封裝,主要需要動態傳入的參數是openid
(用戶唯一標識)和orderId
。接下來我們看看如何開發。
1、配置
//微信公眾賬號支付配置
WxPayH5Config wxPayH5Config = new WxPayH5Config();
wxPayH5Config.setAppId("xxxxx");
wxPayH5Config.setAppSecret("xxxxxxxx");
wxPayH5Config.setMchId("xxxxxx");
wxPayH5Config.setMchKey("xxxxxxx");
wxPayH5Config.setNotifyUrl("http://xxxxx");
//支付類, 所有方法都在這個類里
BestPayServiceImpl bestPayService = new BestPayServiceImpl();
bestPayService.setWxPayH5Config(wxPayH5Config);
2、發起支付
PayRequest payRequest = new PayRequest();
payRequest.setPayTypeEnum(BestPayTypeEnum.WXPAY_H5);
payRequest.setOrderId("123456");
payRequest.setOrderName("微信公眾賬號支付訂單");
payRequest.setOrderAmount(0.01);
payRequest.setOpenid("openid_xxxxxx");
bestPayService.pay(payRequest);
3、異步回調
bestPayService.asyncNotify();
這就是這個sdk所說的10行代碼解決微信支付。
支付完成后,微信會返回給把支付結果以一段支付xml的數據返回給我們,我們需要將這段數據傳遞給異步通知url(notify_url)
,來完成支付結果的驗證(驗證簽名,驗證支付狀態),這兩步SDK都為我們做好了,只需這樣調用bestPayService.asyncNotify(notifyData)
;,完成驗證后,我們需要返回給微信這樣一段數據:
<xml>
<return_code><![CDATA[SUCCESS]]></return_code>
<return_msg><![CDATA[OK]]></return_msg>
</xml>
告訴微信已完成驗證,不要再給我們發送異步通知的請求。
是不是還是不太清楚如何集成到項目?沒關系,這個還有示例demo,可以更加明了的清楚。
三、demo運行
demo網址為:https://github.com/Pay-Group/best-pay-demo
我們最主要的controller
放在這里:
@Controller
@Slf4j
public class PayController {
@Autowired
private BestPayServiceImpl bestPayService;
/**
* 發起支付
*/
@GetMapping(value = "/pay")
public ModelAndView pay(@RequestParam("openid") String openid,
Map<String, Object> map) {
PayRequest request = new PayRequest();
Random random = new Random();
//支付請求參數
request.setPayTypeEnum(BestPayTypeEnum.WXPAY_H5);
request.setOrderId(String.valueOf(random.nextInt(1000000000)));
request.setOrderAmount(0.01);
request.setOrderName("最好的支付sdk");
request.setOpenid(openid);
log.info("【發起支付】request={}", JsonUtil.toJson(request));
PayResponse payResponse = bestPayService.pay(request);
log.info("【發起支付】response={}", JsonUtil.toJson(payResponse));
map.put("payResponse", payResponse);
return new ModelAndView("pay/create", map);
}
/**
* 異步回調
*/
@PostMapping(value = "/notify")
public ModelAndView notify(@RequestBody String notifyData) throws Exception {
log.info("【異步回調】request={}", notifyData);
PayResponse response = bestPayService.asyncNotify(notifyData);
log.info("【異步回調】response={}", JsonUtil.toJson(response));
return new ModelAndView("pay/success");
}
}
這個可以自己去下載就可以,下面看一下一下如何運行
項目說明
需要在Jdk版本>1.8上運行
本項目采用SpringBoot1.5.1開發
項目結構
src/main/java/com/github/lly835
├── PayDemoApplication.java
├── ServletInitializer.java
├── config
│ └── PayConfig.java //支付密鑰配置類
└── controller
└── PayController.java //支付調用
運行示例
運行前需要先配置好密鑰, 見PayConfig.java
運行命令
git clone https://github.com/Pay-Group/best-pay-demo
cd best-pay-demo
mvn clean package
java -jar target/*.war
瀏覽器訪問http://127.0.0.1:8080/pay