微信公衆號支付開發全過程(java版)

文章有不當之處,歡迎指正,若是喜歡微信閱讀,你也能夠關注個人微信公衆號: 好好學java,獲取優質學習資源。

1、微信官方文檔微信支付開發流程(公衆號支付)

首先咱們到微信支付的官方文檔的開發步驟部分查看一下須要的設置。
[圖片上傳失敗...(image-5eb825-1531014079742)]php

由於微信支付須要較高的權限,只有認證了得服務號纔有使用微信支付接口的權限,咱們我的很難申請到,因此須要向其餘朋友借用帳號。java

來到文檔的業務流程部分,查看微信支付的流程(我以爲這個仍是須要十分仔細的瞭解和查看的,這有助於你理解微信開發的流程)。
這裏寫圖片描述git

而後,訪問微信支付接口是要傳遞的參數不少,見統一下單
[圖片上傳失敗...(image-df7051-1531014079742)]github

經過查看上面的這些微信支付的官方文檔以後,我相信你對這些應該有了必定的瞭解了,可是仍是以爲微信支付的開發十分的麻煩,因此咱們接下來使用第三方的sdk來開發。api

2、微信支付第三方sdk開發(公衆號支付)

這個是公衆號支付,咱們使用best-pay-sdk,這個SDK使用PayRequestPayResponse對請求接口和相應結果作了大量的封裝,主要須要動態傳入的參數是openid(用戶惟一標識)和orderId。接下來咱們看看如何開發。瀏覽器

一、配置

//微信公衆帳號支付配置
    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);

二、發起支付

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);

三、異步回調

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>

告訴微信已完成驗證,不要再給咱們發送異步通知的請求。app

是否是仍是不太清楚如何集成到項目?不要緊,這個還有示例demo,能夠更加明瞭的清楚。dom

3、demo運行

demo網址爲:https://github.com/Pay-Group/...

咱們最主要的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

相關文章
相關標籤/搜索